不需要下载其他插件,使用脚本
目录
操作步骤如下:
实际举例如下:
1.编写sh文件
2.编辑sh文件
3.进入iterm2,打开profiles,edit profiles
4.验证
扩展 expect脚本
操作步骤如下:
在你电脑你想编辑的地方,编辑一个sh文件,命名随意。接着编写sh文件,写入内容,然后再iterm2中打开profiles,写入加载sh命名,最后点击这个profile即可完成登录
实际举例如下:
1.编写sh文件
我在用户目录本用户下创建一个test文件夹,里面新建一个test.sh文件,路径如图所示
2.编辑sh文件
编辑 文件,写入如下内容
注意:需要修改用户名、ip和密码为自己服务器的
#set user 登录用户名root,根据自己修改
set user root
#服务器ip或域名,根据自己修改
set host 12.15.23.21
#登陆密码为1234,根据自己修改
set password 1234
spawn ssh $user@$host
expect {
"yes/no" { send "yes\r";exp_continue }
"password:" { send "$password\r" }
}
interact
expect eof
3.进入iterm2,打开profiles,edit profiles
新建一个profile,自定义一个名字,在command中选择command,默认为login shell;
在command中写入命令
expect ~/fooleryang/test/test.sh
该命令为执行该脚本,脚本路径参照创建sh文件时,写绝对路径
4.验证
点击master
不用输入密码,直接进入
iterm2在打开多个链接时还支持同时输入,按住command+shift+i即可进行同时写入
扩展 expect脚本
Expect是建立在tcl基础上的一个工具,Expect 是用来进行自动化控制和测试的工具。主要解决shell脚本中不可交互的问题。对于大规模的linux 运维很有帮助
在linux运维和开发中,我们经常需要远程登录服务器进行操作,登录的过程是一个交互的过程,可能会需要输入yes/no password等信息。为了模拟这种输入,可以使用Expect脚本
- send:向进程发送字符串,用于模拟用户的输入,该命令不能自动回车换行,一般要加 \r(回车)
- expect:expect的一个内部命令,判断上次输出结果里是否包含指定的字符串,如果有则立即返回,否则就等待超时时间后返回。只能捕捉由spawn启动的进程的输出
- spawn:启动进程,并跟踪后续交互信息
- interact:执行完成后保持交互状态,把控制权交给控制台
- Timeout:指定超时时间,过期则继续执行后续指令
- exp_continue:允许expect继续向下执行指令
- send_user:回显命令,相当于echo
- $argv 参数数组:Expect脚本可以接受从bash传递的参数.可以使用[lindex $argv n]获得,n从0开始,分别表示第一个,第二个,第三个…参数