Shell脚本实现SSH免密登录及批量配置管理

pssh工具批量管理

SHELL自动化脚本

本篇总结

场景分析

作为一个运维工程师,不是每个人工作的环境都想阿里、腾讯那样,动不动就上亿的PV量,上万台服务器。我们通常还是工作在,几十台上百台服务器这样的环境,而使用ansible或者puppet这样的自动化运维工具则显得大材小用,并且最终的效果可能还不如几个小工具达到的效果好。像ssh免密登录在配合pssh这样的推送工具,在配合自动化配置脚本,可以说是即方便也使用。这一节将详细带大家以shell脚本的形式实现ssh免密登录进行百台机器的配置和管理。

ssh服务

随着明文通信协议telnet渐渐退出历史舞台,ssh这个作为安全的远程登录工具,更加受广大用户的青睐。SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定;SSH 为建立在应用层基础上的安全协议。SSH 是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。SSH最初是UNIX系统上的一个程序,后来又迅速扩展到其他操作平台。SSH在正确使用时可弥补网络中的漏洞。SSH客户端适用于多种平台。几乎所有UNIX平台—包括HP-UX、Linux、AIX、Solaris、Digital UNIX、Irix,以及其他平台,都可运行SSH。

ssh服务有两种验证用户登录的方式,一种是基于密码口令的认证,一种是基于密钥的认证,本文主要是实现基于密钥的认证。ssh基于密钥认证过程:

wKioL1naFYGxqnPsAACTluQeBiY673.png

ssh工具不仅仅提供了远程登录的功能,他还自带了一些命令工具,能够生成ssh会话密钥,并且能够将生成密钥对的公钥复制到远程主机,例如:

生成密钥ssh-keygen -t rsa [-P ''] [-f '~/.ssh/id_rsa']

wKioL1nZzv-S5BgGAABFPIA92cg277.png

复制公钥至远程主机ssh-copy-id [-i indetify_file ][user@host_ip]

wKiom1nZz2GAu_pxAABVv8MpkWc120.png

-p表示指定私钥密码,上面我没有对私钥进行加密,主要是方便,在实际生产中建议对私钥进行加密,因为如果不小心丢了私钥,你的整个系统都将面临很大的风险。通过上面两步之后你就可以实现ssh免密码登录了,下次你在用ssh登录到172.18.14.123(有你公钥的主机)时将不在输入密码。

不过这里我们会发现,我们在复制公钥的时候还是需要手动输入密码,我们可以使用shell脚本编程中的expect语法,他能代替我们输入登录密码

#!/usr/bin/expect

spawn ssh 172.18.8.100

expect {

    "yes/no" { send "yes\n";exp_continue }      # 替你回答下载公钥是的提示

    "password" { send "your_passwd\n" }         # 提示输入密码

}

interact

expect eof 

pssh工具     

      在上面的例子中我们发现,我们仅仅是实现了一台主机的ssh免密码登录,而我们的环境至也得有几十台机器,这远远没有达到我们的目的“自动化部署、配置、管理”;前辈有言:如果你的同一个操作大于3次,那么你就要考虑使用自动化方式了。所以,我们还得做进一步的改善,此时我们想到了一个功能很强大的小工具pssh。

pssh命令是一个Python编写可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的,类似pdsh,个人认为相对pdsh更为简便,使用必须在各个服务器上配置好密钥认证访问。做了免密登录之后,pssh将发挥它最大的功能。下面说说pssh的参数。

*****pssh的选项参数*****

  

--version:查看版本 

--help:查看帮助,即此信息

-h:主机文件列表,内容格式"[user@]host[:port]" 

-H:主机字符串,内容格式"[user@]host[:port]" 

- :登录使用的用户名 

-p:并发的线程数[ 可选 ]

-o:输出的文件目录[ 可选 ] 

-e:错误输入文件[ 可选 ] 

-t:TIMEOUT 超时时间设置,0无限制[ 可选 ] 

-O:SSH的选项 

-v:详细模式 

-A:手动输入密码模式 

-x:额外的命令行参数使用空白符号,引号,反斜线处理 

-X:额外的命令行参数,单个参数模式,同-x 

-i:每个服务器内部处理信息输出 -P:打印出服务器返回信息

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/ff58391b2fe0e85db8c8e0e49fad4745.html