使用python3脚本部署mariadb主从架构

环境准备

一个脚本自动部署master服务

另一个部署slave服务

关闭主从节点的防火墙

以及事先设置好root远程登陆的权限。

master

import paramikossh=paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())ssh.connect(hostname=‘192.168.253.180‘,port=22,username=‘root‘,password=‘369369yn‘)for i in ["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" ‘‘‘]:    print(i)

stdin,stderr,stdout=ssh.exec_command(i)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.cnfsystemctl restart mariadbmysql -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_DBmysql_bin.000012   887359  



在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=887350import paramikossh=paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())ssh.connect(hostname=‘192.168.253.30‘,port=22,username=‘root‘,password=‘369369ynx‘)for i in ["sed -i ‘12aserver_id=2‘  /etc/my.cnf.d/server.cnf",‘systemctl restart mariadb‘ , ‘‘‘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) , "mysql -uroot -p1 -e ‘start slave‘"]:    print(i)stdin,stderr,stdout=ssh.exec_command(i)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

原文地址:https://www.cnblogs.com/daisyyang/p/11137438.html

时间: 2024-10-08 01:30:53

使用python3脚本部署mariadb主从架构的相关文章

python部署mariadb主从架构

主机部署: import configparser import os def config_mariadb_yum(): exists = os.path.exists('/etc/yum.repos.d/mariadb.repo') if exists: print('mariadb.repo文件已经存在') yum_install_mariadb() else: config = configparser.ConfigParser() config.read('/etc/yum.repos

实战部署openldap主从架构

一.openldap介绍 二.openldap特点 三.openldap相关缩写 四.openldap组件 五.openldap环境规划 六.openldap部署---Master端 七.openldap部署---Slave端 八.openldap使用LAM工具管理 九.Master-Slave测试是否同步 一.openldap介绍: LDAP是轻量目录访问协议(Lightweight Directory Access Protocol)的缩写. LDAP标准实际上是在X.500标准基础上产生的

Linux7/Centos7 Mariadb主从配置过程

环境:RedHat7 同样适用于Centos7(本文是在无网络环境部署mariadb主从) 卸载Mysql (防止mysql和mariadb冲突 ) 停止服务:systemctl stop mysqld 查询安装包:rpm -qa | grep mysql 卸载: rpm -e mysql-server rpm -e --nodeps mysql-libs 准备环境查看磁盘挂载情况:df –h < 如果没有则挂载系统盘:mount/dev/cdrom /media > PS: 在虚拟机设置里对

mariadb主从部署

MariaDB主从服务器优点简介 辅组实现备份Replication 高可用:在主服务器出现异常情况,修改指定配置可以直接顶替主服务器. 异地容灾 Scale out:分摊负载(是否启用!) 一.部署文档 1.确保在主服务器和从服务器上安装的MariaDB版本一致. 2.在主服务器上为从服务器设置一个连接账户 MariaDB [(none)]> GRANT REPLICATION SLAVE, SUPER, RELOAD ON *.* TO ''@'' IDENTIFIED BY '. 主服务器

一分钟教你快速建立起MySQL/Mariadb 主从状态检测脚本(shell)

脚本主要实现了网络检测和简单的主从状态检测,发现状态异常即发送邮件报警,在手机上安装一个易信可实现实时联动,及时获取服务器状态信息,脚本虽简单却实用. #!/bin/bash ##author:jerry_jiang mail_addr="[email protected]"br/>mail_addr2="[email protected]"ping 192.168.33.19 -c1 >/dev/nullsping1=echo $?ping 192.1

基于LNAMP环境搭建discuz论坛并部署mysql主从

这几天看见个题目:有两台服务器,其中一台部署apache+php+nginx+discuz,另外一台单独跑mysql数据库,其中nginx监听80端口,负责跑静态网页,apache监听88端口,负责跑动态网页(php相关)并且由nginx代理.最后在A设备上安装一个mysql数据库与B设备上的数据库构成mysql主从架构. 实验环境: 1.VMware Workstation 10 2.真机IP:192.168.0.113 2.设备A:nginx+apache+php+discuz+mysql,

mysql/mariadb主从复制架构配置及过程中出现的问题

两台CentOS7系虚拟主机:分别是:主服务器172.16.75.1,从服务器172.16.75.2使用的是mariadb-5.5.56,即centOS自带的软件版本为了使实验结果显示精准,此处关闭两台服务器的防火墙和SELinux:[[email protected] ~]# setenforce 0[[email protected] ~]# iptables -F 一.首先在主服务器172.16.75.1上配置:在/etc/my.cnf中配置如下:[mysqld]###定义二进制日志的存放

使用python搭建Linux-mariadb主从架构

环境准备两台: 192.168.193.90 master 192.168.193.91 slave 需要Linux装python环境: https://www.cnblogs.com/kingzhe/p/11124527.html 在做主从时,要保证两个数据库的信息一致 [[email protected] ~]# mysql_secure_installation [[email protected] ~]# mysql_secure_installation master import c

mysql-poxy 实现mysql主从架构读写分离

在高并发系统设计中,后端数据库的性能往往会成为系统的瓶颈,这时候就需要进行合理的设计,以分摊后端数据库的压力,比如在数据层前面构建缓存层.数据文件存放在RAID这样的设备.对数据进行分库分表分区存放.合理利用索引.进行数据的读写分离等.mysql-proxy提供了mysql数据库的读写分离能力,mysql-proxy通过Lua脚本能分析得出用户的sql请求,如果发现在是read请求,则会转化到master-slave模型的slave中,如果是write请求,则会转发到master中,以达到读写分