濮阳杆衣贸易有限公司

主頁 > 知識庫 > Linux中rsh遠(yuǎn)程shell命令的使用技巧解析

Linux中rsh遠(yuǎn)程shell命令的使用技巧解析

熱門標(biāo)簽:大眾點評公寓式酒店地圖標(biāo)注 慶陽便宜外呼系統(tǒng)報價 微信地圖標(biāo)注在哪 高德地圖標(biāo)注技術(shù) 辦理400電話怎么申請 天地圖標(biāo)注線 滴滴洗衣店地圖標(biāo)注 如何在地圖標(biāo)注多個位置 靈圖uu電子服務(wù)區(qū)地圖標(biāo)注

rsh有兩種使用模式:

rsh $host : 遠(yuǎn)程登錄,啟動交互式進(jìn)程。
rsh $host $command :遠(yuǎn)程執(zhí)行命令,并顯示輸出。

rsh hosthostcommand

rsh $host $command的作用是:

1.在遠(yuǎn)程機(jī)器上執(zhí)行命令$command
2.通過網(wǎng)絡(luò)連接(socket)重定向當(dāng)前進(jìn)程和遠(yuǎn)端進(jìn)程的標(biāo)準(zhǔn)輸入和標(biāo)準(zhǔn)輸出
3.遠(yuǎn)端rsh進(jìn)程在遠(yuǎn)端進(jìn)程結(jié)束后結(jié)束
4.本地rsh進(jìn)程讀取遠(yuǎn)端進(jìn)程的標(biāo)準(zhǔn)輸出直到結(jié)束(EOF)
深刻理解這個執(zhí)行過程有助于理解各種“奇怪”的現(xiàn)象和用法。

復(fù)制代碼
代碼如下:

+ Suspended (tty input)
$ rsh localhost infinite-loop
[1] + Suspended (tty input) rsh pv007 infinite-loop
$ rsh -n localhost infinite-loop
# 執(zhí)行正常

后臺執(zhí)行rsh命令時,提示了和標(biāo)準(zhǔn)輸入相關(guān)的錯誤信息。這是因為rsh默認(rèn)會把當(dāng)前窗口的標(biāo)準(zhǔn)輸入重定向到遠(yuǎn)端進(jìn)程。
而本地rsh進(jìn)程作為后臺程序運行的話,標(biāo)準(zhǔn)輸入被“阻塞”了。

通過-n選項制定不需要重定向標(biāo)準(zhǔn)輸入(stdin)。


遠(yuǎn)端進(jìn)程的執(zhí)行

執(zhí)行命令

復(fù)制代碼
代碼如下:
rsh somehost infinite-loop

在遠(yuǎn)端機(jī)器上查看相關(guān)進(jìn)程:

復(fù)制代碼
代碼如下:

$ pstree -a -p 3353
in.rshd,3353
└─csh,3363 -c infinite-loop
└─infinite-loop,3632 /u/szhang/bin/infinite-loop

可以看出,遠(yuǎn)端機(jī)器上的rshd進(jìn)程負(fù)責(zé)啟動遠(yuǎn)端進(jìn)程。而且可以看出是通過csh -c的方式啟動的(這里用戶的默認(rèn)Shell是C Shell)。

遠(yuǎn)端進(jìn)程的標(biāo)準(zhǔn)IO

檢查遠(yuǎn)端進(jìn)程的文件描述符:

復(fù)制代碼
代碼如下:

$ ls -l /proc/3363/fd /proc/3632/fd
/proc/3363/fd:
total 0
lrwx------. 1 Jul 30 23:47 16 -> socket:[1184748899]
lrwx------. 1 Jul 30 23:47 17 -> socket:[1184748899]
l-wx------. 1 Jul 30 23:47 18 -> pipe:[1184749092]
lrwx------. 1 Jul 30 23:47 19 -> socket:[1184748899]


復(fù)制代碼
代碼如下:

/proc/3632/fd:
total 0
lrwx------. 1 Jul 30 23:47 0 -> socket:[1184748899]
lrwx------. 1 Jul 30 23:47 1 -> socket:[1184748899]
l-wx------. 1 Jul 30 23:47 2 -> pipe:[1184749092]

可以看出遠(yuǎn)端里程的標(biāo)準(zhǔn)輸入輸出是被重定向到socket上的:

1.stdin 和 stdout 共享一個socket連接
2.stderr 則通過一個pipe重定向(重定向到stdout ???)
3.rsh 的返回值

rsh程序自身的返回值表明的是rsh自身的運行狀況,而不是遠(yuǎn)端進(jìn)程的返回值。

獲得遠(yuǎn)端進(jìn)程的返回值

復(fù)制代碼
代碼如下:

# 遠(yuǎn)端是C Shell
$ rsh $host "$command ; echo $status"


復(fù)制代碼
代碼如下:

# 遠(yuǎn)端是Bash Shell
$ rsh $host "$command ; echo $?"


復(fù)制代碼
代碼如下:

# 遠(yuǎn)端Shell類型不確定
$ rsh $host "sh -c '$command ; echo $?'"

啟動遠(yuǎn)端進(jìn)程所用的Shell

由于用于啟動遠(yuǎn)端進(jìn)程的Shell類型是未知的,而有些操作的語法在不同Shell里是不同的。

比如輸入輸出重定向、命令返回值等。

解決該問題的方法之一是通過明確指定的Shell來啟動真正需要的里程。比如:

復(fù)制代碼
代碼如下:

# 不確定遠(yuǎn)端Shell的類型,顯式通過Bash Shell來啟動需要的進(jìn)程
$ rsh -n $host "sh -c '$command > /dev/null 2>1'"

另一種思路,則是通過一個wrapper程序來啟動真正的命令。

