在 Linux 下進(jìn)行遠(yuǎn)程登陸的時(shí)候,總是要進(jìn)行 ssh 輸入賬號(hào)密碼,相對(duì)比較繁瑣。而在工作中總會(huì)先從本地登陸到公司的中間機(jī)器(跳板機(jī))然后才能登陸到線上的機(jī)器,每次操作更加繁瑣。如果從 A -> B 可以直接進(jìn)行建立相互的信任關(guān)系來(lái)解決面輸入密碼的問(wèn)題。顯示情況如果 A -> B -> C 三臺(tái)機(jī)器,如果想從 A 直接到 C 只能通過(guò) B 進(jìn)行登錄,這樣就無(wú)法建立 A -> C 的信任關(guān)系(這種操作主要是為了保護(hù)線上機(jī)器不能隨便登錄)。該腳本就是解決這種有多個(gè)依賴的關(guān)系。
注意事項(xiàng):
1. 使用實(shí)時(shí) bash version >= 4.0,因?yàn)榕渲弥行枰褂藐P(guān)聯(lián)數(shù)據(jù)
2. 如果需要全局使用直接修改 autologin 的名字,移動(dòng)到 PATH 路徑下即可 eg: mv autologin /usrl/local/bin/to(改為自己想要使用的名字)
腳本代碼:
#!/usr/local/bin/bash # @Version 0.3.1 # @filename to # 修復(fù)等不需要要配置跳板機(jī)的時(shí)候執(zhí)行命令,在配置跳板機(jī)位置默認(rèn)填 no 即可 # @Author pemakoa@gmail.com # Bash version >= 4.0 使用關(guān)聯(lián)數(shù)組 # Usage: host user passwd port jump_host command # 四種情況如下: # 1. 直接登錄目標(biāo)機(jī)器 如 A # 2. 需要中間機(jī)器登陸到目標(biāo)機(jī)器 如 C, 其中 B 為中間機(jī)器,會(huì)先登錄 B在從 B登陸到 C然后執(zhí)行 command # 3. 直接登錄目標(biāo)機(jī)器并執(zhí)行相應(yīng)的命令 如 D declare -A _server_config _server_config['A']="a_host a_user a_passwd a_port" _server_config['B']="b_host b_user b_passwd b_port" _server_config['C']="c_host c_user c_passwd c_port B '(command eg) ls .'" _server_config['D']="d_host d_user d_passwd d_port no 'cd /home && ll'" _config_keys=(${!_server_config[@]}) _length=${#_server_config[@]} _login_server=$1 _config_status=false # 是否輸入登陸機(jī)器 if [ "$_login_server" == "" ];then echo -e "\033[40m\033[31m Please input login server, you can choose one follows list \033[0m" for i in "${_config_keys[@]}";do echo -e "\033[41;37m $i \033[0m " done exit fi # 檢查登陸的機(jī)器是否配置 for i in "${_config_keys[@]}";do if [ "$_login_server" == "$i" ];then _config_status=true fi done if [ "${_config_status}" == "false" ];then echo -ne "\033[40m\033[31m Not config server info ... Please config in _server_config like Host User Passwd Port Jump Command\033[0m" exit fi # 登陸 如果配置跳板機(jī),先登陸跳板機(jī)在登陸到目標(biāo)機(jī)器 _host=$(echo ${_server_config["${_login_server}"]} | awk '{print $1}') _user=$(echo ${_server_config["${_login_server}"]} | awk '{print $2}') _passwd=$(echo ${_server_config["${_login_server}"]} | awk '{print $3}') _port=$(echo ${_server_config["${_login_server}"]} | awk '{print $4}') _jump=$(echo ${_server_config["${_login_server}"]} | awk '{print $5}') _command=$(echo ${_server_config["${_login_server}"]} | awk -F"'" '{print $2}') if [ "${_command}" != "" ]; then _command="expect \"*]*\" send \"${_command}\r\"" fi if [ "${_jump}" != "" ] && [ "${_jump}" != "no" ]; then _jump_host=$(echo ${_server_config["${_jump}"]} | awk '{print $1}') _jump_user=$(echo ${_server_config["${_jump}"]} | awk '{print $2}') _jump_passwd=$(echo ${_server_config["${_jump}"]} | awk '{print $3}') _jump_port=$(echo ${_server_config["${_jump}"]} | awk '{print $4}') expect -c " set timeout 30 spawn ssh -p${_jump_port} ${_jump_user}@${_jump_host} expect { \"yes/no\" { send \"yes\r\"; exp_continue } \"assword\" { send \"${_jump_passwd}\r\" } } expect \"*]*\" send \"ssh -p${_port} ${_user}@${_host}\r\" expect \"assword:\" send \"${_passwd}\r\" ${_command} interact" else expect -c " set timeout 30 spawn ssh -p${_port} ${_user}@${_host} expect { \"yes/no\" {send \"yes\r\"; exp_continue } \"*assword:\" { send \"$_passwd\r\" } } ${_command} interact " fi
GitHub代碼地址: https://github.com/pemako/LearnShell/blob/master/lib/autologin
另外的方法:Linux中使用expect腳本實(shí)現(xiàn)遠(yuǎn)程機(jī)器自動(dòng)登錄
首先創(chuàng)建一個(gè)expect腳本ssh_expect,文件內(nèi)容如下:
#!/usr/bin/expect -f set hostname [lindex $argv 0] set user [lindex $argv 1] set passwd [lindex $argv 2] set timeout 30 set force_conservative 1 if {$force_conservative} { set send_slow {128 .1} } spawn ssh $user@$hostname; expect { "*continue connecting (yes/no)?" { send -s "yes\r"; exp_continue } "*assword:" { send -s "$passwd\r"; } } interact
然后定義一些命令別名,比如:
alias h101='ssh_expect 192.168.0.101 <user> <password>' alias h102='ssh_expect 192.168.0.102 <user> <password>'
這些別名可以寫(xiě)到~/.bashrc文件中
然后執(zhí)行 h101 就可以自動(dòng)登錄192.168.0.101機(jī)器了。
如對(duì)本文有疑問(wèn),請(qǐng)?zhí)峤坏浇涣髡搲?,廣大熱心網(wǎng)友會(huì)為你解答??! 點(diǎn)擊進(jìn)入論壇