溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

有哪些常用且重要的SSH命令

發(fā)布時間:2021-07-28 17:32:47 來源:億速云 閱讀:168 作者:chen 欄目:系統(tǒng)運維

本篇內(nèi)容主要講解“有哪些常用且重要的SSH命令”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“有哪些常用且重要的SSH命令”吧!

OpenSSH是SSH連接工具的免費版本。telnet,rlogin和ftp用戶可能還沒意識到他們在互聯(lián)網(wǎng)上傳輸?shù)拿艽a是未加密的,但SSH是加密的,OpenSSH加密所有通信(包括密碼),有效消除了竊聽,連接劫持和其它攻擊。此外,OpenSSH提供了安全隧道功能和多種身份驗證方法,支持SSH協(xié)議的所有版本。

SSH是一個非常偉大的工具,如果你要在互聯(lián)網(wǎng)上遠程連接到服務器,那么SSH無疑是最佳的候選。下面是通過網(wǎng)絡(luò)投票選出的25個最佳SSH命令,你必須牢記于心。

(注:有些內(nèi)容較長的命令,在本文中會顯示為截斷的狀態(tài)。如果你需要閱讀完整的命令,可以把整行復制到您的記事本當中閱讀。)

1、復制SSH密鑰到目標主機,開啟無密碼SSH登錄

ssh-copy-id user@host

如果還沒有密鑰,請使用ssh-keygen命令生成。

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

ssh -N -L2001:localhost:80 somemachine

現(xiàn)在你可以直接在瀏覽器中輸入http://localhost:2001訪問這個網(wǎng)站。

3、將你的麥克風輸出到遠程計算機的揚聲器

dd if=/dev/dsp | ssh -c arcfour -C username@host dd of=/dev/dsp

這樣來自你麥克風端口的聲音將在SSH目標計算機的揚聲器端口輸出,但遺憾的是,聲音質(zhì)量很差,你會聽到很多嘶嘶聲。

4、比較遠程和本地文件

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

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

5、通過SSH掛載目錄/文件系統(tǒng)

sshfs name@server:/path/to/folder /path/to/mount/point

從http://fuse.sourceforge.net/sshfs.html下載sshfs,它允許你跨網(wǎng)絡(luò)安全掛載一個目錄。

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

ssh -t reachable_host ssh unreachable_host

Unreachable_host表示從本地網(wǎng)絡(luò)無法直接訪問的主機,但可以從reachable_host所在網(wǎng)絡(luò)訪問,這個命令通過到reachable_host的“隱藏”連接,創(chuàng)建起到unreachable_host的連接。

7、將你的SSH公鑰復制到遠程主機,開啟無密碼登錄 – 簡單的方法

ssh-copy-id username@hostname

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

ssh -t hostA ssh hostB

當然,你要能訪問主機A才行。

9、創(chuàng)建到目標主機的持久化連接

ssh -MNf <user>@<host>

在后臺創(chuàng)建到目標主機的持久化連接,將這個命令和你~/.ssh/config中的配置結(jié)合使用:

Host host ControlPath ~/.ssh/master-%r@%h:%p ControlMaster no

所有到目標主機的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個命令將非常有用,因為每次打開一個SSH連接時不會創(chuàng)建新的套接字。

10、通過SSH連接屏幕

ssh -t remote_host screen &ndash;r

直接連接到遠程屏幕會話(節(jié)省了無用的父bash進程)。

11、端口檢測(敲門)

knock <host> 3000 4000 5000 && ssh -p <port> user@host && knock <host> 5000 4000 3000

在一個端口上敲一下打開某個服務的端口(如SSH),再敲一下關(guān)閉該端口,需要先安裝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 &ndash;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 &ndash;dport 22 -j ACCEPT tcpflags = syn

12、刪除文本文件中的一行內(nèi)容,有用的修復

ssh-keygen -R <the_offending_host>

在這種情況下,最好使用專業(yè)的工具。

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

ssh host -l user $(<cmd.txt)

更具移植性的版本:

ssh host -l user “`cat cmd.txt`”