通過rsh在遠(yuǎn)端執(zhí)行后臺進(jìn)程

想在遠(yuǎn)端機(jī)器上執(zhí)行后臺進(jìn)程。命令rsh $host "$command "是不起作用的,會導(dǎo)致本地的rsh進(jìn)程不能結(jié)束。

背后的原因應(yīng)該是,$command的標(biāo)準(zhǔn)輸入輸出通常仍然綁定在rsh連接的socket上,從而導(dǎo)致本地的rsh進(jìn)程無法讀取到文件結(jié)束符EOF。

知道了原因就知道該怎么辦了,關(guān)鍵是關(guān)閉后臺進(jìn)程續(xù)定在rsh連接上的標(biāo)準(zhǔn)輸入輸出。

復(fù)制代碼
代碼如下:

# 如果遠(yuǎn)端Shell是C Shell
$ rsh -n $host "$command > /dev/null "


復(fù)制代碼
代碼如下:

# 如果遠(yuǎn)端Shell是Bash Shell
$ rsh -n $host "$command > /dev/null 2>1 "


復(fù)制代碼
代碼如下:

# 不確定遠(yuǎn)端Shell的類型
$ rsh -n $host "sh -c '$command > /dev/null 2>1 '"

但上面這樣重定向的辦法有個缺點是不能得到任何遠(yuǎn)端進(jìn)程的輸出,而有時我們希望獲得一些輸出信息。
這時就需要遠(yuǎn)端進(jìn)程能夠以守護(hù)進(jìn)程(daemon)的方式運行。

這種情況下,rsh命令可以簡單地寫作:$ rsh -n $host "$command "

遠(yuǎn)端后臺進(jìn)程的內(nèi)容用Tcl表示,大意如下:

復(fù)制代碼
代碼如下:

#/bin/env tclsh
puts "I am a background job"
puts "This Can Be Seen by Remote rsh Process"
close stdout
close stderr
# rsh連接到此應(yīng)該結(jié)束。

puts "This Can NOT Be Seen by Remote rsh Process"
更進(jìn)就步,我們可以甚至忽略rsh命令中的后臺運行符:$ rsh -n $host "$command"

這時遠(yuǎn)端進(jìn)程需要通過fork的方式結(jié)束自己,并啟動真正的后臺進(jìn)程(守護(hù)進(jìn)程)。

rsh進(jìn)程的阻塞和超時處理

在程序中調(diào)用rsh $host $command時可能由于各種奇怪的原因發(fā)生rsh進(jìn)程的阻塞,這不是我們希望看到的。

我們希望設(shè)置一個超時(timeout)機(jī)制來解決這個問題。

在Tcl程序中的一種實現(xiàn)可以這樣: TODO


TCP Connection連接數(shù)過多引起的rsh失敗
監(jiān)控郵件顯示rsh $host $command命令失敗,錯誤提示為“poll: protocol failure in circuit setup"

懷疑是網(wǎng)絡(luò)連接數(shù)過多所引起。

rsh $host $command 的網(wǎng)絡(luò)連接過程

命令rsh $host連接遠(yuǎn)程主機(jī)的513端口。

命令rsh $host $command則連接遠(yuǎn)程主機(jī)的514端口,并隨后發(fā)送一個本地端口號給遠(yuǎn)程主機(jī),要求遠(yuǎn)程主機(jī)建立一個新的TCP連接到這個端口(還不清楚這個新的連接有什么作用)。然后才是傳送命令和等待命令結(jié)束。

這樣做的結(jié)果就是在rsh $host $command進(jìn)程過多時,本地開放的端口資源被消耗完了,從而導(dǎo)致新的rsh $host $command失敗。

這是rsh $host的使用則依然正常。

這里提到的rsh的缺陷,也是建議盡量使用ssh的原因之一。

沒有完全關(guān)閉的網(wǎng)絡(luò)連接:

在遠(yuǎn)程主機(jī)上kill掉相關(guān)的rsh進(jìn)程后,會導(dǎo)致TCP連接沒有完全關(guān)閉。

netstat命令顯示CLOSE_WAIT狀態(tài),端口資源并沒有釋放出來。

根據(jù)配置文件/proc/sys/net/ipv4/tcp_keepalive_time顯示,需要等待2個小時,那些端口才會因為超時而被真正關(guān)閉,從而釋放出來。

復(fù)制代碼
代碼如下:

%> netstat -a | grep localhost
tcp 0 0 localhost:933 localhost:935 CLOSE_WAIT
%> cat /proc/sys/net/ipv4/tcp_keepalive_time
7200 ;# in seconds. = 2 hours
%> echo "net.ipv4.tcp_keepalive_time = 120" >> /etc/sysctl.con

標(biāo)簽:九江 臺州 優(yōu)質(zhì)穩(wěn)定 玉樹 海東 孝感 哈密 昌都

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux中rsh遠(yuǎn)程shell命令的使用技巧解析》,本文關(guān)鍵詞  Linux,中,rsh,遠(yuǎn)程,shell,命令,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux中rsh遠(yuǎn)程shell命令的使用技巧解析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Linux中rsh遠(yuǎn)程shell命令的使用技巧解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    开原市| 庄河市| 拜城县| 二连浩特市| 互助| 昂仁县| 华阴市| 临泽县| 惠州市| 新兴县| 大埔县| 沧州市| 喀喇沁旗| 敦煌市| 辽中县| 东源县| 如皋市| 高密市| 临潭县| 乌拉特中旗| 历史| 渝中区| 铜川市| 道真| 沽源县| 化州市| 东明县| 遂宁市| 乾安县| 汝南县| 通辽市| 扎赉特旗| 渭源县| 阳江市| 宁安市| 佳木斯市| 玛纳斯县| 上饶市| 甘孜| 调兵山市| 芦山县|