nc 到底干嘛用的我不多描述,今天主要講下用nc 傳輸文件。由於公司的設備sudo 後沒有ssh ,scp 等遠程接入命令,或host.deny 裡面設置了ssh 的deny ,不管怎樣的原因。我今天跨過大家常用的scp, 來說明下一個更有用的輕量級工具,nc 的另一個強大的功--- 文件傳輸。
范例如下:
目的主機監聽
nc -l 監聽端口[ 未使用端口] > 要接收的文件名
nc -l 4444 > cache.tar.gz
源主機發起請求
nc 目的主機ip 目的端口 < 要發送的文件
nc 192.168.0.85 4444 < /root/cache.tar.gz
netstat 如下
[root@localhost jiangbao]# netstat -tpln
tcp 0 0 0.0.0.0:4444 0.0.0.0:* LISTEN 18166/nc
英文描述如下
DATA TRANSFER
Start by using nc to listen on a specific port, with output captured into a file:
$ nc -l 1234 > filename.out
Using a second machine, connect to the listening nc process, feeding it the file which is to be transferred:
$ nc host.example.com 1234 < filename.in
另附nc 的其他選項說明:
語 法: nc [-hlnruz][-g< 網關...>][-G< 指向器數目>][-i< 延遲秒數>][-o< 輸出文件>][-p< 通信端口>][-s< 來源位址>][-v...][-w< 超時秒數>][ 主機名稱][ 通信端口...]
補充說明: 執行本指令可設置路由器的相關參數。
參 數:
-g< 網關> 設置路由器躍程通信網關,最丟哦可設置8 個。
-G< 指向器數目> 設置來源路由指向器,其數值為4 的倍數。
-h 在線幫助。
-i< 延遲秒數> 設置時間間隔,以便傳送信息及掃描通信端口。
-l 使用監聽模式,管控傳入的資料。
-n 直接使用IP 地址,而不通過域名 服務器 。
-p< 通信端口> 設置本地主機使用的通信端口。
-r 亂數指定本地與遠端主機的通信端口。
-s< 來源位址> 設置本地主機送出數據包的IP 地址。
-u 使用UDP 傳輸 協議 。
-v 顯示指令執行過程。
-w< 超時秒數> 設置等待連線的時間。
-z 使用0 輸入/ 輸出模式,只在掃描通信端口時使用
Linux 遠程復制文件
如果想把機器A上面的dir目錄下面的所有文件復制到機器B的dir目錄下,我們可以使用nc命令來完成
在機器A的dir目錄下面執行:
tar -czf - * | nc -l 4444
然後再機器B的目錄目錄dir下面執行:
sudo nc 「機器A的機器ip」 4444 | sudo tar -xzf -
補充資料2:
1,在Linux下需要對大量小文件進行移動或復制時,用cp、mv都會顯得很沒有效率,可以用tar先壓縮再解壓縮的方式。
2,在網絡環境中傳輸時,可以再結合nc命令,通過管道和tcp端口進行傳輸。
nc和tar可以用來快速的在兩台機器之間傳輸文件和目錄,比ftp和scp要來得簡單的多。
由於nc是一個超輕量的命令,所以一般busybox都會集成它。當一個linux終端,比如linux pda,通過usblan的方式連接到另一台linux主機的時候,這樣的嵌入式終端上一般不會集成ftp server, ssh server這樣比較笨重的服務,這個時候, nc可能成為唯一的上傳手段。
比如將機器A上的mytest目錄上傳到到機器 B(192.168.0.11)上,只需要:
在機器B上,用nc來監聽一個端口,隨便就好,只要不被占用;並且將收到的數據用tar展開。-l代表監聽模式。
[root@ www.linuxidc.com ~]#nc -l 4444 |tar -C /tmp/dir -zxf -
然後,在A上通過nc和 tar發送test目錄。使用一致的4444的端口。
[root@ www.linuxidc.net ~]#tar -zcvf - mytest|nc 192.168.0.11 4444
記得有一次,一台機器內核崩了,後來有位高手用liveCD把機器啟動起來,就是用了類似的方法把數據導出來的。