当前位置:首页 > 公众号精选 > 嵌入式微处理器
[导读]原创地址:https://www.cnblogs.com/zzzynx/p/11125892.html 原创作者:四次元猪肉 环境准备 一个脚本自动部署master服务 另一个部署slave服务 关闭主从节点的防火墙 以及事先设置好root远程登陆的权限。  grant all on *.* to root@'%' identified by 'root'

原创地址:https://www.cnblogs.com/zzzynx/p/11125892.html

原创作者:四次元猪肉


环境准备

一个脚本自动部署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


1.原因一:配置文件没有添加server_id=2,或者添加完没有成功重启。
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

-END-




推荐阅读



【01】我硬生生地把C代码塞进了Python和Ruby!
【02】自己「焊」键盘:使用Python编写
【03】C++ 转 Python 这三年,我都经历了什么?
【04】给大神鼓掌:400行Python代码实现文语处理助手!
【05】使用 Python 来开发 STM32F411 !



免责声明:整理文章为传播相关技术,版权归原作者所有,如有侵权,请联系删除

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

嵌入式ARM

扫描二维码,关注更多精彩内容

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
关闭
关闭