MySQL数据库自身提供的主从复制功能可以方便的实现数据的多处自动备份,实现数据库的拓展。多个数据备份不仅可以加强数据的安全性,通过实现读写分离还能进一步提升数据库的负载性能。

一、主从复制的原理
在一主多从的数据库体系中,多个从服务器采用异步的方式更新主数据库的变化,业务服务器在执行写或者相关修改数据库的操作是在主服务器上进行的,读操作则是在各从服务器上进行。如果配置了多个从服务器或者多个主服务器又涉及到相应的负载均衡问题。Mysql主从复制实现的原理:

Mysql之间数据复制是基于二进制日志文件的,相当于redis中的aof持久化。记录的是数据库的操作命令。一台Master数据库一旦启用二进制日志后,它自身数据库中的所有操作都会以‘事件’的方式记录在二进制事件中,其它数据库通过一个线程与主服务保持通信并监听,如果发现日志有变化则会把变化复制到自己的中继日志中。
二、主从复制的配置
主服务器:
- 开启二进制日志
- 配置唯一的sever-id
- 创建一个用于slave和master通信的用户账号
从服务器: - 配置唯一的server-id
- 使用master分配的用户账号读取master二进制日志
- 启动slave
1.主数据库的修改
- 开启二进制日志(my.cnf)
log-bin=mysql-bin #开启二进制日志
server-id=1 #设置server-id
- 创建用户并授权
mysql> CREATE USER 'repl'@'123.57.44.85' IDENTIFIED BY 'slavepass';#创建用户
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'123.57.44.85';#分配权限
mysql>flush privileges; #刷新权限
- 查看master状态
SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 | 73 | test | manual,mysql |
+------------------+----------+--------------+------------------+
2、从服务器的修改
- 修改mysql的配置
server-id=2 - 重启mysql执行同步语句
mysql> CHANGE MASTER TO
-> MASTER_HOST='182.92.172.80',
-> MASTER_USER='rep1',
-> MASTER_PASSWORD='slavepass',
-> MASTER_LOG_FILE='mysql-bin.000003',
-> MASTER_LOG_POS=73;
- 启动进程
mysql>start slave;
- 查看状态
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 182.92.172.80
Master_User: rep1
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000013
Read_Master_Log_Pos: 11662
Relay_Log_File: mysqld-relay-bin.000022
Relay_Log_Pos: 11765
Relay_Master_Log_File: mysql-bin.000013
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
网友评论