Ubuntu下使用python实现全自动ssh免密登录设置
本文主要是使用了python自带的模块os和第三方的模块paramiko,实现在知道用户名和密码的情况下,将ssh远程连接设置为免密登录的形式。本质就是为要登录的主机添加公钥,本机添加私钥。当然一切的前提是你已经开启了ssh服务。
这个函数也可以嵌入的你的代码中,在需要ssh登录的地方提前设置好免登录,今后就可以不用再输密码了。
本人在服务端的Ubuntu和centos上均测试通过。centos你可能需要修改一下sshd服务重启的指令。
import os, paramiko
def ssh_authentication(server_ip, user, passwd):
"""进行ssh的免密码认证"""
# server_id 备份服务器地址,字符串
logger.info("test ping server %s ..." % server_ip)
if os.system("ping %s -c 3 >>/dev/null" % server_ip):
# 先测试一下连通性
return -1
if os.path.exists(os.path.expanduser("~/.ssh/id_rsa")) and os.path.exists(
os.path.expanduser("~/.ssh/id_rsa.pub")):
else:
if os.system("ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa"): # 在客户端生成ssh密钥,设置好参数,这样就不会中途要求输入
return -1
# 使用

本文介绍了如何在Ubuntu环境下利用python的os和paramiko模块,实现在已知用户名和密码的情况下,自动化设置SSH远程连接的免密登录。通过为远程主机添加公钥和本地添加私钥,实现无需密码即可登录的目标。此方法已在Ubuntu和CentOS系统上测试成功,注意CentOS中SSHD服务重启命令可能需要调整。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



