MySQL基于binlog主从复制配置

本文详细介绍了如何在两台RHEL服务器上配置MySQL 5.5版本的主从复制环境,包括修改配置文件、创建复制用户、同步数据库等关键步骤。

Master-Slave 搭建环境:
Master:
Os: rhel-server-6.3-x86_64
Mysql: MySQL -5.5.35-1
虚拟机:Virtual BOX
Ip:192.168.56.102

Slave:
Os: rhel-server-6.3-x86_64
Mysql: MySQL -5.5.35-1
虚拟机:Virtual BOX
Ip:192.168.56.103

总体步骤:
1、 修改Master配置文件(my.cnf)
2、 在Master上创建一个有复制权限的用户
3、 复制Master上的数据库到Slave
4、 修改Slave配置文件(my.cnf)
5、 Slave初始化复制
6、 测试
7、 常见问题

1、 修改Master配置文件(my.cnf)

[mysqld]
server-id=1  //必须是服务器唯一id,默认是0,  
log-bin=mysql-bin //必须启用二进制日志
replicate-do-db=dba


[mysqld]

server-id=1

log-bin=/var/lib/mysql/master-bin

#log-bin-index=/var/lib/mysql/master-bin.index

replicate-do-db=abc

2、 在Master上创建一个有复制权限的用户

mysql>create user abc;
mysql>grant replication slave on *.* to abc identified by ‘abc';

3、 复制Master上的数据库到Slave

mysql>flush tables with read lock;
mysql> show master status
    -> ;
+-----------------+----------+--------------+------------------+
| File            | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-----------------+----------+--------------+------------------+
| ogg1-bin.000003 |      107 |              |                  |
+-----------------+----------+--------------+------------------+1 row in set (0.00 sec)
mysql>quit
[root@ogg /]# /usr/bin/mysqldump abc -uroot -proot --opt | mysql abc -uroot -proot -h 192.168.56.103

MySQL 5.6 不允许使用明密码文件远程

[root@guo ~]# /usr/bin/mysqldump abc -uroot -p --opt | mysql abc -uroot -p -h 192.168.56.103

489487.png


需要在slave中授权:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.56.103' IDENTIFIED BY 'root' WITH GRANT OPTION;

mysql>unlock tables;

4、修改Slave配置文件(my.cnf)

[mysqld]
server-id=2  //必须是服务器唯一id,默认是0,  
log-bin=mysql-bin //必须启用二进制日志
replicate-do-db=zbdba


[mysqld]

server-id=11

relay-log=/var/lib/mysql/slave-relay-bin

#relay-log-index=/var/lib/mysql/slave-relay-bin.index

#port=3316

#datadir=/var/lib/mysql/data

replicate-do-db=abc


5、 Slave初始化复制

mysql>slave stop;
mysql>CHANGE MASTER TO MASTER_HOST='192.168.56.12',
MASTER_USER='zbdba',MASTER_PASSWORD='123456',MASTER_LOG_FILE='ogg1-bin.000003',MASTER_LOG_POS=107;

CHANGE MASTER TO MASTER_HOST='192.168.56.102',

MASTER_PORT=3306,MASTER_USER='abc',

MASTER_PASSWORD='abc';

mysql> show slave status\G;
*************************** 1. row ***************************
              Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.56.12
                  Master_User: zbdba
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: ogg1-bin.000003
          Read_Master_Log_Pos: 107
              Relay_Log_File: ogg2-relay-bin.000002
                Relay_Log_Pos: 252
        Relay_Master_Log_File: ogg1-bin.000003
            Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: abc

138216.png

6、 测试

master:

mysql> show tables;
+-----------------+
| Tables_in_zbdba |
+-----------------+
| guestbook      |
| test            |
| test1          |
+-----------------+

create table test2 select * from test1;

mysql> show tables;
+-----------------+
| Tables_in_zbdba |
+-----------------+
| guestbook      |
| test            |
| test1          |
| test2          |
+-----------------+

