歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> Linux教程 >> 25 條 SSH 命令和技巧

25 條 SSH 命令和技巧

日期:2017/2/28 16:27:20   编辑:Linux教程

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,下面是一個配置文件示例。

[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-keygen -R <the_offending_host>

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

Copyright © Linux教程網 All Rights Reserved