MySQL主从复制配置的解决办法
这篇文章主要为大家详细介绍了MySQL主从复制配置的简单示例,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随数据库教程的小编来看看吧!
主库配置
1. 配置mysql
代码如下:
vim /etc/my.cn
# 在文件中增加以下内容
server-id=1 # 保证server id唯一
log-bin = /var/lib/mysql/mysql-bin.log
binlog-do-db = db1
binlog-do-db = db2
MySQL主从复制配置过程
其中db1和db2是计划进行主从复制的库,如果有多个,写多行即可。配置完毕后,重启数据库: service mysqld restart
2. 添加复制用户
通过phpmyadmin,添加新用户,并授予REPLICATION SLAVE权限。或者通过root用户登录到mysql,赋予权限:
代码如下:
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'password'
MySQL主从复制配置过程
其中repl是用户名,password是该用户的密码。
3. dump数据
如果能够保证不会产生新数据,就不需要对数据库加锁。如果不能保证,则需要对每一个dump数据的数据库加锁:
代码如下:
use db1;
FLUSH TABLES WITH READ LOCK;
MySQL主从复制配置过程
然后dump数据:
代码如下:
mysqldump -uroot -p db1 > db1.sql
MySQL主从复制配置过程
如果有多个数据库,则重复上述过程多次。
4. 查看二进制文件位置
使用root身份登录mysql,查看master状态:
代码如下:
show master status;
MySQL主从复制配置过程
该命令会有类似如下格式的输出:
代码如下:
+-----------------+-----------+----------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-----------------+-----------+----------------+------------------+
| mysql-bin.00002 | 445 | db1,db2 | |
+-----------------+-----------+----------------+------------------+
1 row in set (0.00 sec)
MySQL主从复制配置过程
5. 解锁
如果导出数居前对数据库加了读锁,则需要解除:
代码如下:
use db1;
UNLOCK TABLES;
MySQL主从复制配置过程
到此,主库配置完毕。特别需要记住 show master status
输出中的 file 和 position 的值。
从库配置
1. 新建数据库
首先在从库上建立相同名称的数据库。
2. 配置从数据库
代码如下:
vim /etc/my.cnf
# 在my.cnf中增加以下内容:
server-id = 2 # 保证id唯一
relay-log = /var/lib/mysql/mysql-relay-bin.log
replicate-wild-do-table = db1.%
replicate-wild-do-table = db2.%
MySQL主从复制配置过程
如果同步多个数据库,replicate-wild-do-table需要写多行。配置好后,重启数据库。
3. 导入数据
将主服务器上dump出来的数据导入从服务器中:
代码如下:
mysql -uroot -p db1 < db1.sql
MySQL主从复制配置过程
4. 配置主从同步
登录到mysql服务器,配置同步的主服务器信息:
代码如下:
> change master to master_host='xxx.xxx.xx.xx',
> master_user='repl',
> master_password='password',
> master_log_file='mysql-bin.00000x',
> master_log_pos=xxxx;
MySQL主从复制配置过程
配置好后启动主从同步: start slave
。然后通过命令查看状态:show slave status
,如果成功的话slave_io_running和slave_sql_running两项应该都是yes.
测试
在主库上新增记录或者添加表等操作,几乎都能实时反映到从库上。
以上就是mysql主从复制配置过程的详细内容,更多关于mysql主从复制配置的资料请关注512笔记其它相关文章!
注:关于MySQL主从复制配置的简单示例的内容就先介绍到这里,更多相关文章的可以留意