zoukankan      html  css  js  c++  java
  • Python_oldboy_自动化运维之路_paramiko,mysql(十二)

    本节内容:

    1. paramiko
    2. mysql

    1.paramiko

    http://www.cnblogs.com/wupeiqi/articles/5095821.html

    paramiko是一个模块,socket和ssh协议,利用这个模块就可以用python代码实现远程服务器操作

    ansible底层就是用的这个模块

    功能:

      a.使用用户名密码:命令,文件

      b.使用用户名秘钥:命令,文件

      c.执行创建session(后面讲堡垒机项目)

    1.基于用户名密码连接:

    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('df')
    # 获取命令结果
    result = stdout.read()
      
    # 关闭连接
    ssh.close()
    paramiko
    b'anaconda-ks.cfg
    install.log
    install.log.syslog
    package
    xe5x85xacxe5x85xb1xe7x9ax84
    xe6xa8xa1xe6x9dxbf
    xe8xa7x86xe9xa2x91
    xe5x9bxbexe7x89x87
    xe6x96x87xe6xa1xa3
    xe4xb8x8bxe8xbdxbd
    xe9x9fxb3xe4xb9x90
    xe6xa1x8cxe9x9dxa2
    '
    输出

    假如利用普通用户登录

    # -*- coding: UTF-8 -*-
    #blog:http://www.cnblogs.com/linux-chenyang/
    import paramiko
    
    # 创建SSH对象
    ssh = paramiko.SSHClient()
    # 允许连接不在know_hosts文件中的主机
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    # 连接服务器
    ssh.connect(hostname='10.236.62.37', port=22, username='root', password='123456')
    
    # 执行命令
    stdin, stdout, stderr = ssh.exec_command('sudo ls')
    stdin.write('123456')
    stdin.flush()
    # 获取命令结果
    result = stdout.read()
    print(str(result))
    
    # 关闭连接
    ssh.close()
    paramiko
    import paramiko
    
    transport = paramiko.Transport(('hostname', 22))
    transport.connect(username='wupeiqi', password='123')
    
    ssh = paramiko.SSHClient()
    ssh._transport = transport
    
    stdin, stdout, stderr = ssh.exec_command('df')
    print stdout.read()
    
    transport.close()
    SSHClient 封装 Transport

    2.基于用户名秘钥连接

    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()
    paramiko
    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)
    
    ssh = paramiko.SSHClient()
    ssh._transport = transport
    
    stdin, stdout, stderr = ssh.exec_command('df')
    
    transport.close()
    SSHClient 封装 Transport

    3.基于私钥字符串的形式

    #3.基于私钥字符串的形式
    import paramiko
    
    from io import StringIO
    
    key_str = """
    zhe shi yi da dui zi fu chuan
    """
    
    #1.相当于生成一个文件先f=StringIO(key_str)
    #2.然后在读f.read()
    private_key = paramiko.RSAKey(file_obj=StringIO(key_str))
    
    # 创建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()
    paramiko

    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()
    # -*- coding: UTF-8 -*-
    #blog:http://www.cnblogs.com/linux-chenyang/
    #
    #
    #传统的方式就是我上传一个文件,先连接上,然后上传完在断开,执行一个命令,先连接上,在执行命令,然后断开
    #案例场景,创建一个连接,执行多条命令,执行多个上传,自己想关掉连接就关掉
    #通过paramiko可以封装成个模块,
    
    import paramiko
    
    class SshHelper(object):
    
        def __init__(self,host,port,username,pwd):
            self.host = host
            self.port = port
            self.username = username
            self.pwd = pwd
            self.transport = None
    
        def connect(self):
            transport = paramiko.Transport((self.host, self.port))
            transport.connect(username=self.username, password=self.pwd)
            self.transport = transport
    
        def upload(self,local,target):
            sftp = paramiko.SFTPClient.from_transport(self.transport)
            # 将location.py 上传至服务器 /tmp/test.py
            sftp.put(local, target)
            # 将remove_path 下载到本地 local_path
            #sftp.get('remove_path', 'local_path')
    
        def cmd(self,shell):
            ssh = paramiko.SSHClient()
            ssh._transport = self.transport
            stdin, stdout, stderr = ssh.exec_command(shell)
            print(stdout.read())
    
        def close(self):
            self.transport.close()
    
    if __name__ == '__main__':
        obj = SshHelper('..........')
        obj.connect()
    
        #中间可以想执行多少次命令就执行多少次
    
        obj.close()
    自定义paramiko模块

    2.mysql

           - 什么是MySQL
                服务端:
                    a.socket服务端运行,监听:IP和端口
                    b.获取客户端发送的数据: asdfasdfasdfasdfasdfasdf
                    c.解析
                    d.去文件中做操作
                客户端:
                    a.socket客户端:基于各种语言的客户端
                    b.验证
                    c.发送命令(学习规则SQL语句)

  • 相关阅读:
    WPF
    Xamarin.Forms + Prism,整理页面导航跳转流程
    Xamarin.Forms踩坑整理
    整理
    WPF
    LINQ中,Single()、SingleOrDefault()的解析、示例
    InstallShield打包
    Centos7安装jexus,部署asp.net core,asp.net mvc
    c#修改webConfig的内容
    .net core 3.1简单swagger配置教程
  • 原文地址:https://www.cnblogs.com/linux-chenyang/p/6628428.html
Copyright © 2011-2022 走看看