shell下令

分享
计算机软件开发 2024-9-2 23:04:45 100 0 来自 中国
1、查找目次下全部以 .zip 末了的文件移动到指定目次
find . -name "*.zip" -exec mv {} ./backup/2、查找当前目次 30 天从前大于 100M 的 log 文件并删除
find . -name "*.log" -mtime +30 -type f -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 {} /tmp6、怎样判断某个目次是否存在,不存在则新建,存在则打印信息
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.txt8、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.txt9、取出磁盘分区剩余容量
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.txt12、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/workif [ "$?" != 0 ];then   scp -rp ${WORKSPACE}/dist work@192.168.6.x:/homeelse   ssh work@192.168.6.x rm -rf /home   scp -rp ${WORKSPACE}/dist work@192.168.6.x:/homefi15、检察设置文件去空行,去解释
grep -v "^#" name.conf | grep -v "^$"
您需要登录后才可以回帖 登录 | 立即注册

Powered by CangBaoKu v1.0 小黑屋藏宝库It社区( 冀ICP备14008649号 )

GMT+8, 2024-10-19 16:24, Processed in 0.169074 second(s), 32 queries.© 2003-2025 cbk Team.

快速回复 返回顶部 返回列表