shell实现SSH自动登陆
前言 公司开发使用docker,每次登陆自己开发机总要输入 前些天在同事进行技术分享时,看到他竟然只输入了一行命令 shell脚本基础在编写ssh自动登陆脚本之前,先说一下shell脚本的基础,此基础不是一些语法什么的,网上到处都是,这里总结了一下shell脚本的运行机制~ shell脚本的运行方式首先要说一下shell的几种启动方式,正是踩了脚本启动的坑,才使用原来十分钟就搞定的脚本,花了两个小时才搞定。同时也使得我们运行shell,知其所以然。 通过文件名执行 shell脚本可以直接通过文件名执行,需要注意的是文件需要执行权限。通过 指定脚本解释器来执行文件 我们常用的 使用. ./file_name或source命令执行脚本这种方式不会像前两种方式一样fork一个子进程去执行脚本,而是使用当前shell环境执行,用于 .bashrc或者.bash_profile被修改的时候,我们不必重启shell或者重新登录系统,就能使当前的更改生效。 shebang 我们写一个shell脚本时,总是习惯在最前面加上一行 贴一段wiki上的解释:
简单的说,它指示了此脚本运行时的解释器,所以,使用文件名直接执行shell脚本时,必须带上shebang; 此外,我们还可以在shebang后面直接附加选项,执行时我们默认使用选项执行; 如 相当于: bin/sh -x ./test.sh hello; 而编写一个ssh自动登陆脚本,需要用到的shebang(解释器)为 需要注意的是:在指定脚本解释器来执行脚本时,shebang会被指定的脚本解释器覆盖,即优先使用指定的脚本解释器来执行脚本(习惯性地用sh ./test.sh却提示command not found) expect解释器expect是一个能实现自动和交互式任务的解释器,它也能解释常见的shell语法命令,其特色在以下几个命令: spawn命令:spawn command命令会fork一个子进程去执行command命令,然后在此子进程中执行后面的命令; 在ssh自动登陆脚本中,我们使用 expect命令: expect命令是expect解释器的关键命令,它的一般用法为 string与命令行返回的信息匹配后,expect会立刻向下执行脚本; set timeout命令:set timeout n命令将expect命令的等待超时时间设置为n秒,在n秒内还没有获取到其期待的命令,expect 为false,脚本会继续向下执行; send命令: send命令的一般用法为 interact命令:interact命令很简单,执行到此命令时,脚本fork的子进程会将操作权交给用户,允许用户与当前shell进行交互; 完成脚本 以下是一个完成版的脚本 #!/usr/bin/expect // 指定shebang set timeout 3 // 设定超时时间为3秒 spawn ssh user_name@172.***.***.*** // fork一个子进程执行ssh命令 expect "*password*" // 期待匹配到 'user_name@ip_string's password:' send "my_passwordr" // 向命令行输入密码并回车 send "sudo -sr" send "cd /data/logsr" // 帮我切换到常用的工作目录 interact // 允许用户与命令行交互 执行 运行 简单的几个命令,,搭配起来解决了与命令行的交互问题后,很多复杂的功能也不在话下了~ alias别名脚本完成了,可是还是有些小瑕疵:
这里我们想到了linux的alias命令: alias命令: alias命令使用方式为 可是,我们会发现,当你关闭当前shell后,再打开一个shell窗口,再使用alias_name,系统提示 有没有能保持命令的方式呢?编辑bash_profile文件。 bash_profile文件我们编辑bash_profile文件,此文件会在终端窗口创建的时候首先执行一次,所以可以帮我们再设置一次别名; 执行命令 alias alias_name="/root_dir/../file_name.sh 保存后,再使用 这样,我们无论在哪个目录,只要输入 总结 作为一个程序猿,时刻保持着 一个多月没写博客了,最近在看APUE,UNP一套的书,C和Unix上入门尚浅,不敢乱写误人子弟;平常自己用记事本做的笔记也比较散乱,不成系统; 慢慢积累吧,有适当的项目会写的,欢迎大家关注~ 转自:http://www.cnblogs.com/zhenbianshu/p/5867440.html (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |