一.自动输入密码
场景:
由于多台机必须要登陆执行命令,需要使用密钥一台台登录,所以每次登陆机器的时候都需要手动输入域账号密码。密码太长且复杂,手动输入容易输错,故使用脚本来做这个事情,实现免输入密码登陆,工作效率大大提升!
解决方法:
使用 expect
使用 sshpass
结合 alfred 可以快速一键登录
也可以使用 electerm 进行登录
对于我自己而言的话,用的最爽的还是使用 sshpass+alfred 一键登录,先安装 sshpass,然后使用命令
sshpass -p 你的密码 ssh -A -g yourname@ip
1
登录到服务器,然后再执行脚本,部署自己的应用或者博客,登录服务器的命令用 alfred 的 workflow 来执行,方便快捷
后续使用 cicd 来部署,每次提交即可进行部署,不用登录到服务器即可部署.
二.sshpass 方式
1.安装 sshpass
sshpass 是一个实用工具,它提供了一种自动化 SSH 密码认证的方式。它允许你将密码作为命令行参数或通过环境变量传递给 SSH 命令,从而在非交互式方式下进行 SSH 登录。
使用 sshpass 可以方便地批量管理多台服务器,同时也可以将其用于自动化脚本或任务中,从而减少手动输入密码的繁琐。需要注意的是,使用 sshpass 可能会存在一定的安全风险,因此在使用时需要谨慎考虑。
不能使用命令安装,会报错,使用源码安装.
使用方式:
sshpass -p 'password' ssh user@host
1
其中 -p 参数指定密码,user@host 是要登录的目标服务器地址和用户名。使用上述命令后,sshpass 将会自动完成 SSH 登录过程,而无需手动输入密码。
除了使用命令行参数外,你也可以将密码保存在环境变量中,然后通过 $ENV_VAR 的方式引用它,例如:
export SSHPASS='password'
sshpass -e ssh user@host
1
2
其中 -e 参数指示 sshpass 使用环境变量传递密码。在这种方式下,你需要事先将密码保存在 $SSHPASS 环境变量中。
需要注意的是,使用 sshpass 存在一定的安全风险,因为密码会以明文方式传递,容易被恶意程序截获。因此,在使用 sshpass 时,应尽可能避免将密码保存在脚本中,或者将其保存在安全加密的文件中。另外,如果可能的话,建议使用 SSH 公钥认证方式来代替密码认证。
2.源码下载
#源码下载
https://sourceforge.net/projects/sshpass/
1
2
3.安装过程
#解压缩
#安装
cd sshpass-1.08
#执行配置文件
./configure
#编译
make
#编译安装
make install
1
2
3
4
5
6
7
8
9
10
11
12
13
4.验证
#查看版本
sshpass -V
#登录服务器
sshpass -p 你的密码 ssh -A -g yourname@ip
1
2
3
4
5
三.expect 方式
首先我们创建以一个文本文件,命名为 proxy.expect,内容如下:
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qyj19920704/article/details/128224641