salve:

mysql> show tables;
+-----------------+
| Tables_in_zbdba |
+-----------------+
| guestbook      |
| test            |
| test1          |
| test2          |
+-----------------+
4 rows in set (0.00 sec)

如果需要配置相互主从的关系,只需要在slave数据库上面建立对应用户,原master上面做一下初始化就行了。

7、 常见问题
/etc下面没有对应的my.cnf文件
解决方法:
如果mysql使用rpm包安装的,/etc下没有对应的my.cnf文件,这时候只需要复制一个/usr/share/mysql目录下的.cnf文件到/etc目录,并改名为my.cnf即可。

Server-id参数无法修改
解决方法:
看my.cnf中是否存在相同的server-id=1

MySQL主备出现这个错误: ERROR 1201 (HY000):
解决方法:
mysql> slave stop;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> reset slave;

Query OK, 0 rows affected,(0.00 sec)

ERROR 1130 (HY000): Host '*.*.*.*' is not allowed to connect to this MySQL server
解决方法:
如果你想允许用户myuser从ip为192.168.1.103的主机连接到mysql服务器,并使用mypassword作为密码
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.103' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24742969/viewspace-1797042/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24742969/viewspace-1797042/

MySQL主从复制是一种通过binlog(二进制日志)进行操作的复制机制,其具体原理如下: ### binlog 概述 binlog 即二进制日志,即使没有主从复制MySQL 也会写 binlog主从复制正是通过 binlog 来实现的,它记录了对数据库执行更改的所有操作,这些操作可以用于数据恢复和主从复制等功能[^2]。 ### 主从复制过程 主从复制涉及一个主数据库和一个或多个从数据库,主数据库将信息通过 binlog 复制到从数据库中。在并发压力大时,可在主数据库进行增删改操作,在从数据库进行查操作,以此降低主数据库的压力。若主数据库崩溃,可将从数据库顶上继续提供服务。在主数据库备份期间,为保证数据一致性会加全局锁,此时可访问从数据库以保证数据库正常操作[^3]。 ### binlog 模式 主从同步事件 binlog 模式有 3 种形式: - **statement**:会将对数据库操作的 SQL 语句写入到 binlog 中。 - **row**:会将每一条数据的变化写入到 binlog 中。 - **mixed**:是 statement 与 row 的混合模式,MySQL 会根据情况决定何时写 statement 格式、何时写 row 格式的 binlog[^4]。 ### 读写分离与主从复制 读写分离基于主从复制实现。在实际应用环境中,读操作通常远多于写操作。基于主从复制的读写分离配置,让主库专门进行数据修改(写操作),主库通过主从复制将数据更改通过 binlog 同步到从库,客户端的查询请求则映射到从库。一个主库可搭配两三个从库,这样能很好地分摊读写压力,提高后端服务的并发处理能力,同时具备高可用容灾能力,当主库挂掉后,可将指定从库变成主库[^2]。 ### 代码示例 以下是一个简单的 Python 代码示例,用于连接 MySQL 数据库并执行基本的增删改查操作,这与主从复制中的读写操作相关: ```python import mysql.connector # 连接到主数据库 mydb = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="yourdatabase" ) mycursor = mydb.cursor() # 插入数据(写操作,一般在主库执行) sql = "INSERT INTO customers (name, address) VALUES (%s, %s)" val = ("John", "Highway 21") mycursor.execute(sql, val) mydb.commit() print(mycursor.rowcount, "record inserted.") # 从从数据库查询数据(读操作,一般在从库执行) # 这里简单假设从库配置类似,实际中需要根据从库地址等信息修改连接参数 mydb_slave = mysql.connector.connect( host="localhost", user="yourusername", password="yourpassword", database="yourdatabase" ) mycursor_slave = mydb_slave.cursor() mycursor_slave.execute("SELECT * FROM customers") myresult = mycursor_slave.fetchall() for x in myresult: print(x) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值