3o_AutoSSH
∮自动发送 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的更多相关文章
随机推荐
- ASP.NET Web API - ASP.NET MVC 4 系列
Web API 项目是 Windows 通信接口(Windows Communication Foundation,WCF)团队及其用户激情下的产物,他们想与 HTTP 深度整合.WCF ...
- KNN近邻算法
K近邻(KNN,k-NearestNeighbor)分类算法是数据挖掘分类技术中最简单的方法之一.所谓K最近邻,就是k个最近的邻居的意思,说的是每个样本都可以用它最接近的k个邻居来代表.kNN算法的核 ...
- jquery之实例应用
Query是一个兼容多浏览器的javascript库,核心理念是write less,do more(写得更少,做得更多),对javascript进行了封装,是的更加便捷的开发,并且在兼容性方面十分优 ...
- 浅入浅出EmguCv(三)EmguCv打开指定视频
打开视频的思路跟打开图片的思路是一样的,只不过视频是由一帧帧图片组成,因此,打开视频的处理程序有一个连续的获取图片并逐帧显示的处理过程.GUI同<浅入浅出EmguCv(二)EmguCv打开指定图 ...
- AlwaysOn添加高可用性自定义登陆用户的方法
1.在主服务器添加自定义登陆用户,比如TestUser 2.在主服务器执行如下SQL,在master数据库创建存储过程sp_hexadecimal,sp_help_revlogin USE maste ...
- java内存的那些事
在Java中,内存的管理分为以下几个部分: Heap:堆区域,存放对象实例,凡是New出来的东西都存放在此. Stack:栈区域,存放基本数据类型.常量.局部变量.对象的引用地址 Data Segme ...
- 文章汇总(包括NVMe SPDK vSAN Ceph xfs等)
基础部分 NVMe驱动解析-前言 NVMe驱动解析-注册设备 NVMe驱动解析-关键的BAR空间 NVMe驱动解析-DMA传输(热门) NVMe驱动解析-响应I/O请求 用一个简单的例子窥探NVMe的 ...
- Files 的值“ < < < < < < < .mine”无效。路径中具有非法字符。
出现这个问题的原因是,用svn时,发生了冲突.解决方法:先解决代码冲突,然后在你的工程OBJ/DEBUG目录下,找到 工程名.csproj.FileListAbsolute.txt的文件打开并删除含有 ...
- Digests from CG articales
Turtle Talk Prior to the on-set motion capture, the team had the actors perform expressions while be ...
- opengl入门学习
OpenGL入门学习 说起编程作图,大概还有很多人想起TC的#include <graphics.h>吧? 但是各位是否想过,那些画面绚丽的PC游戏是如何编写出来的?就靠TC那可怜的640 ...