先看效果

  你需要做的事情,在配置文件中配置服务器信息选择对应的服务器,进行连接。

传统手工连接

#密码方式
ssh user@ip # 然后输入服务器密码 #密钥登录
ssh -i identity_file user@ip #将本机 id_rsa.pub 添加到服务器authorized_keys中
ssh ssh user@ip

​   弊端很明显,需要记服务器地址、ip、key位置、密码等,每次都需要自己手打一长串命令啊。。。

自动连接

​   思路很简单,将连接需要的参数提取到配置文件,从读取配置文件读取指定行服务器信息进行连接,下面是配置文件

server.conf

id  desc            username   ip              connect-type    key-path/password
) test_server ec2-user .xx.xx.xx key key_abs_path
) prod_server root .xxx.x.x8 password dasdxxxxx

​   除第一行之外,每行代表一台服务器连接信息,配置文件信息比较简单,仅仅包含一些连接需要的必要信息和简单说明。

过程说明

  • 打印服务器配置文件信息

  • 用户输入需要连接服务器的 id

  • 读取用户选择行的信息到数组中,组成对应的 shell执行

    其中如果需要密码输入,自动交互由 expect 完成

    expect是什么?

    ​ 一个可以帮助完成 用户与 终端交互的小工具(可以自行了解下,很简单,花不了10分钟)

    ​ 比如连接服务器需要输入密码,你写好 expect 脚本,让它在指定的时候,帮你输入你的密码,下面是脚本内容

expect_login.sh

#!/usr/bin/expect -f
# @author : wangjia
# @time : // :
# desc : expect 登录

set timeout
#接受传入参数,
#参数1是 user@ip,
#参数2 password
set user_ip [lindex ${argv} ]
set password [lindex ${argv} ]

#套壳 根据 expect 发送 对应信息
spawn ssh ${user_ip}
# 根据期望做出对应的动作,自动输入密码
expect {
"*assword:*" { send "${password}\r"}
}
#将操作权交还给用户
interact

相关代码

  第一步读取配置文件,并打印到 终端

# 读取配置文件到数组
# @param1 $1服务器信息配置表
function init_server_info_arr(){
conf_file_path=$;
lineCount=;
while read oneLine
do
lines[lineCount]=${oneLine}
let lineCount++;
done < ${conf_file_path}
print_server_list
}

#服务器信息打印(数组打印)
function print_server_list(){
for i in "${!lines[@]}";
do
echo " ${lines[i]}"
done
}

  第二步,用户交互

# 用户选择需要连接的服务器
function interact_user(){
read -p " which server to connect? Input the server id : " user_choose
input_check "${user_choose}"
}

#用户交互 输入检查
function input_check(){
input=$
if [[ ${input} =~ ^[-]+$ ]] && [ ${input} -lt ${lineCount} ]
then
input="pass"
else
echo " wrong enter"
exit
fi
}

  第三步,连接

