• 使用python脚本部署mariadb主从架构


    环境准备

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

     

  • 相关阅读:
    windows下mysql数据库导入导出
    比较两个数组,根据id删除相同的对象
    angular子组件给父组件传值
    angular父组件给子组件传值
    angular获取dom节点
    angular创建服务
    forEach和for包含异步调用的区别
    用某种符号或字符替换某些字符
    嵌套函数和闭包
    JavaScript 递归
  • 原文地址:https://www.cnblogs.com/zzzynx/p/11125892.html
Copyright © 2020-2023  润新知