广州明生医药有限公司


25个好用的Shell脚本常用命令分享

网络编程 25个好用的Shell脚本常用命令分享 06-21

1.列出所有目录使用量,并按大小排序。

ls|xargs du -h|sort -rn 
#不递归下级目录使用du -sh

2.查看文件排除以#开关和空白行,适合查看配置文件。
egrep -v "^#|^$"  filename
sed '/#.*$/d; /^ *$/d'

3.删除空格和空行。
sed '/^$/d' filename #删除空行
sed 's/ //g' filename
sed 's/[[:space:]]//g' filename

4.删除#后的注释。
sed -i 's/#.*$//g' filename

5.踢出登录的用户,用who查看终端。
pkill -KILL -t pts/0

6.删除空文件。
find / -type f -size 0 -exec rm -rf {} ;

7.查找进程pid并kill。
pgrep nginx|xargs kill 
pidof nginx|xargs kill

8.获取当前IP地址,强大的awk,一个命令搞定。
ifconfig |awk -F"[ ]+|[:]" 'NR==2 {print $4}'

9.文本方式查看wtmp日志
utmpdump /var/log/wtmp

10.以内存大小排序列出进程
ps aux --sort=rss |sort -k 6 -rn

11.简单web server列出当前目录文件,端口8000:
python -m SimpleHTTPServer

12.以管道输入方式修改用户密码:
echo "password" |passwd ?stdin root

12.生成SSH证书并复制到远端服务器:
ssh-keygen -y -f ~/.ssh/id_rsa && cat ~/.ssh/id_rsa.pub | ssh root@host "cat - >> ~/.ssh/authorized_keys"

13.shell下新建文件夹并进入,以下加入bashrc:
mkcd ( ){
mkdir $1
cd $1
}

14.通过SSH快速备份文件到另一服务器:
tar zcvf - back/ | ssh root@www.gimoo.net tar xzf - -C /root/back/

15.用wget下载整站:
wget -r -p -np -k http://www.gimoo.net
#r递归 p下载所有文件 np不下载上级 k转换相对链接

16.Kill整个进程树:
pstree -ap 10277|grep -oP '[0-9]{4,6}'|xargs kill -9

17.生成随机字符:
cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 32 | head -n 1

18.使用awk导出最后一列非空的数据:
awk -F "|" '{if($NF!="") print $NF}'

19.查找每行大于几位数的数据:
awk -F '' '{if(NF>6) print $0}'

20.获取HTML页面文本内容:
lynx -dump www.gimoo.net #包含页面的URL
w3m -no-cookie -dump www.gimoo.net
links -dump www.gimoo.net #对中文内容支持不好

21.端口重定向:
socat TCP4-LISTEN:1234,reuseaddr,fork, TCP4:www.baidu.com:80

22.行前或行后插入:
sed 'p;s/^.*$/--------/' file
awk '{print $0;print "-------"}' file

23.行首或行尾插入:
sed 's/^/new/g' file
sed 's/$/new/g' file

24.逐字换行:
awk -F "" '{for(i=1;i<=NF;i++) print $i}'

25.目录中大量文件删除:
ls | xargs rm

svn服务器启动和svn服务器重启、停止等操作脚本分享
#!/bin/bashcase"$1"instart)svnserve-d-r/svndatasvnport=`netstat-natp|grepsvnserve|awk-F:'{print$4}'|awk'NR==1'`if[$svnport-eq3690]thenecho"SVNServerAlreadyRunnning.Port:3690"elseecho"SVNServerDoesNotS

定时导出mysql本地数据替换远程数据库数据脚本分享
需求在每天的5点将192.168.3.5上ser_a库中的tb_a表导入到192.168.3.6上的ser_b库中,表名还叫tb_a服务端脚本/usr/shell_clubs/auto_sql/server.sh#!/bin/sh#codebyscpman/usr/bin/fin

使用shell检查并修复mysql数据库表的脚本
#!/bin/sh#codebyscpman#功能:检查并修复mysql数据库表#将此脚本加到定时中,脚本执行时,等会读库,列出要修复的所有表,然后计时,开始修复#修复过程中将


编辑:广州明生医药有限公司

标签:脚本,递归,服务器,文件,空行