共計(jì) 1924 個(gè)字符,預(yù)計(jì)需要花費(fèi) 5 分鐘才能閱讀完成。
這篇“Linux 中如何用 ssh 命令統(tǒng)計(jì)分布式集群信息”文章的知識(shí)點(diǎn)大部分人都不太理解,所以丸趣 TV 小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Linux 中如何用 ssh 命令統(tǒng)計(jì)分布式集群信息”文章吧。
一、統(tǒng)計(jì)分布式集群信息的思路
用免密的遠(yuǎn)程登陸命令,實(shí)現(xiàn)一臺(tái)機(jī)器訪問其他集群的機(jī)器。因此想要實(shí)現(xiàn)有幾個(gè)重要步驟:
學(xué)會(huì) shh 的使用方法
實(shí)現(xiàn)免密登錄
編寫 shell 程序
二、SSH 加密原理
非對(duì)稱加密技術(shù)是一種加密和解密用的不同密鑰的加密方法。其中 RSA 和 DSA 就是非對(duì)稱加密方法。當(dāng)然非對(duì)稱加密算法有一個(gè)前提,就是有一對(duì)密鑰可以相互加密和解密,通常這一對(duì)密鑰就會(huì)成為持有者的公鑰和私鑰。公鑰是其他人可以知悉的密鑰,而私鑰只能持有者自己知道。當(dāng)然如果私鑰泄露給外人,可能會(huì)有信息安全問題。
假如:A 要發(fā)送給 B 一個(gè)加密數(shù)據(jù)。第一種方法是:A 用自己的私鑰加密,B 獲得數(shù)據(jù)后用 A 的公鑰解密。第二種方法是:A 用 B 的公鑰加密數(shù)據(jù),B 獲得數(shù)據(jù)后再用自己的私鑰解密。
SSH 遠(yuǎn)程登錄用的是第一種方法。
三、SSH 命令
常用的方法是
ssh -i [私鑰文件名] -p [端口號(hào)] user@hostname [執(zhí)行的命令]
其中私鑰文件名默認(rèn)為 $HOME/.ssh/id_rsa 或者 $HOME/.ssh/id_dsa,端口號(hào)默認(rèn)為 22.
例如:
ssh myname@128.180.146.89 # 輸入目標(biāo)主機(jī)的密碼后進(jìn)行遠(yuǎn)程操作,exit 命令退出
四、利用 ssh-keygen 和 ssh-copy-id 實(shí)現(xiàn)免密登錄
ssh-keygen # 直接全部回車,先都默認(rèn)
然后會(huì)在 $HOME/.ssh/ 目錄下生成一個(gè)密鑰對(duì)文件,其中 *.pub 統(tǒng)一為公鑰文件,另外一個(gè)就是私鑰文件。
接下來把公鑰文件中的內(nèi)容拷貝到目標(biāo)主機(jī)用戶的 $HOME/.ssh/authorized_keys 中??截惙绞娇梢宰约菏謩?dòng)操作。也可用如下命令實(shí)現(xiàn)
ssh-copy-id -i [公鑰文件名] user$hostname
例如 :
ssh-copy-id -i $HOME/.ssh/id_rsa.pub myname@128.180.146.89
然后再執(zhí)行遠(yuǎn)程登錄命令就可以實(shí)現(xiàn)免密登錄啦。如果第二次登錄還需要密碼,可能是因?yàn)槲募臀募夸洐?quán)限問題。也可能是因?yàn)檫B接的私鑰與公鑰不是一對(duì)。
五、Linux Shell 腳本實(shí)現(xiàn)
sshtest.sh 文件:
#!/bin/bash
func___setenv(){
RTS_ECT_DIR= $HOME
#.....
######################################
# 程序主體
######################################
#調(diào)用環(huán)境變量
func___setenv
#讀取機(jī)器連接信息
while read line
ssh_cmd=
ssh_linkhost=`echo ${line}`
while read cmdline
do
# 空命令行跳過
if [ -z $cmdline ]; then
continue
fi
# 讀取的命令行拼接;
if [ ! -n $ssh_cmd ]; then
ssh_cmd=`echo ${$cmdline}` ;
else
ssh_cmd= ${ssh_cmd}; `echo ${$cmdline}` ;
fi
done ${RTS_ECT_DIR}/sshcmd.cfg
#執(zhí)行遠(yuǎn)程命令
ssh $ssh_linkhost $ssh_cmd /dev/null
done ${RTS_ECT_DIR}/sshlink.cfg
sshlink.cfg 文件:前提要先配好密鑰才可以免密登錄
myname@128.180.146.89
myName@128.180.146.90
Myname@128.180.146.91
sshcmd.cfg 文件:根據(jù)自己需要填寫
ps -ef|grep java
df -h
六、ssh 只循環(huán)一次問題
如果上述代碼的倒數(shù)第二行如果改成
ssh $ssh_linkhost $ssh_cmd
那么 while 循環(huán)就只循環(huán) 1 次。因?yàn)?while read line 會(huì)把循環(huán)信息放到標(biāo)準(zhǔn)輸入中,而 ssh 命令會(huì)把輸入緩存全部讀光,因此 while 不在循環(huán),所以 ssh 命令需要重定向。
以上就是關(guān)于“Linux 中如何用 ssh 命令統(tǒng)計(jì)分布式集群信息”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望丸趣 TV 小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注丸趣 TV 行業(yè)資訊頻道。
向 AI 問一下細(xì)節(jié)
丸趣 TV 網(wǎng) – 提供最優(yōu)質(zhì)的資源集合!