linux SSH 彙總

SSH是一個非常偉大的工具,如果你要在互聯網上遠程連接到服務器,那麼SSH無疑是最佳的候選。但是,你對SSH知道多少呢?下面是25個最佳的SSH命令,看看有你用的着的嗎?或者試用一下也不錯。

1. 複製SSH密鑰到目標主機,開啓無密碼SSH登錄

ssh-copy-id -i   -i ~/.ssh/id_dsa.pub  user@host
如果還沒有密鑰,請使用ssh-keygen命令生成。

2、從某主機的80端口開啓到本地主機2001端口的隧道

ssh -N -L2001:localhost:80 somemachine
現在你可以直接在瀏覽器中輸入http://localhost:2001訪問這個網站。

3、查看比較遠程和本地文件

ssh user@host cat /path/to/remotefile |

ssh user@host cat /path/to/remotefile | diff /path/to/localfile –

在比較本地文件和遠程文件是否有差異時這個命令很管用。

5、通過SSH掛載目錄/文件系統

sshfs name@server:/path/to/folder /path/to/mount/point
http://fuse.sourceforge.net/sshfs.html下載sshfs,它允許你跨網絡安全掛載一個目錄。

6、通過中間主機建立SSH連接

ssh -t reachable_host ssh unreachable_host
Unreachable_host表示從本地網絡無法直接訪問的主機,但可以從reachable_host所在網絡訪問,這個命令通過到reachable_host的“隱藏”連接,創建起到unreachable_host的連接。

7、直接連接到只能通過主機B連接的主機A

ssh -t hostA ssh hostB
當然,你要能訪問主機A才行。

8、創建到目標主機的持久化連接

ssh -MNf @
在後臺創建到目標主機的持久化連接,將這個命令和你~/.ssh/config中的配置結合使用:

Host host ControlPath ~/.ssh/master-%r@%h:%p ControlMaster no
所有到目標主機的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個命令將非常有用,因爲每次打開一個SSH連接時不會創建新的套接字。

9、通過SSH連接屏幕

ssh -t remote_host screen –r
直接連接到遠程屏幕會話(節省了無用的父bash進程)。

10、端口檢測(敲門)

knock 3000 4000 5000 && ssh -p user@host && knock 5000 4000 3000
在一個端口上敲一下打開某個服務的端口(如SSH),再敲一下關閉該端口,需要先安裝knockd,下面是一個配置文件示例。

[options] logfile = /var/log/knockd.log [openSSH] sequence = 3000,4000,5000 seq_timeout = 5 command = /sbin/iptables -A INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT tcpflags = syn [closeSSH] sequence = 5000,4000,3000 seq_timeout = 5 command = /sbin/iptables -D INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT tcpflags = syn


12、通過SSH運行復雜的遠程shell命令

ssh host -l user $(
更具移植性的版本:

ssh host -l user “cat cmd.txt

13、通過ssh將mysql數據庫複製到新服務器

mysqldump –add-drop-table –extended-insert –force –log-error=error.log -uuser -ppass old_db_name | ssh -c user@newhost “mysql -uuser -ppass new_db_name”
通過壓縮的ssh隧道dump一個mysql數據庫,將其作爲輸入傳遞給mysql命令,我認爲這是遷移數據庫到新服務器最快最好的方法。

14、刪除文本文件中的一行,修復“ssh主機密鑰更改”的警告

sed -i 8d ~/.ssh/known_hosts

15、從一臺沒有ssh-copy-id命令的主機將你的ssh公鑰複製到服務器

cat ~/.ssh/id_rsa.pub | ssh user@machine “mkdir ~/.ssh; cat >> ~/.ssh/authorized_keys”
如果你使用mac os x或其它沒有ssh-copy-id命令的*nix變種,這個命令可以將你的公鑰複製到遠程主機,因此你照樣可以實現無密碼ssh登錄。

16、實時ssh網絡吞吐量測試

yes | pv | ssh $host “cat > /dev/null”
通過ssh連接到主機,顯示實時的傳輸速度,將所有傳輸數據指向/dev/null,需要先安裝pv。

如果是debian:

apt-get install pv
如果是fedora:

yum install pv
(可能需要啓用額外的軟件倉庫)。

17、如果建立一個可以重新連接的遠程gnu screen

ssh -t [email protected] /usr/bin/screen –xrr
人們總是喜歡在一個文本終端中打開許多shell,如果會話突然中斷,或你按下了“ctrl-a d”,遠程主機上的shell不會受到絲毫影響,你可以重新連接,其它有用的screen命令有“ctrl-a c”(打開新的shell)和“ctrl-a a”(在shell之間來回切換),請訪問http://aperiodic.net/screen/quick_reference閱讀更多關於screen命令的快速參考。

18、繼續scp大文件

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file
它可以恢復失敗的rsync命令,當你通過vpn傳輸大文件,如備份的數據庫時這個命令非常有用,需要在兩邊的主機上安裝rsync。

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file local -> remote

rsync –partial –progress –rsh=ssh $user@$host:$remote_file $destination_file remote -> local

819、通過ssh w/ wireshark分析流量

ssh [email protected] ‘tshark -f “port !22″ -w -' | wireshark -k -i –
使用tshark捕捉遠程主機上的網絡通信,通過ssh連接發送原始pcap數據,並在wireshark中顯示,按下ctrl c將停止捕捉,但也會關閉wireshark窗口,可以傳遞一個“-c #”參數給tshark,讓它只捕捉“#”指定的數據包類型,或通過命名管道重定向數據,而不是直接通過ssh傳輸給wireshark,我建議你過濾數據包,以節約帶寬,tshark可以使用tcpdump替代:

ssh [email protected] tcpdump -w – ‘port !22′ | wireshark -k -i –

20、保持ssh會話永久打開

autossh -m50000 -t server.example.com ‘screen -raad mysession’
打開一個ssh會話後,讓其保持永久打開,對於使用筆記本電腦的用戶,如果需要在wi-fi熱點之間切換,可以保證切換後不會丟失連接。

21、更穩定,更快,更強的ssh客戶端

ssh -4 -c -c blowfish-cbc
強制使用ipv4,壓縮數據流,使用blowfish加密。

22、使用cstream控制帶寬

tar -cj /backup | cstream -t 777k | ssh host ‘tar -xj -c /backup’
使用bzip壓縮文件夾,然後以777k bit/s速率向遠程主機傳輸。cstream還有更多的功能,請訪問http://www.cons.org/cracauer/cstream.html#usage瞭解詳情,例如:

echo w00t, i’m 733 | cstream -b1 -t2

23、一步將ssh公鑰傳輸到另一臺機器

ssh-keygen; ssh-copy-id user@host; ssh user@host
這個命令組合允許你無密碼ssh登錄,注意,如果在本地機器的~/.ssh目錄下已經有一個ssh密鑰對,ssh-keygen命令生成的新密鑰可能會覆蓋它們,ssh-copy-id將密鑰複製到遠程主機,並追加到遠程賬號的~/.ssh/authorized_keys文件中,使用ssh連接時,如果你沒有使用密鑰口令,調用ssh user@host後不久就會顯示遠程shell。

24、將標準輸入(stdin)複製到你的x11緩衝區

ssh user@host cat /path/to/some/file | xclip
你是否使用scp將文件複製到工作用電腦上,以便複製其內容到電子郵件中?xclip可以幫到你,它可以將標準輸入複製到x11緩衝區,你需要做的就是點擊鼠標中鍵粘貼緩衝區中的內容。

發佈了27 篇原創文章 · 獲贊 6 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章