14、通過SSH將MySQL數(shù)據(jù)庫復制到新服務器

mysqldump &ndash;add-drop-table &ndash;extended-insert &ndash;force &ndash;log-error=error.log -uUSER -pPASS OLD_DB_NAME | ssh -C user@newhost “mysql -uUSER -pPASS NEW_DB_NAME”

通過壓縮的SSH隧道Dump一個MySQL數(shù)據(jù)庫,將其作為輸入傳遞給mysql命令,我認為這是遷移數(shù)據(jù)庫到新服務器最快最好的方法。

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變種,這個命令可以將你的公鑰復制到遠程主機,因此你照樣可以實現(xiàn)無密碼SSH登錄。

17、實時SSH網(wǎng)絡(luò)吞吐量測試

yes | pv | ssh $host “cat > /dev/null”

通過SSH連接到主機,顯示實時的傳輸速度,將所有傳輸數(shù)據(jù)指向/dev/null,需要先安裝pv。

如果是Debian:

apt-get install pv

如果是Fedora:

yum install pv

(可能需要啟用額外的軟件倉庫)。

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

ssh -t user@some.domain.com /usr/bin/screen &ndash;xRR

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

19、繼續(xù)SCP大文件

rsync &ndash;partial &ndash;progress &ndash;rsh=ssh $file_source $user@$host:$destination_file

它可以恢復失敗的rsync命令,當你通過VPN傳輸大文件,如備份的數(shù)據(jù)庫時這個命令非常有用,需要在兩邊的主機上安裝rsync。

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

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

20、通過SSH W/ WIRESHARK分析流量

ssh root@server.com &lsquo;tshark -f “port !22&Prime; -w -' | wireshark -k -i &ndash;

使用tshark捕捉遠程主機上的網(wǎng)絡(luò)通信,通過SSH連接發(fā)送原始pcap數(shù)據(jù),并在wireshark中顯示,按下Ctrl+C將停止捕捉,但也會關(guān)閉wireshark窗口,可以傳遞一個“-c #”參數(shù)給tshark,讓它只捕捉“#”指定的數(shù)據(jù)包類型,或通過命名管道重定向數(shù)據(jù),而不是直接通過SSH傳輸給wireshark,我建議你過濾數(shù)據(jù)包,以節(jié)約帶寬,tshark可以使用tcpdump替代:

ssh root@example.com tcpdump -w &ndash; &lsquo;port !22&prime; | wireshark -k -i &ndash;

21、保持SSH會話永久打開

autossh -M50000 -t server.example.com &lsquo;screen -raAd mysession&rsquo;

打開一個SSH會話后,讓其保持永久打開,對于使用筆記本電腦的用戶,如果需要在Wi-Fi熱點之間切換,可以保證切換后不會丟失連接。

22、更穩(wěn)定,更快,更強的SSH客戶端

ssh -4 -C -c blowfish-cbc

強制使用IPv4,壓縮數(shù)據(jù)流,使用Blowfish加密。

23、使用cstream控制帶寬

tar -cj /backup | cstream -t 777k | ssh host &lsquo;tar -xj -C /backup&rsquo;

使用bzip壓縮文件夾,然后以777k bit/s速率向遠程主機傳輸。Cstream還有更多的功能,請訪問http://www.cons.org/cracauer/cstream.html#usage了解詳情,例如:

echo w00t, i&rsquo;m 733+ | cstream -b1 -t2

24、一步將SSH公鑰傳輸?shù)搅硪慌_機器

ssh-keygen; ssh-copy-id user@host; ssh user@host

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

25、將標準輸入(stdin)復制到你的X11緩沖區(qū)

ssh user@host cat /path/to/some/file | xclip

你是否使用scp將文件復制到工作用電腦上,以便復制其內(nèi)容到電子郵件中?xclip可以幫到你,它可以將標準輸入復制到X11緩沖區(qū),你需要做的就是點擊鼠標中鍵粘貼緩沖區(qū)中的內(nèi)容。

到此,相信大家對“有哪些常用且重要的SSH命令”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

ssh
AI