溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux中如何用ssh命令統(tǒng)計(jì)分布式集群信息

發(fā)布時(shí)間:2023-05-18 14:11:49 來(lái)源:億速云 閱讀:121 作者:zzz 欄目:建站服務(wù)器

這篇“Linux中如何用ssh命令統(tǒng)計(jì)分布式集群信息”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“Linux中如何用ssh命令統(tǒng)計(jì)分布式集群信息”文章吧。

一、統(tǒng)計(jì)分布式集群信息的思路

用免密的遠(yuǎn)程登陸命令,實(shí)現(xiàn)一臺(tái)機(jī)器訪問(wèn)其他集群的機(jī)器。因此想要實(shí)現(xiàn)有幾個(gè)重要步驟:

  • 學(xué)會(huì)shh的使用方法

  • 實(shí)現(xiàn)免密登錄

  • 編寫(xiě)shell程序

二、SSH加密原理

非對(duì)稱加密技術(shù)是一種加密和解密用的不同密鑰的加密方法。其中RSA和DSA就是非對(duì)稱加密方法。當(dāng)然非對(duì)稱加密算法有一個(gè)前提,就是有一對(duì)密鑰可以相互加密和解密,通常這一對(duì)密鑰就會(huì)成為持有者的公鑰和私鑰。公鑰是其他人可以知悉的密鑰,而私鑰只能持有者自己知道。當(dāng)然如果私鑰泄露給外人,可能會(huì)有信息安全問(wèn)題。

假如: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     #直接全部回車(chē),先都默認(rèn)

然后會(huì)在$HOME/.ssh/   目錄下生成一個(gè)密鑰對(duì)文件,其中 *.pub統(tǒng)一為公鑰文件,另外一個(gè)就是私鑰文件。

接下來(lái)把公鑰文件中的內(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)限問(wè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
do
ssh_cmd=
ssh_linkhost=`echo ${line}`
    while  read  cmdline
    do
    #空命令行跳過(guò)
    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ù)自己需要填寫(xiě)

ps -ef|grep java 
df -h

六、ssh只循環(huán)一次問(wèn)題

如果上述代碼的倒數(shù)第二行如果改成

ssh $ssh_linkhost $ssh_cmd

那么while循環(huán)就只循環(huán)1次。因?yàn)閣hile read line 會(huì)把循環(huán)信息放到標(biāo)準(zhǔn)輸入中,而ssh命令會(huì)把輸入緩存全部讀光,因此while不在循環(huán),所以ssh命令需要重定向。

以上就是關(guān)于“Linux中如何用ssh命令統(tǒng)計(jì)分布式集群信息”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

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

AI