#进行连接
#@param1 配置文件的行
function connect_by_line(){
choose_server=$;
#将行信息按空格分割成数组
server_info_arr=(${choose_server// / })
#读取数组,key-按密钥方式登录,password按密码方式调用 expect登录
if [ "${server_info_arr[4]}" == "key" ]
then
ssh -i "${server_info_arr[5]}" "${server_info_arr[2]}@${server_info_arr[3]}";
elif [ "${server_info_arr[4]}" = "password" ]
then
pw_login "${server_info_arr[2]}@${server_info_arr[3]}" "${server_info_arr[5]}";
else
ssh "${server_info_arr[2]}@${server_info_arr[3]}";
fi
}

# 账号密码登录 expect 脚本调用
# @param1 用户登录名@IP eg.. root@123.23.12.22
# @param2 password
function pw_login(){
/Users/wangjia/coder/github/shell/ssh/expect_login.sh $ $
}

  • 本文没有什么深奥的地方,仅仅是很早之前简单了解 shell 之后,对日常操作做了一点点改进和优化,相信还有许多更好更优化的方式,也希望本文对一些朋友有帮助。

  • 该自动登录需要 expect 支持,如果不想装 expect ,可以将 ecpect 相关注释掉,需要输入密码的时候,将打印出的密码 copy 进去即可。

#进行连接
# @param1 配置文件的行
function connect_by_line(){
choose_server=$;
#按空格分割成数组
server_info_arr=(${choose_server// / })
if [ "${server_info_arr[4]}" == "key" ]
then
ssh -i "${server_info_arr[5]}" "${server_info_arr[2]}@${server_info_arr[3]}";
# elif [ "${server_info_arr[4]}" = "password" ]
# then
# pw_login "${server_info_arr[2]}@${server_info_arr[3]}" "${server_info_arr[5]}";
else
ssh "${server_info_arr[2]}@${server_info_arr[3]}";
fi
}

  文中所有源码地址 github-shell自动登录,也欢迎指针、交流(微信:wj435532580)

shell全自动登录远程终端的更多相关文章

  1. 交互式shell和非交互式shell、登录shell和非登录shell的区别

    交互式shell和非交互式shell.登录shell和非登录shell的区别.首先,这是两个不同的维度来划分的,一个是是否交互式,另一个是是否登录. 交互式shell和非交互式shell(intera ...

  2. linux 本地账号密码无法登陆(shell可以登录),一直返回 登陆的login界面

    今天我在我虚拟机测试的时候遇到了一个问题.登陆centos一直是返回login,账号和密码没错,我也换了两个用户. 1.问题描述 我正常的输入用户名和密码 错误提示截图:返回登陆界面,我重新试了另外的 ...

  3. SSH Secure Shell 无法登录:server responded "algorithm negotiation failed”

    SSH Secure Shell Client 连接 ubuntu系统报错 修改ssh的配置文件 /etc/ssh/sshd_config在配置文件中添加: Ciphers aes128-cbc,ae ...

  4. shell脚本登录数据库

    #!/bin/bashHOSTNAME="localhost" #数据库信息 PORT="3306" USERNAME="root" PAS ...

  5. shell脚本登录远程服务器并下载至本地

    通常有这样备份的需求,将远程服务器的代码或者数据打包压缩然后下载到本地路径 实现方式 需要对远程服务器实现无密码访问,通过配置公钥实现: 使用ssh执行命令然后转向到本地的方法一步完成打包和下载,可参 ...

  6. 登录式与非登录式&交互式与非交互式shell及其环境初始化过程

    交互式shell和非交互式shell(interactive shell and non-interactive shell) 交互式模式就是在终端上执行,shell等待你的输入,并且立即执行你提交的 ...

  7. Linux登录shell和非登录(交互式shell)环境变量配置

    使用Jenkins执行shell脚本的时候, 碰到command not found. 比如java mvn, 这些环境变量配置在/etc/profile 中, 但jenkins执行的时候并没有加载. ...

  8. 快Key:按一下鼠标【滚轮】,帮你自动填写用户名密码,快速登录,可制作U盘随身(开源免费-附安装文件和源代码)

    * 代码以本文所附下载文件包为准,安装文件和源文件包均在本文尾部可下载. * 快Key及本文所有内容仅供交流使用,使用者责任自负,由快Key对使用者及其相关人员或组织造成的任何损失均由使用者自负,与本 ...

  9. shell与变量的声明的操作

    1.给命令起别名:alias 执行下面命令后,可以使用dir代替ls –l 命令,显示目录中的文件详细信息: 还可以用一个别名表示几个命令 的结合: 2.ps:显示当前登录会话的所有活动进程: 3.更 ...

随机推荐

  1. WPF DataGrid显格式

    Guide to WPF DataGrid formatting using bindings Peter Huber SG, 25 Nov 2013 CPOL    4.83 (13 votes) ...

  2. linux RPM软件包管理

    linux RPM软件包管理 目录 1.软件包的介绍 2.rpm包管理 3.rpm包管理前端工具 1.软件包的介绍 在我们在对软件包管理前,先对软件包有个很好的了解,这样更方便我们来对其进行管理. 软 ...

  3. Hadoop技术之Hadoop HA 机制学习

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:温球良 导语 最近分享过一次关于Hadoop技术主题的演讲,由于接触时间不长,很多技术细节认识不够,也没讲清楚,作为一个技术人员,本 ...

  4. UVa1630,Folding

    区间dp,记忆化搜就可以 st为原串 dp[p][q]存st[p]~st[q]的最优长度,f[p][q]存对应的最优串 从(0,len-1)开始搜,f[0][len-1]为所求ans,回溯条件为p== ...

  5. day38(增强类的实现)

    定义一个接口 package com.baidu.test; public interface Person { public abstract void eat(); public abstract ...

  6. WordCount项目

    采用的源码来自http://blog.csdn.net/lnz001/article/details/54851551 经修改后,已上传至GitHub.https://github.com/FengX ...

  7. Django数据库操作性能相关

    Django数据库操作性能相关 案例: 现在我们的数据库中有两张表如下: 1.职员表: class UserInfo(models.Model): name = models.CharField(ma ...

  8. JAVA提高八:动态代理技术

    对于动态代理,学过AOP的应该都不会陌生,因为代理是实现AOP功能的核心和关键技术.那么今天我们将开始动态代理的学习: 一.引出动态代理 生活中代理应该是很常见的,比如你可以通过代理商去买电脑,也可以 ...

  9. 【面向对象】详解之JavaScript篇

    [重点提前说:面向对象的思想很重要!] 最近开始接触学习后台的PHP语言,在接触到PHP中的面向对象相关思想之后,突然想到之前曾接触的JS中的面向对象思想,无奈记性太差,便去翻了翻资料,花了点时间梳理 ...

  10. 使用Git与Github创建自己的远程仓库

    原因 早就想创建一个自己的远程仓库,方便发布到Nuget上,自己用也好,项目组用也好,都方便. 今天抽了个时间建了个仓库,随便记下溜方便后来的人. 流程 1,创建自己的GitHub仓库 首先需要到 G ...