Python中利用subprocess远程登陆执行命令

本文介绍了一种使用Python的subprocess模块结合sshpass程序实现SSH远程连接的方法,并演示了如何通过脚本自动输入密码进行认证的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import subprocess

import os



(rfd, wfd) = os.pipe()

arg = "-d%d" % rfd

try:

    p = subprocess.Popen(["sshpass",arg,"ssh","-l","haohzhang","phxaishdc9dn1447.stratus.phx.ebay.com","ls","/tmp/"], stdin=subprocess.PIPE,stdout=subprocess.PIPE, stderr=subprocess.PIPE)

    os.close(rfd)

    os.write(wfd,"PASSWORD\n")

    os.close(wfd)

    stdout, stderr = p.communicate()

    print stdout, stderr

except OSError:

    print("to use the 'ssh' connection type with passwords, you must install the sshpass program")

 

### 配置SSH密钥以实现在多个Linux服务器之间进行免密码登录 #### 创建SSH密钥对 为了在多台Linux服务器间实现无密码登录,首先需要创建一个SSH密钥对。这可以通过`ssh-keygen`工具完成。 ```bash ssh-keygen -t rsa -b 4096 -C "your_email@example.com" ``` 这条命令将会生成一个新的RSA类型的私钥和公钥文件,默认情况下会被保存在用户的`.ssh`目录下[^3]。 #### 复制公钥至远程主机 一旦有了密钥对之后,下一步就是把本地机器上的公钥复制到其他想要访问的目标服务器上去。可以利用`ssh-copy-id`这个便捷的小程序来做这件事: ```bash ssh-copy-id user@remote_host ``` 这里`user`代表你在远端系统的用户名字,而`remote_host`则是那台计算机的IP地址或者是域名[^1]。 对于批量操作来说,如果面对的是大量的服务器,则可能希望编写一个小脚本来自动化这一过程。下面给出一段Python代码作为例子,用于迭代给定的一系列主机并执行上述步骤: ```python import subprocess hosts = ['host1', 'host2', 'host3'] # 替换成实际的主机名列表 for host in hosts: result = subprocess.run(['ssh-copy-id', f'user@{host}'], capture_output=True, text=True) print(f'Copying key to {host}:') if result.returncode == 0: print('Success!') else: print(result.stderr.strip()) ``` 这段脚本会尝试向每一台指定的主机发送当前用户的公钥,并打印出相应的成功与否的信息[^4]。 #### 测试连接 最后一步是要确认一切正常工作。可以从一台已经设置了密钥认证的客户机发起不带任何参数(即不需要再次输入密码)的SSH请求到达另一台或多台目标服务器上试试看能否顺利建立连接。 ```bash ssh user@target_server ``` 只要之前的操作都没有错误的话,此时应该可以直接进入对方系统而不会被提示要求输入密码了[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值