首頁 > 軟體

Linux Shell如何用ssh命令統計分散式叢集資訊詳解

2022-07-24 18:00:49

一、統計分散式叢集資訊的思路

用免密的遠端登陸命令,實現一臺機器存取其他叢集的機器。因此想要實現有幾個重要步驟:

  • 學會shh的使用方法
  • 實現免密登入
  • 編寫shell程式

二、SSH加密原理

非對稱加密技術是一種加密和解密用的不同金鑰的加密方法。其中RSA和DSA就是非對稱加密方法。當然非對稱加密演演算法有一個前提,就是有一對金鑰可以相互加密和解密,通常這一對金鑰就會成為持有者的公鑰和私鑰。公鑰是其他人可以知悉的金鑰,而私鑰只能持有者自己知道。當然如果私鑰洩露給外人,可能會有資訊保安問題。

假如:A要傳送給B一個加密資料。第一種方法是:A用自己的私鑰加密,B獲得資料後用A的公鑰解密。第二種方法是:A用B的公鑰加密資料,B獲得資料後再用自己的私鑰解密。

SSH遠端登入用的是第一種方法。

三、SSH命令

常用的方法是

 ssh -i [私鑰檔名] -p  [埠號] user@hostname  [執行的命令]

其中私鑰檔名預設為 $HOME/.ssh/id_rsa    或者 $HOME/.ssh/id_dsa ,埠號預設為22.  

例如:

ssh   myname@128.180.146.89  #輸入目標主機的密碼後進行遠端操作,exit命令退出

四、利用ssh-keygen和ssh-copy-id 實現免密登入

ssh-keygen     #直接全部回車,先都預設

然後會在$HOME/.ssh/   目錄下生成一個金鑰對檔案,其中 *.pub統一為公鑰檔案,另外一個就是私鑰檔案。

接下來把公鑰檔案中的內容拷貝到目標主機使用者的 $HOME/.ssh/authorized_keys 中。拷貝方式可以自己手動操作。也可用如下命令實現

ssh-copy-id -i [公鑰檔名]  user$hostname

例如  :

ssh-copy-id -i  $HOME/.ssh/id_rsa.pub  myname@128.180.146.89

然後再執行遠端登入命令就可以實現免密登入啦。如果第二次登入還需要密碼,可能是因為檔案和檔案目錄許可權問題。也可能是因為連線的私鑰與公鑰不是一對。

五、Linux Shell 指令碼實現

sshtest.sh檔案:

#!/bin/bash
func___setenv(){
   RTS_ECT_DIR="$HOME"
   #.....
}
######################################
#
#   程式主體
######################################
 
#呼叫環境變數
func___setenv
 
#讀取機器連線資訊
while read line
do
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
#執行遠端命令
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 檔案:根據自己需要填寫

ps -ef|grep java 
df -h 

六、ssh只回圈一次問題

如果上述程式碼的倒數第二行如果改成

ssh $ssh_linkhost $ssh_cmd

那麼while迴圈就只回圈1次。因為while read line 會把迴圈資訊放到標準輸入中,而ssh命令會把輸入快取全部讀光,因此while不在迴圈。所以ssh命令需要重定向

總結

到此這篇關於Linux Shell如何用ssh命令統計分散式叢集資訊的文章就介紹到這了,更多相關Linux Shell ssh命令統計叢集資訊內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com