自动化运维工具

Posted p0st

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动化运维工具相关的知识,希望对你有一定的参考价值。

Paramiko

  paramiko模块,基于SSH用于连接远程服务器并执行相关操作。使用该模块可以对远程服务器进行命令或文件操作,值得一说的是,fabric和ansible内部的远程管理就是使用的paramiko来现实。

1.安装paramiko

pip3 install paramiko

2.使用paramiko

  sshclient

技术分享图片
import paramiko
   
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname=c1.salt.com, port=22, username=wupeiqi, password=123)
   
# 执行命令
stdin, stdout, stderr = ssh.exec_command(ls)
# 获取命令结果
result = stdout.read()
   
# 关闭连接
ssh.close()
基于用户名密码连接远程主机
技术分享图片
import paramiko
  
private_key = paramiko.RSAKey.from_private_key_file(/home/auto/.ssh/id_rsa)
  
# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname=c1.salt.com, port=22, username=wupeiqi, key=private_key)
  
# 执行命令
stdin, stdout, stderr = ssh.exec_command(df)
# 获取命令结果
result = stdout.read()
  
# 关闭连接
ssh.close()
基于公钥连接远程主机

  sftpclient

技术分享图片
import paramiko
  
transport = paramiko.Transport((hostname,22))
transport.connect(username=wupeiqi,password=123)
  
sftp = paramiko.SFTPClient.from_transport(transport)
# 将location.py 上传至服务器 /tmp/test.py
sftp.put(/tmp/location.py, /tmp/test.py)
# 将remove_path 下载到本地 local_path
sftp.get(remove_path, local_path)
  
transport.close()
基于用户名密码上传
技术分享图片
import paramiko
  
private_key = paramiko.RSAKey.from_private_key_file(/home/auto/.ssh/id_rsa)
  
transport = paramiko.Transport((hostname, 22))
transport.connect(username=wupeiqi, pkey=private_key )
  
sftp = paramiko.SFTPClient.from_transport(transport)
# 将location.py 上传至服务器 /tmp/test.py
sftp.put(/tmp/location.py, /tmp/test.py)
# 将remove_path 下载到本地 local_path
sftp.get(remove_path, local_path)
  
transport.close()
基于秘钥进行上传

3.demo

技术分享图片
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import paramiko
import uuid

class SSHConnection(object):

    def __init__(self, host=172.16.103.191, port=22, username=wupeiqi,pwd=123):
        self.host = host
        self.port = port
        self.username = username
        self.pwd = pwd
        self.__k = None

    def create_file(self):
        file_name = str(uuid.uuid4())
        with open(file_name,w) as f:
            f.write(sb)
        return file_name

    def run(self):
        self.connect()
        self.upload(/home/wupeiqi/tttttttttttt.py)
        self.rename(/home/wupeiqi/tttttttttttt.py, /home/wupeiqi/ooooooooo.py)
        self.close()

    def connect(self):
        transport = paramiko.Transport((self.host,self.port))
        transport.connect(username=self.username,password=self.pwd)
        self.__transport = transport

    def close(self):

        self.__transport.close()

    def upload(self,target_path):
        # 连接,上传
        file_name = self.create_file()

        sftp = paramiko.SFTPClient.from_transport(self.__transport)
        # 将location.py 上传至服务器 /tmp/test.py
        sftp.put(file_name, target_path)

    def rename(self, old_path, new_path):

        ssh = paramiko.SSHClient()
        ssh._transport = self.__transport
        # 执行命令
        cmd = "mv %s %s" % (old_path, new_path,)
        stdin, stdout, stderr = ssh.exec_command(cmd)
        # 获取命令结果
        result = stdout.read()

    def cmd(self, command):
        ssh = paramiko.SSHClient()
        ssh._transport = self.__transport
        # 执行命令
        stdin, stdout, stderr = ssh.exec_command(command)
        # 获取命令结果
        result = stdout.read()
        return result
        


ha = SSHConnection()
ha.run()
demo

 

以上是关于自动化运维工具的主要内容,如果未能解决你的问题,请参考以下文章

实战小项目python开发自动化运维工具--批量操作主机

微信小程序代码片段

运维自动化工具 Ansible

批量同步代码:有3台服务器(A,B,C)做负载均衡,由于规模太小目前并未使用专业的自动化运维工具

自动化运维能否解决系统代码级问题?

自动化运维工具puppet详解