∮自动发送 ssh 公钥,为 ansible 鸣锣开道

  • Bold 参考资料 http://mageedu.blog.51cto.com/4265610/1412028
  • ...其实我并没有参考这篇博文的很多东西,只是我不太想解释我在做什么....
  • ...我在做的其实是 使ansible 的被管理主机实现通过脚本发送 ssh 公钥,使其可以基于 ssh 进行互信通信

之前对 ssh 的理解稍有偏差,我在这里直接说正确的理解就好了.

A 连接 B (A,B 是两台机器,跑着 Linux CentOS7 的机器),B 是SSH 服务器,A 是客户端.

客户端需要把 自己的公钥发送至 服务器.以实现无需验证的 ssh 登陆.B 需要一直监听在 TCP22 端口.

A 是客户端,但 A 也是 ansible 的管理端, B 是众多被管理的 小弟之中的一个... "小弟"之中的一个.但 B 是 SSH 的服务器端.

其实我下面要说的 和 ansible 就没啥关系...

我直接上脚本吧... . ~之前还要做一件事#yum install expect

嗯嗯,一般来讲,expect 是另一种脚本,第一行得指明解释器的位置, man文档里说的比较清楚 # man expect

人家说确保 #!/usr/bin/expect -f 在程序的第一行,不过人家是用英语说的...

但是我用 EOF流 将expect 的脚本嵌套在 bash 脚本中了.

# vim auto_ssh.sh" /etc/passwd

#!/bin/bash

count=1

if [ -z $1 ] ; then

       echo "READ ./auto_ssh.txt NOOB ... ^v^"

       exit 6

fi

if [ ! -e /root/.ssh/id_rsa.pub ] ; then

       ssh-keygen -q -t rsa -f /root/.ssh/id_rsa -P ''

fi

for i in `awk '{print $1}' auto_ssh.txt` ; do

       user=`awk -v I="$i" '{if(I==$1)print $2}' auto_ssh.txt`

       pawd=`awk -v I="$i" '{if(I==$1)print $3}' auto_ssh.txt`

       /usr/bin/expect << EOF

       set time 5

       spawn ssh-copy-id -i /root/.ssh/id_rsa.pub $user\@$i

       expect {

               "*(yes/no)*"        {

                     send "yes\r"

                     exp_continue

               }

               "*password*" {

                     send "$pawd\r"

               }

       }

       interact

       expect eof

       EOF

       echo ""

       echo "$i ssh-copy-id done!!"

       if [ $count -ge $1 ] ; then

              break

       fi

       let count++

       sleep 1

done

ssh-add # 这句很关键呦

接下来编辑一下你的配置文件,方便脚本去解析.

# vim auto_ssh.txt

以上方案应该不是最优方案,嗯嗯,一定不是.

但 以上方案是一个可行的方案,如果你觉得要写配置文件有点麻烦...

你的 /etc/ansible/hosts 文件里的主机是怎么添加上的.

嗯嗯,一如既往的献上彩蛋~

经过以上的操作之后, ssh 可以不用输入密码就可以登陆了.[即使在对方主机修改了 登陆密码之后,比如 root]

有一种奇葩的操作,是 定期给服务器更换 root 密码.如果你执行了以下指令.

# echo `cat /dev/urandom |strings -n 12 |head -n 1` | passwd --stdin root

基本正常人就再也 不可能知道你的 root 密码了~ 嗯嗯,也再没有人能以 root 登陆这台主机了.除了...

除了这台 SSH 客户端,可以登陆,而且无需验证密码~ 其实我很感兴趣的是 除此之外还有什么方法能以 root 再登陆B主机呢...

欢迎 交流~

3o_AutoSSH的更多相关文章

随机推荐

  1. Linux环境下段错误的产生原因及调试方法小结(转)

    最近在Linux环境下做C语言项目,由于是在一个原有项目基础之上进行二次开发,而且 项目工程庞大复杂,出现了不少问题,其中遇到最多.花费时间最长的问题就是著名的“段错误”(Segmentation F ...

  2. php7 编译安装 apache

    http://blog.csdn.net/21aspnet/article/details/47708763 根据此教程的步骤但是碰到了若干问题 1.  执行./configure的时候报错 大部分可 ...

  3. 水池进水与放水问题:有一个水池,水池的容量是固定 的500L,一边为进水口,一边为出水口.........(多线程应用)

    package demo2; class Pooll {    /**1:有一个水池,水池的容量是固定 的500L,一边为进水口,一边为出水口.     * 要求,进水与放水不能同时进行.     水 ...

  4. multipath test

    [root@rac02 mnt]# multipath -llmpathb (36005076300810df6f800000000000005) dm-3 IBM,2145size=50G feat ...

  5. Maven间接依赖冲突解决办法

    如果项目中maven依赖太多,由于还有jar之间的间接依赖,所以可能会存在依赖冲突.依赖冲突大部分都是由于版本冲突引起的,查看maven的依赖关系,可以找到引起冲突的间接依赖 如上图,通过Depend ...

  6. 【学】React的学习之旅1

    React的学习之旅1 单标签要有斜杠代表结束 用React.createClass()方法时,赋值后的组件名称首字母一定要大写 一定要先定义组件,再用ReactDOM.render调用 组件里ren ...

  7. js嵌套对象相等比较的一种方法 (原创)

    做前端开发经常会遇到比较js对象是否相等的情况, 或者说其它问题往往会归结到这个问题上来:比如对象数组的去重复. 网上看到过很多例子, 但是基本上都是那种比较简单的对象结构, 而复杂的对象结构,比如对 ...

  8. Random

    /* * Random:产生随机数的类 * * 构造方法: * public Random():没有给种子,用的是默认种子,是当前时间的毫秒值 * public Random(long seed):给 ...

  9. log4net 配置

    1.是直接在代码中通过调用XmlConfigurator.Configure()来解析配置文件,配置日志环境. log4net.Config.XmlConfigurator.Configure(); ...

  10. DevExpress TreeList 全选和反选 z

    /// <summary> /// 全选树 /// </summary> /// <param name="tree">树控件</para ...