python mysql paramiko_python paramiko 验证和发送命令的几种方式

法1:使用 exec.command(),此方法不适合用 sudu su不输入密码的状况

#!/usr/bin/env python

import paramiko

hostname='172.16.88.117'

username='liuqian'

pk_path='/home/liuqian/.ssh/id_rsa'

try:

key=paramiko.RSAKey.from_private_key_file(pk_path)

except paramiko.PasswordRequiredException:

password = getpass.getpass('RSA key password:

')

key =

paramiko.RSAKey.from_private_key_file(pk_path, password)

#

需要口令的私钥

ssh=paramiko.SSHClient()

ssh.load_system_host_keys()

ssh.connect(hostname=hostname, username=username,

pkey=key)

stdin, stdout, stderr=ssh.exec_command('cd /var/log;ls')

# 下面的方法适合使用密码登陆的状况

# ssh.connect(hostname=hostname,

username=username, password=‘123456’)

# stdin, stdout,

stderr=ssh.exec_command('sudo su')

# stdin.write('123456')

# stdin.flush()

print stdout.readlines()

print stderr.readlines()

ssh.close()

法2:使用 send()

#!/usr/bin/env python

import paramiko

import time

import socket

ip='172.16.88.117'

username='liuqian'

pk_path='/home/liuqian/.ssh/id_rsa'

cmds=['sudo su\n', 'cd /var/log\n', 'ls\n']

try:

key=paramiko.RSAKey.from_private_key_file(pk_path)

except paramiko.PasswordRequiredException:

password = getpass.getpass('RSA key password:

')

key =

paramiko.RSAKey.from_private_key_file(pk_path, password)

s=paramiko.SSHClient()

s.load_system_host_keys()

try:

s.connect(hostname=ip,username=username,pkey=key,timeout=5)

except socket.timeout as e:

sys.exit(1)

ssh=s.invoke_shell()

for cmd in cmds:

time.sleep(1)

ssh.send(cmd)

out = ssh.recv(1024)

print out

ssh.close()

推荐一个非常好的关于容器技术的公众号,有兴趣的可以关注!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值