2010年11月27日 星期六

[Linux] SSH 命令和技巧

瀏覽數
來源:  http://wowubuntu.com/25-ssh-cmd.html SSH是一個非常偉大的工具,如果你要在互聯網上遠程連接到服務器,那麼SSH無疑是最佳的候選。 下面是通過網絡投票選出的25個最佳SSH命令,你必須牢記於心。  1、複製SSH密鑰到目標主機,開啟無密碼SSH登錄  ssh-copy-id user@host  如果還沒有密鑰,請使用ssh-keygen命令生成。  2、從某主機的80端口開啟到本地主機2001端口的ssh 隧道  ssh -N -L2001:localhost:80 somemachine  現在你可以直接在瀏覽器中輸入http://localhost:2001訪問這個網站。  3、將你的麥克風輸出到遠程計算機的揚聲器  dd if=/dev/dsp | ssh -c arcfour -C username@host dd of=/dev/dsp  這樣來自你麥克風端口的聲音將在SSH目標計算機的揚聲器端口輸出,但遺憾的是,聲音質量很差,你會聽到很多嘶嘶聲。  4、比較遠程和本地文件  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、通過你的電腦,複製遠程host1 主機上的文件到遠程host2 主機上的文件  ssh root@host1 “cd /somedir/tocopy/ && tar -cf – .” | ssh root@host2 “cd /samedir/tocopyto/ && tar -xf -”   如果只有你能同時訪問host1 和host 2 ,但它們不能訪問你的主機(因此ncat 是無法工作的),而且它們之間也無法直接訪問。  8、運行任何遠程主機上的 GUI 程序  ssh -fX <user>@<host> <program>   SSH 服務器端必須要具備以下條件:  X11Forwarding yes #確保X11 轉發是打開的  同時也可以打開  Compression delayed  當然,你要能訪問主機A才行。  9、創建到目標主機的持久化連接  ssh -MNf <user>@<host>  在後台創建到目標主機的持久化連接,將這個命令和你~/.ssh/config中的配置結合使用:  Host host  ControlPath ~/.ssh/master-%r@%h:%p  ControlMaster no  所有到目標主機的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個命令將非常有用,因為每次打開一個SSH連接時不 會創建新的套接字。  10、通過SSH 直接開啟並還原screen 命令  ssh -t remote_host screen –r  直接連接到遠程screen 會話(節省了無用的父bash進程)。  11、端口檢測(敲門)  knock <host> 3000 4000 5000 && ssh -p <port> user@host && knock <host> 5000 4000 3000   在一個端口上敲一下打開某個服務的端口(如SSH),再敲一下關閉該端口,需要先安裝knockd,下面是一個配置文件示例。    logfile = /var/log/knockd.log    sequence = 3000,4000,5000  seq_timeout = 5  command = /sbin/iptables -A INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT  tcpflags = syn    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-keygen -R <the_offending_host>  在這種情況下,最好使用專業的工具。  13、通過SSH運行複雜的遠程shell命令  ssh host -l user $(<cmd.txt)  更具移植性的版本:  ssh host -l user “`cat cmd.txt`”  14、通過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命令,這是遷移數據庫到新服務器最快最好的方法。  15、刪除文本文件中的一行,修復“SSH主機密鑰更改”的警告  sed -i 8d ~/.ssh/known_hosts  16、從一台沒有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登錄。  17、實時SSH網絡吞吐量測試  yes | pv | ssh $host “cat > /dev/null”  通過SSH連接到主機,顯示實時的傳輸速度,將所有傳輸數據指向/dev/null,需要先安裝pv。  如果是Debian:  apt-get install pv   如果是Fedora:  yum install pv  (可能需要啟用額外的軟件倉庫)。  18、如果建立一個可以重新連接的遠程GNU screen  ssh -t user@some.domain.com /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命令的 快速參考。  19、繼續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  20、通過SSH W/ WIRESHARK分析流量  ssh root@server.com 'tshark -f “port !22″ -w -' | wireshark -k -i –  使用tshark捕捉遠程主機上的網絡通信,通過SSH連接發送原始pcap數據,並在wireshark中顯示,按下Ctrl+C將停止捕捉,但也會關閉wireshark窗口,可以傳遞一個“-c #”參數給 tshark,讓它只捕捉“#”指定的數據包類型,或通過命名管道重定向數據,而不是直接通過SSH傳輸給wireshark,我建議你過濾數據包,以節約帶寬,tshark可以使用tcpdump替代:  ssh root@example.com tcpdump -w – 'port !22′ | wireshark -k -i –  21、保持SSH會話永久打開  autossh -M50000 -t server.example.com 'screen -raAd mysession'  打開一個SSH會話後,讓其保持永久打開,對於使用筆記本電腦的用戶,如果需要在Wi-Fi熱點之間切換,可以保證切換後不會丟失連接。  22、更穩定,更快,更強的SSH客戶端  ssh -4 -C -c blowfish-cbc  強制使用IPv4,壓縮數據流,使用Blowfish加密。  23、使用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  24、一步將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。  25、將標準輸入(stdin)複製到你的X11緩衝區  ssh user@host cat /path/to/some/file | xclip

沒有留言: