我正在尝试使用 python-paramiko 在远程机器上执行 sudo 命令,当我执行命令时,我将它与 3 个流绑定,并且我使用输入流来传递密码,但它不起作用,这是回溯结果:
Traceback (most recent call last):
File "<input>", line 1, in <module>
File "/usr/local/lib/python2.7/dist-packages/paramiko/file.py", line 314, in write
self._write_all(data)
File "/usr/local/lib/python2.7/dist-packages/paramiko/file.py", line 439, in _write_all
count = self._write(data)
File "/usr/local/lib/python2.7/dist-packages/paramiko/channel.py", line 1263,in _write
self.channel.sendall(data)
File "/usr/local/lib/python2.7/dist-packages/paramiko/channel.py", line 796, in sendall
raise socket.error('Socket is closed')
error: Socket is closed
这是我的 python 代码:
import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('192.168.0.104', username='cdc',password='123456')
stdin, stdout, stderr = ssh.exec_command("sudo dmesg")
stdin.write("123456\n")
stdin.flush()
print stdout.readlines()
ssh.close()
有什么帮助吗?提前致谢
原文由 user3176971 发布,翻译遵循 CC BY-SA 4.0 许可协议
首先,您是否在控制台中尝试过
ssh cdc@192.168.0.104 "sudo -S -p '' dmesg"
。如果它也失败了,那么您可以检查sshd
设置和sudoer
设置。如果运行良好,请在行与行之间添加一些回声,以便我们可以准确知道抛出异常的时间。我非常怀疑您是否应该将
sudo dmesg
更改为sudo -S -p '' dmesg
。你也可以试试我的 paramiko 包装纸。我可以顺利地使用它来访问任何 CentOS/SuSE 节点并执行任何命令(w/wo sudo 权限):