MacTalk 2018-05-19
是一个运维自动化管理项目:
为了减少人工干预,降低人员成本 ---资产管理 --操作管理
避免人员直接操作服务器,使用后台去统一操作


注意:数据是由服务器agent主动发送至API
实现方案:
本地执行cmd命令。
方法一:os.system("命令") 不可以返回数据
方法二:subprocess模块,使用进程执行命令,可以获取到数据Popen("命令"),进程.stdout.read()<py2>或者直接getoutput("命令")<py3>

def agent(self,cmd):
import subprocess
try:
ret = subprocess.getoutput(cmd)
except AttributeError:
sub = subprocess.Popen(args=cmd,shell=True,stdout=subprocess.PIPE)
sub.wait()
ret = sub.stdout.read()
return retpython实现agentparamiko模块了解



def ssh(self,cmd):
import paramiko
#.创建SSH对象
ssh = paramiko.SSHClient()
#.加上这句话不用担心选yes的问题,会自动选上
#.用ssh连接远程主机时,第一次连接时会提示是否继续进行远程连接,选择yes
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname="远程主机名",port="远程端口",username="用户名",password="密码")
#执行命令,获取结果到标准输入\出\错误流中
stdin,stdout,stderr = ssh.exec_command(cmd)
#.获取命令结果
result = stdout.read()
#.关闭连接
ssh.close()paramiko实现远程命令执行(方法一:使用用户名,密码)

def ssh(self,cmd):
import paramiko
#.创建SSH对象
ssh = paramiko.SSHClient()
#.加上这句话不用担心选yes的问题,会自动选上
#用ssh连接远程主机时,第一次连接时会提示是否继续进行远程连接,选择yes
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
#.获取私钥
private_key = paramiko.RSAKey.from_private_key_file("文件:其中保存了私钥,用于解密")
#.通过私钥去连接远程服务器(前提是自己的公钥已经在对方的authorized_keys文件中,paramiko已实现)
ssh.connect(hostname="远程主机名",port="远程端口",username="用户名",pkey="私钥private_key")
#.执行命令,获取结果到标准输入\出\错误流中
stdin,stdout,stderr = ssh.exec_command(cmd)
#.获取命令结果
result = stdout.read()
#.关闭连接
ssh.close()
return resultparamiko使用私钥去登录远程服务器执行命令