1. sort
简介:顾名思义,就是用来排序的工具,在我们日常工作中对于重复列的多行输出,如果想要对内容按照特定规则排序,此时就用到了sort工具。
原理:sort 将文件的每一行作为一个单位,相互比较,比较原则默认情况是从首字符向后,依次按 ASCII 码值进行比较, 后将他们按升序输出。
语法:sort [OPTION]... [FILE]…
- -t:指定以什么作为列分割
- -k:用来制定利用那列进行排序,通常
-t
于-k
配合使用 - -r:将文本文件降序输出
- -n:以数组来进行生序排序
- -f:忽略大小写字母
- -u:取消重复的行
在此我们不全部展开起所有选项,只根据日常经验结合实际案例列举最常用的选项进行说明。
[root@10-234-1-235 ~]saslauth:x:499:76:Saslauthd user:/var/empty/saslauth:/sbin/nologin
gitlab-www:x:498:497::/var/opt/gitlab/nginx:/bin/falsegit:x:497:496::/var/opt/gitlab:/bin/sh
gitlab-redis:x:496:495::/var/opt/gitlab/redis:/bin/falsegitlab-psql:x:495:494::/var/opt/gitlab/postgresql:/bin/sh
gitlab-prometheus:x:494:493::/var/opt/gitlab/prometheus:/bin/sh
mongod:x:493:492:mongod:/var/lib/mongo:/bin/falsenobody:x:99:99:Nobody:/:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
apache:x:48:48:Apache:/var/www:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
halt:x:7:0:halt:/sbin:/sbin/haltshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownsync:x:5:0:sync:/sbin:/bin/sync
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
root:x:0:0:root:/root:/bin/bash
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
通过上例可以看到,利用-t
选项指定/etc/passwd文件中,以:
作为列进行分割,指定uid的列为k3
,-n以数字进行排序,-r
为倒序排序输出。
2. uniq
语法:uniq [OPTION]... [INPUT [OUTPUT]]
- -c: 打印出现的次数,只能统计相邻的;
- -d: 只打印重复行;
- -u: 只打印不重复行;
- -D: 只打印重复行,并且把所有重复行打印出来。
- 对/etc/passwd中以
:
,对最后一列求出现的次数
[root@master ~]/bin/bash/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/bin/sync/sbin/shutdown/sbin/halt/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/bin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin/sbin/nologin[root@master ~]
22 /sbin/nologin 1 /sbin/shutdown
1 /sbin/halt 1 /bin/sync 1 /bin/nologin 1 /bin/bash
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
先利用awk打印出最后一列内容,之后利用sort 来进行排序,将相同的字符规在一起输出,最后对相同的行进行去重,得出每种不同类型shell出现的次数,最后对数学从大到小排序。
3. find
简介:顾名思义,就是用来在系统中查找文件的工具,可以指定一个基础起始目录,根据不同的选项查找不同的文件。
语法:find path -option [ -print ] [ -exec -ok command ] {} \;
原理:find 根据option在指定的系统路径中查找文件,如果查找到与对应的exec命令,则执行对应的command。
- print: find 命令将匹配的文件输出到标准输出;
- exec: find 命令对匹配的文件执行该参数所给出的 shell 命令。相应命令的形式为 ‘command’ {} ;,注意 {} 和 \;之间的空格;
- ok: 和 - exec 的作用相同,只不过以一种更为安全的模式来执行该参数所给出的 shell 命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行;
- -name filename - -perm - -user username - -group groupname - -mtime -n +n - -atime -n +n - -ctime -n +n - -type b/d/c/p/l/f - -size n [c] - -depth - -prune
在此我们对命令支持的选项全部展开详解,根据日常经验结合实际案例列举最常用的选项进行说明:
- 在当前目录寻找文件名称以
.txt
结尾的文件并打印出来
[root@master ~]/root/kubesphere-all-advanced-2.0.2/scripts/os/requirements.txt/root/kubesphere-all-advanced-2.0.2/kubesphere/roles/storages/NFS-Server/files/nfs-server-provisioner/templates/NOTES.txt/root/kubesphere-all-advanced-2.0.2/kubesphere/roles/ks-devops/jenkins/files/jenkins/jenkins-update-center/templates/NOTES.txt/root/kubesphere-all-advanced-2.0.2/kubesphere/roles/ks-devops/harbor/files/harbor/harbor/templates/NOTES.txt/root/kubesphere-all-advanced-2.0.2/kubesphere/roles/metrics-server/files/metrics-server/templates/NOTES.txt/root/kubesphere-all-advanced-2.0.2/kubesphere/roles/openpitrix/files/openpitrix/kubernetes/password.txt
- 查找 /usr/bin 目录下大于 10M 的文件
[root@master ~]-rwxr-xr-x. 1 root root 13606800 Jul 10 2018 /usr/bin/ceph-dencoder-rwxr-xr-x. 1 root root 15863688 Jul 10 2018 /usr/bin/ceph-objectstore-tool-rwxr-xr-x. 1 root root 15589080 Jul 10 2018 /usr/bin/ceph-osd-rwxr-xr-x. 1 root root 33073928 Feb 10 2019 /usr/bin/docker-rwxr-xr-x. 1 root root 38088856 Feb 10 2019 /usr/bin/docker-containerd-rwxr-xr-x. 1 root root 68608416 Feb 10 2019 /usr/bin/dockerd-rwxr-xr-x. 1 root root 20895160 Feb 10 2019 /usr/bin/docker-containerd-ctr-rwxr-xr-x. 1 root root 10785264 Jul 10 2018 /usr/bin/ceph-mon
[root@master ~]./.helm/repository/cache/local-index.yaml./kubesphere-all-v2.1.0/k8s/extra_playbooks/inventory./kubesphere-all-v2.1.0/k8s/extra_playbooks/roles./kubesphere-all-v2.1.0/k8s/contrib/terraform/openstack/hosts
4. date
在我们编写 Shell 的时候经常遇到需要记录日志的情况,在记录日志的时候需要打上时间戳,以便后期查看那个时间节点运行执行的操作,此时就需要用到 date 命令
简介:date 可以用来显示或设定系统的日期与时间。
-d<字符串>:显示字符串所指的日期与时间。字符串前后必须加上双引号;
-s<字符串>:根据字符串来设置日期与时间。字符串前后必须加上双引号;
-u:显示GMT;
%Y %m %d %t %H %I %M %S %j %Z %z %F %T
#!/bin/bash
start=$(date +%s)
echo "$(date +%F" "%T) 开始执行命令"
sleep 5
echo "$(date +%F" "%T) 执行命令完成"
end=$(date +%s)
difference=$(( end - start ))
echo "执行命令总耗时:$difference seconds."
[root@master ~]# bash time.sh
2020-04-19 10:19:58 开始执行命令
2020-04-19 10:20:03 执行命令完成
执行命令总耗时:5 seconds.
5. xargs
简介:xargs 全称是 transform arguments,意为转换参数,它将标准输入转换为命令行参数。因为 linux 命令行中经常要使用到管道符连接不同的命令,但是有些命令不支持标准输入,此时就需要使用 xargs 将标准输入转换为参数,
语法:stdin_input | xargs [option] cmd
原理:xargs 一般是通过管道符接受标准输入并将其转换为命令行参数传递给 cmd。
[root@master ~]123456[root@master ~]1 23 45 6
ls *.log |xargs rm -r f {}
- 查找 /home/data 下权限为 644 的文件修改权限为 600
find /home/data -perm 644 | xargs chmod 600
find / -name *.jpg -type f -print | xargs tar -cvzf images.tar.gz
6. 实例
6.1 需求
我们经常在 Linux 系统操作操作文件,俗话说常在河边走,哪有不湿鞋,一不小心删除重要文件是非常危险的。我们可以利用 Shell 脚本来制作一个类似于 Windows 下的回收站,配合定时任务,定期清理这个回收站中的内容,从而达到缓冲及规避危险操作。
6.2 思路
- 通过 alias rm 来将删除的文件,移动文件到一个回收站目录;
- 定期的在系统磁盘允许可控的使用率情况下,对回收站目录下的文件进行删除。
6.3 实现
#!/bin/bashCMD_SCRIPTS=$HOME/.rm_scripts.sh
TRASH_DIR=$HOME/.TRASH_DIR
CRON_FILE=/var/spool/cron/root
BASHRC=$HOME/.bashrc[ ! -d ${TRASH_DIR} ] && mkdir -p ${TRASH_DIR}cat > $CMD_SCRIPTS <<EOF
PARA_CNT=\$#TRASH_DIR=$TRASH_DIRfor i in \$*; do
DATE=\$(date +%F%T)
fileName=\$(basename \$i)
mv \$i \$TRASH_DIR/\$fileName.\$DATEdone
EOFsed -i "s@$(grep 'alias rm=' $BASHRC)@alias rm='bash ${CMD_SCRIPTS}'@g" $BASHRCsource $HOME/.bashrcecho "0 0 * * * rm -rf $TRASH_DIR/*" >> $CRON_FILEecho "删除目录:$TRASH_DIR"echo "删除脚本:$CMD_SCRIPTS"echo "请执行:source $BASHRC 来加载文件或退出当前shell重新登录"
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
[root@10-234-1-235 ~]删除目录:/root/.TRASH_DIR
删除脚本:/root/.rm_scripts.sh
请执行:source /root/.bashrc 来加载文件或退出当前shell重新登录[root@10-234-1-235 ~][root@10-234-1-235 ~][root@10-234-1-235 ~]total 16drwxr-xr-x. 3 root root 4096 Apr 18 20:11 .dr-xr-xdrwxr-xr-x. 2 root root 4096 Apr 18 20:10 testdir.2020-04-1820:11:37-rw-r[root@10-234-1-235 ~]0 0 * * * rm -rf /root/.TRASH_DIR/*
7. 小结
Shell 编程就是利用工具加数据结构流程控制实现一组操作,所以掌握更多常用的工具或命令非常利于我们编写 Shell 脚本,平时可以多尝试利用各种命令或工具,并在 Shell 中熟练运用它们,勤练并反思总结,归纳整理,日积月累就会形成自己强大的工具库。