標籤:
1.顯示消耗記憶體/CPU最多的10個進程
ps aux | sort -nk +4 | tail
ps aux | sort -nk +3 | tail
2.查看Apache的並發請求數及其TCP串連狀態
netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘
3.找出自己最常用的10條命令及使用次數(或求訪問最多的ip數)
sed -e ‘s/| /\n/g‘ ~/.bash_history |cut -d ‘‘ -f 1 | sort | uniq -c | sort -nr | head
4.日誌中第10個欄位表示連線時間,求平均連線時間
cat access_log |grep “connect cbp” |awk ‘BEGIN{sum=0;count=0;}{sum+=$10;count++;}END{printf(“sum=%d,count=%d,avg=%f\n”,sum,count,
sum/count)}’
5.lsof命令
lsof abc.txt 顯示開啟檔案abc.txt的進程
lsof -i :22 知道22連接埠現在運行什麼程式
lsof -c abc 顯示abc進程現在開啟的檔案
lsof -p 12 看進程號為12的進程開啟了哪些檔案
6.殺掉一個程式的所有進程
pkill -9 httpd
killall -9 httpd
注意盡量不用-9,資料庫伺服器上更不能輕易用kill,否則造成重要資料丟失後果將不堪設想。
7.rsync命令(要求只同步某天的壓縮檔,而且遠程目錄保持與本地目錄一致)
/usr/bin/rsync -azvR –password-file=/etc/rsync.secrets `find . -name “*$yesterday.gz” -type f ` [email protected]::logbackup/13.21/
8.把目錄下*.sh檔案改名為*.SH
find . -name "*.sh" | sed ‘s/\(.*\)\.sh/mv \0 \1.SH/‘ |sh
find . -name "*.sh" | sed ‘s/\(.*\)\.sh/mv & \1.SH/‘|sh (跟上面那個效果一樣)
9.ssh執行遠端程式,並在本地顯示
ssh -n -l zouyunhao 192.168.2.14 "ls -al /home/zouyunhao"
10. 直接用命令列修改密碼
echo "zouyunhaoPassword" |passwd –stdin zouyunhao
ssh-keygen
ssh-copy-id -i ~/.ssh/id_rsa.pub [email protected]
12.以http方式共用當前檔案夾的檔案
$ python -m SimpleHTTPServer
在瀏覽器訪問http://IP:8000/即可下載目前的目錄的檔案。
13.shell段注釋
:<<‘echo hello,world!‘
14.查看伺服器序號
dmidecode |grep "Serial Number"
(查看機器其他硬體資訊也可用這個命令)
15.查看網卡是否有網線物理串連
/sbin/mii-tool
查看apache的進程數(prefork模式下Apache的並發數)
ps -ef | grep httpd | wc –l
找出cpu利用率高的20個進程
ps -e -o pcpu,pid,user,sgi_p,cmd |grep -v PID| sort -k 1| tail -20
查看tcp連結狀態
netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘
時間同步
sudo ntpdate ntp.ubuntu.com
或
ntpdate s1a.time.edu.cn
擷取文字文件的行數
# awk ‘{print NR}‘ test|tail -n1
得到進程pid
pgrep java
快速備份某檔案
cp keepalived.conf{,.bak} 將keepalived.conf備份 為 keepalived.conf.bak
獲得mysql使用者下的進程總數
ps -ef|awk ‘{print $1}‘|grep "mysql"|grep -v "grep"|wc -l
查看80連接埠串連數
netstat -antp | grep 80 | grep ESTABLISHED -c
查看8080連接埠
netstat -na | grep ESTAB | grep 8080 | wc -l
查看返回的數字就是apache的運行進程數
ps -ef | grep httpd | wc -l
列舉系統中已經被開啟的檔案命令lsof
#-c 顯示ssh開頭的命令開啟的檔案
lsof -c ssh
#-p 顯示某進程開啟的檔案
lsof -p 5200
#+d 顯示某目錄下的開啟檔案 +D 顯示某目錄下的開啟檔案,包括子目錄。
lsof +d /usr/local
lsof +D /usr/local
#-u 顯示某使用者開啟的檔案
lsof -u root
#-i 顯示某協議,ip,連接埠上開啟的檔案
lsof -i [email protected]:22
? 快速備份一個檔案
cp filename{,.bak} 快速備份一個檔案,filename{,.bak} 這一段會被展開成filename filename.bak再傳給cp。
? 清空或建立一個檔案
> file.txt
? 重設終端
reset ,如果你試過不小心cat了某個二進位檔案,很可能整個終端就傻掉了,可能不會換行,沒法回顯,大堆亂碼之類的,這時候敲入reset斷行符號,不管命令有沒有顯示,就能回複正常了。
? 執行一條命令但不儲存到 history 中
<space> command 空格加要執行的命令,執行一條命令但不儲存到 history 中。
? 顯示目前的目錄中所有子目錄的大小
du -h --max-depth=1 顯示目前的目錄中所有子目錄的大小,max-depth 指目錄層級。
? 從A登陸到B
ssh -t host_A ssh host_B 如果目標機器host_B處於比較複雜的網路環境,本機無法直接存取,但另外一台host_A能夠訪問到host_B,而且也能被本機訪問到,那上述命令就解決了方便登入host_B的問題。
ssh -p 8888 [email protected]
? scp傳輸檔案
scp /root/bb/api.war [email protected]:/root/tools
也可以一次傳輸多個目標。
scp /root/bb/api.war [email protected]:/root/tools [email protected]:/root/tools
如果ssh預設連接埠修改為了8888 使用下面
scp -P 8888 /root/bb/api.war [email protected]:/root/tools
? 將my.cnf中前面有#的配置行去掉
more /etc/my.cnf |sed -n ‘/^#/!p‘>my2.cnf
? ssh執行遠端程式,並在本地顯示
ssh -p 22 -n -l root 192.168.1.128 "ls /root/tools"
ssh -p 22 -n -l root 192.168.1.128 "rm -rf /root/tools/dovecot-1.2.16-1_114.el5.i386.rpm"
? 查看進程啟用時間
ps -A -opid,stime,etime,args|grep java
? VI替換文字
:n,$s/vivian/sky/g 替換第 n 行開始到最後一行中每一行所有 vivian 為 sky
? 將檔案按時間最新的排序顯示
ls -lt 或 ll –t
? 將檔案按大小排序顯示
ll -S
netstat -an | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘
查看系統tcp串連中各個狀態的串連數。
netstat -an |grep 80 |grep ESTA |awk ‘{print$5 "\n"}‘ |awk ‘BEGIN {FS=":"} {print $1 "\n"}‘ |sort |uniq
查看和本機80連接埠建立串連並狀態在established的所有ip
netstat -n | awk ‘/^tcp/ {n=split($(NF-1),array,":");if(n<=2)++S[array[(1)]];else++S[array[(4)]];++s[$NF];++N} END {for(a in S){printf("%-20s %s\n", a, S[a]);++I}printf("%-20s %s\n","TOTAL_IP",I);for(a in s) printf("%-20s %s\n",a, s[a]);printf("%-20s %s\n","TOTAL_LINK",N);}‘
輸出每個ip的串連數,以及總的各個狀態的串連數
推薦營運shell命令