這篇“Linux中如何用ssh命令統(tǒng)計分布式集群信息”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Linux中如何用ssh命令統(tǒng)計分布式集群信息”文章吧。
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),海豐企業(yè)網(wǎng)站建設(shè),海豐品牌網(wǎng)站建設(shè),網(wǎng)站定制,海豐網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,海豐網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
用免密的遠程登陸命令,實現(xiàn)一臺機器訪問其他集群的機器。因此想要實現(xiàn)有幾個重要步驟:
學(xué)會shh的使用方法
實現(xiàn)免密登錄
編寫shell程序
非對稱加密技術(shù)是一種加密和解密用的不同密鑰的加密方法。其中RSA和DSA就是非對稱加密方法。當然非對稱加密算法有一個前提,就是有一對密鑰可以相互加密和解密,通常這一對密鑰就會成為持有者的公鑰和私鑰。公鑰是其他人可以知悉的密鑰,而私鑰只能持有者自己知道。當然如果私鑰泄露給外人,可能會有信息安全問題。
假如:A要發(fā)送給B一個加密數(shù)據(jù)。第一種方法是:A用自己的私鑰加密,B獲得數(shù)據(jù)后用A的公鑰解密。第二種方法是:A用B的公鑰加密數(shù)據(jù),B獲得數(shù)據(jù)后再用自己的私鑰解密。
SSH遠程登錄用的是第一種方法。
常用的方法是
ssh -i [私鑰文件名] -p [端口號] user@hostname [執(zhí)行的命令]
其中私鑰文件名默認為 $HOME/.ssh/id_rsa 或者 $HOME/.ssh/id_dsa ,端口號默認為22.
例如:
ssh myname@128.180.146.89 #輸入目標主機的密碼后進行遠程操作,exit命令退出
ssh-keygen #直接全部回車,先都默認
然后會在$HOME/.ssh/ 目錄下生成一個密鑰對文件,其中 *.pub統(tǒng)一為公鑰文件,另外一個就是私鑰文件。
接下來把公鑰文件中的內(nèi)容拷貝到目標主機用戶的 $HOME/.ssh/authorized_keys 中。拷貝方式可以自己手動操作。也可用如下命令實現(xiàn)
ssh-copy-id -i [公鑰文件名] user$hostname
例如 :
ssh-copy-id -i $HOME/.ssh/id_rsa.pub myname@128.180.146.89
然后再執(zhí)行遠程登錄命令就可以實現(xiàn)免密登錄啦。如果第二次登錄還需要密碼,可能是因為文件和文件目錄權(quán)限問題。也可能是因為連接的私鑰與公鑰不是一對。
sshtest.sh文件:
#!/bin/bash func___setenv(){ RTS_ECT_DIR="$HOME" #..... } ###################################### # # 程序主體 ###################################### #調(diào)用環(huán)境變量 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 #執(zhí)行遠程命令 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
如果上述代碼的倒數(shù)第二行如果改成
ssh $ssh_linkhost $ssh_cmd
那么while循環(huán)就只循環(huán)1次。因為while read line 會把循環(huán)信息放到標準輸入中,而ssh命令會把輸入緩存全部讀光,因此while不在循環(huán),所以ssh命令需要重定向。
以上就是關(guān)于“Linux中如何用ssh命令統(tǒng)計分布式集群信息”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當前題目:Linux中如何用ssh命令統(tǒng)計分布式集群信息
網(wǎng)頁網(wǎng)址:http://chinadenli.net/article22/gspjjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、標簽優(yōu)化、App開發(fā)、企業(yè)建站、網(wǎng)站制作、品牌網(wǎng)站設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)