shell全自动登录远程终端
先看效果


你需要做的事情,在配置文件中配置服务器信息,选择对应的服务器,进行连接。
传统手工连接
#密码方式
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全自动登录远程终端的更多相关文章
- 交互式shell和非交互式shell、登录shell和非登录shell的区别
交互式shell和非交互式shell.登录shell和非登录shell的区别.首先,这是两个不同的维度来划分的,一个是是否交互式,另一个是是否登录. 交互式shell和非交互式shell(intera ...
- linux 本地账号密码无法登陆(shell可以登录),一直返回 登陆的login界面
今天我在我虚拟机测试的时候遇到了一个问题.登陆centos一直是返回login,账号和密码没错,我也换了两个用户. 1.问题描述 我正常的输入用户名和密码 错误提示截图:返回登陆界面,我重新试了另外的 ...
- SSH Secure Shell 无法登录:server responded "algorithm negotiation failed”
SSH Secure Shell Client 连接 ubuntu系统报错 修改ssh的配置文件 /etc/ssh/sshd_config在配置文件中添加: Ciphers aes128-cbc,ae ...
- shell脚本登录数据库
#!/bin/bashHOSTNAME="localhost" #数据库信息 PORT="3306" USERNAME="root" PAS ...
- shell脚本登录远程服务器并下载至本地
通常有这样备份的需求,将远程服务器的代码或者数据打包压缩然后下载到本地路径 实现方式 需要对远程服务器实现无密码访问,通过配置公钥实现: 使用ssh执行命令然后转向到本地的方法一步完成打包和下载,可参 ...
- 登录式与非登录式&交互式与非交互式shell及其环境初始化过程
交互式shell和非交互式shell(interactive shell and non-interactive shell) 交互式模式就是在终端上执行,shell等待你的输入,并且立即执行你提交的 ...
- Linux登录shell和非登录(交互式shell)环境变量配置
使用Jenkins执行shell脚本的时候, 碰到command not found. 比如java mvn, 这些环境变量配置在/etc/profile 中, 但jenkins执行的时候并没有加载. ...
- 快Key:按一下鼠标【滚轮】,帮你自动填写用户名密码,快速登录,可制作U盘随身(开源免费-附安装文件和源代码)
* 代码以本文所附下载文件包为准,安装文件和源文件包均在本文尾部可下载. * 快Key及本文所有内容仅供交流使用,使用者责任自负,由快Key对使用者及其相关人员或组织造成的任何损失均由使用者自负,与本 ...
- shell与变量的声明的操作
1.给命令起别名:alias 执行下面命令后,可以使用dir代替ls –l 命令,显示目录中的文件详细信息: 还可以用一个别名表示几个命令 的结合: 2.ps:显示当前登录会话的所有活动进程: 3.更 ...
随机推荐
- 框架应用 : Spring MVC - 开发详述
软件开发中的MVC设计模式 软件开发的目标是减小耦合,让模块之前关系清晰. MVC模式在软件开发中经常和ORM模式一起应用,主要作用是将(数据抽象,数据实体传输和前台数据展示)分层,这样前台,后台,数 ...
- ios自定义数字键盘
因为项目又一个提现的功能,textfiled文本框输入需要弹出数字键盘,首先想到的就是设置textfiled的keyboardType为numberPad,此时你会看到如下的效果: 但是很遗憾这样 ...
- 详解变量声明加 var 和不加 var 的区别
在全局作用域中声明变量加 var 关键字和不加 var ,js 引擎都会将这个变量声明为全局变量,在实际运行时,两种声明方式的变量的行为也是几乎一致的.但是在全局作用域下是否声明一个变量的 时候加va ...
- asp.net C# 实现微信接口权限开发类
当前微信接口类已实现以下接口,代码上如果不够简洁的,请自行处理. 1.获取access_token 2.获取用户基本信息 3.生成带参数二维码 4.新增永久素材 5.新增临时素材 6.发送微信模版 7 ...
- java zip解压
/** * 解压文件到指定目录 * @param zipFile * @param descDir * @author sqdll */@SuppressWarnings("rawtypes ...
- 关于EF Code First模式不同建模方式对建表产生的影响
今天在学EF Code First模式的时候,发现几个很有趣的问题,问题如下: 1.当编写玩实体后,不指定任何主键约束,EF会找长的最像Id的,然后设置其为主键,验证代码如下: //User类 cla ...
- 关于github在客户端不小心删除新仓库,重建后无法上传解决方法
不小心删除了如果直接在客户端重建一个不行,首先找出本地新仓库,删除,然后在重新再客户端建立一个. 但此时如果两仓库名字一样,会发现无法上传. 此时应该在网页打开github,点击进入之前删除的仓库(云 ...
- hibernate和mybatis区别
看图 Hibernate mybatis 难易度 难 简单,容易上手 编码 良好的映射机制,不需要关心 需要手动编写sql,resultMap 调优 制定合理的缓存策略: 尽量使用延迟加载特性: ...
- PHP常用配置
Php配置文件:php.ini(使用‘;’表示注释) Php的配置项可以在配置文件中配置,也可以在脚本中使用ini_set()函数临时配置. 语言相关配置: 1. engine:设置PHP引擎是否可用 ...
- PHP Curl模拟登录并抓取数据
使用PHP的Curl扩展库可以模拟实现登录,并抓取一些需要用户账号登录以后才能查看的数据.具体实现的流程如下(个人总结): 1. 首先需要对相应的登录页面的html源代码进行分析,获得一些必要的信息: ...