先看效果

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

传统手工连接

#密码方式
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. 框架应用 : Spring MVC - 开发详述

    软件开发中的MVC设计模式 软件开发的目标是减小耦合,让模块之前关系清晰. MVC模式在软件开发中经常和ORM模式一起应用,主要作用是将(数据抽象,数据实体传输和前台数据展示)分层,这样前台,后台,数 ...

  2. ios自定义数字键盘

    因为项目又一个提现的功能,textfiled文本框输入需要弹出数字键盘,首先想到的就是设置textfiled的keyboardType为numberPad,此时你会看到如下的效果:   但是很遗憾这样 ...

  3. 详解变量声明加 var 和不加 var 的区别

    在全局作用域中声明变量加 var 关键字和不加 var ,js 引擎都会将这个变量声明为全局变量,在实际运行时,两种声明方式的变量的行为也是几乎一致的.但是在全局作用域下是否声明一个变量的 时候加va ...

  4. asp.net C# 实现微信接口权限开发类

    当前微信接口类已实现以下接口,代码上如果不够简洁的,请自行处理. 1.获取access_token 2.获取用户基本信息 3.生成带参数二维码 4.新增永久素材 5.新增临时素材 6.发送微信模版 7 ...

  5. java zip解压

    /** * 解压文件到指定目录 * @param zipFile * @param descDir * @author sqdll */@SuppressWarnings("rawtypes ...

  6. 关于EF Code First模式不同建模方式对建表产生的影响

    今天在学EF Code First模式的时候,发现几个很有趣的问题,问题如下: 1.当编写玩实体后,不指定任何主键约束,EF会找长的最像Id的,然后设置其为主键,验证代码如下: //User类 cla ...

  7. 关于github在客户端不小心删除新仓库,重建后无法上传解决方法

    不小心删除了如果直接在客户端重建一个不行,首先找出本地新仓库,删除,然后在重新再客户端建立一个. 但此时如果两仓库名字一样,会发现无法上传. 此时应该在网页打开github,点击进入之前删除的仓库(云 ...

  8. hibernate和mybatis区别

    看图    Hibernate mybatis 难易度 难 简单,容易上手 编码 良好的映射机制,不需要关心 需要手动编写sql,resultMap 调优 制定合理的缓存策略: 尽量使用延迟加载特性: ...

  9. PHP常用配置

    Php配置文件:php.ini(使用‘;’表示注释) Php的配置项可以在配置文件中配置,也可以在脚本中使用ini_set()函数临时配置. 语言相关配置: 1. engine:设置PHP引擎是否可用 ...

  10. PHP Curl模拟登录并抓取数据

    使用PHP的Curl扩展库可以模拟实现登录,并抓取一些需要用户账号登录以后才能查看的数据.具体实现的流程如下(个人总结): 1. 首先需要对相应的登录页面的html源代码进行分析,获得一些必要的信息: ...