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语句)

原文地址:https://www.cnblogs.com/linux-chenyang/p/6628428.html