python mysql连接池 知乎_使用python脚本部署mariadb主从架构

本文介绍了如何使用Python脚本自动化部署MariaDB的主从架构,包括环境准备、主节点和从节点的配置,以及解决可能出现的问题。通过paramiko模块执行SSH命令和SQL操作,实现远程配置及状态检查。
摘要由CSDN通过智能技术生成

环境准备

一个脚本自动部署master服务 另一个部署slave服务 关闭主从节点的防火墙 以及事先设置好root远程登陆的权限。 grant all on *.* to root@'%' identified by 'root' ;

master

import paramiko

ssh=paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname='192.168.253.168',port=22,username='root',password='root')

a="sed -i -e '12aserver_id=1' -e '13alog_bin=mysql_bin' /etc/my.cnf.d/server.cnf"

b= 'systemctl restart mariadb'

c='''mysql -uroot -proot -e "grant replication slave on *.* to 'slave'@'%' identified by 'slave'"'''

d='''mysql -uroot -proot -e "show master status" '''

当然也可以将abcd四条命令写入一个列表,使用for语句循环出来放入下面命令执行。

stdin,stderr,stdout=ssh.exec_command(d)    #将abcd分别执行

res = stdout.read().decode('utf-8') + stderr.read().decode('utf-8')

print(res)

运行显示结果:

sed -i -e '12aserver_id=1' -e '13alog_bin=mysql_bin' /etc/my.cnf.d/server.cnf

systemctl restart mariadb

mysql -uroot -p1 -e "grant replication slave on *.* to 'slave'@'%' identified by 'slave'"

mysql -uroot -p1 -e "show master status"

File Position Binlog_Do_DB Binlog_Ignore_DB

mysql_bin.000012 887350

在linux端查看是否配置成功。

注:mysql -uroot -p1 -e   此命令可以使用paramiko模块直接执行sql语句。e是edit的意思。

当然,也可以使用pymsql模块连接mysql数据库然后利用cur游标里封装的execute方法来执行sql语句,但是可能在执行给与权限的命令时会报错,因为远程登陆并没有权限这么做。

slave

如下的file变量和port变量在master节点会变动,特别时重启数据库后。 如果查看slave status,显示: Slave_IO_Running: No Slave_SQL_Running: No 或者一个YES一个connecting的话,这是因为主节点的master状态发生了变化或者两台主机的某一台防火墙没有关闭。

master_ip = '192.168.253.168'

log_file='mysql_bin.000012'

pos=887350

import paramiko

ssh=paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

ssh.connect(hostname='192.168.253.167',port=22,username='root',password='root')

a="sed -i '12aserver_id=2' /etc/my.cnf.d/server.cnf"

b='systemctl restart mariadb'

c='''mysql -uroot -proot -e "CHANGE MASTER TO MASTER_HOST='%s', MASTER_USER='slave', MASTER_PASSWORD='slave', MASTER_LOG_FILE='%s', MASTER_LOG_POS=%s" ''' % (master_ip,log_file,pos)

d="mysql -uroot -proot -e 'start slave'"

stdin,stderr,stdout=ssh.exec_command(d)        #将abcd分别执行

res = stdout.read().decode('utf-8') + stderr.read().decode('utf-8')

print(res)

如果报错:The server is not configured as slave; fix in config file or with CHANGE MASTER TO

原因一:配置文件没有添加server_id=2,或者添加完没有成功重启。

原因二:mysql -uroot -p1 -e "CHANGE MASTER TO MASTER_HOST='%s', MASTER_USER='slave', MASTER_PASSWORD='slave', MASTER_LOG_FILE='%s', MASTER_LOG_POS=%s" ''' % (master_ip,log_file,pos)

这条命令没有执行成功,但注意这条命令不成功不会报错,怎么检测呢,可以粘贴脚本的这条命令到终端上执行试试看能否成功。

结果显示:

检测: 在主节点创建一个数据库,并在从节点数据库中查看是否同步上。

Master

slave

666!阿里巴巴内部P8技术专家面试题汇总已备好,看看你会几道吧!!​​mp.weixin.qq.com

原创作者:四次元猪肉佬

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值