Shell

shell命令

2022-06-16  本文已影响0人  无味wy

1、查找目录下所有以 .zip 结尾的文件移动到指定目录

find . -name "*.zip" -exec mv {} ./backup/

2、查找当前目录 30 天以前大于 100M 的 log 文件并删除

find . -name "*.log" –mtime +30 –typef –size +100M | xargs rm –rf {}

3、批量解压当前目录下以 .zip 结尾的所有文件到指定目录

for i  in  `find . –name "*.zip" –type f`
do
  unzip –d $i /data/www/
done
注解:for i in (command);do … done 为 for 循环的一个常用格式,其中i为变量,可以自己指定

4、写一个脚本查找最后创建时间是 3 天前,后缀是 *.log 的文件并删除

find . -mtime +3  -name "*.log" | xargs rm -rf {}

5、写一个脚本将某目录下大于 100k 的文件移动至 /tmp 下

find . -size +100k -exec mv {} /tmp

6、如何判断某个目录是否存在,不存在则新建,存在则打印信息

if [ ! –d /data/backup/ ];then
   mkdir –p /data/backup/
else
   echo  "目录已存在"
fi
-d 代表目录

7、替换文件中的目录

sed 's:/user/local:/tmp:g' test.txt
或者
sed -i 's//usr/local//tmp/g' test.txt

8、sed 常用命令

如何去掉行首的.字符: sed -i 's/^.//g' test.txt

在行首添加一个a字符: sed 's/^/a/g'    test.txt

在行尾添加一个a字符: sed 's/$/a/'     tets.txt

在特定行后添加一个z字符:sed '/rumen/az' test.txt

在行前加入一个c字符: sed '/rumenz/ic' test.txt

9、取出磁盘分区剩余容量

df / | grep / | awk '{print $4}'

#替换 / 为别的分区的值

10、统计 Nginx 访问日志 访问量排在前20的ip地址

cat access.log |awk '{print $1}'|sort|uniq -c |sort -nr |head -20
注解:sort 排序、uniq(检查及删除文本文件中重复出现的行列 )

11、修改文本中以ab 结尾的替换成 cd:

sed -e 's/ab$/cd/g' b.txt

12、MySQL批量备份单库

for database in `cat /data/name.txt`; do mysqldump -usuproot -pzhi -B $database -h 192.168.0x.x4 --set-gtid-purged=OFF >/data/"$database".sql; done

#name.txt里是库的名字

13、取出磁盘分区剩余容量,不带单位 $1为传参

df -h $1 | grep $1 | awk -F '[ ]+|[G]' '{print $6}'

14、判断远程主机文件是否存在

ssh work@192.168.64.5 test -e /home/work
if [ "$?" != 0 ];then
   scp -rp ${WORKSPACE}/dist work@192.168.6.x:/home
else
   ssh work@192.168.6.x rm -rf /home
   scp -rp ${WORKSPACE}/dist work@192.168.6.x:/home
fi

15、查看配置文件去空行,去注释

grep -v "^#" name.conf | grep -v "^$"
上一篇下一篇

猜你喜欢

热点阅读