共计 2494 个字符,预计需要花费 7 分钟才能阅读完成。
这篇文章主要讲解了“MySQL5.5 数据库的主从复制用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“MySQL5.5 数据库的主从复制用法”吧!
MySQL 5.5 的主从复制
今天参照网上的资料进行数据库的主从复制研究,本来网上的资料已经很详细,但是我在实践中还是遇到了很多问题,下面就根据网上的资料以及我遇到的问题进行一个总结。
系统环境:Ubuntu12.04
软件版本:mysql-server-5.5
主机 IP:192.168.0.200
从机 IP:192.168.0.201
操作:
1、主机操作:
1)、编辑 mysql 配置文件 my.cnf
[mysqld]
server-id=1
log-bin=mysql-bin
注:网上还有一些其他的配置,但是为了偷懒只配置了这两个重要的,当然这两个也是必须的。
2)、用 root 登陆 mysql 执行下面的代码
// 建立一个用户 dean 密码 123456,并赋予 replication slave 权限:
mysql grant replication slave on *.* to dean @ 192.189.0.201 identified by 123456; www.2cto.com
// 让权限立即生效
mysql flush privileges;
// 查询二进制文件的文件名和状态(后面要用)
mysql show master status \G
File:mysql-bin.000006
Position:107
Binlog_Do_DB:
Binlog_Ignore_DB:
2、从机操作:
1)、编辑 myslq 配置文件 my.cnf:
[mysqld]
server-id=2 // 只要和主机不同即可
2)、登陆 mysql,输入以下命令:
a)、mysql change master to master_host= 192.168.0.200 ,master_user= dean , \
master_password= 123456 ,master_log_file= mysql-bin.000006 ,
master_log_pos=107;
b)、mysql start slave;
c)、mysql show slave status \G
如果出现:Slave_IO_Running:Yes
Slave_SQL_Running:Yes
那么说明没有问题了,就可以在主机上面建库建表写测试数据,然后在从机上查询看有没有数据。一般是没有问题了。
但是如果是出现:
Slave_IO_Running:Connecting
Slave_SQL_Running:Yes
那么就表示主从服务有问题了,我也就是遇到这个问题下面是我的解决方案:
1)、在从机上直接远程登陆主机 mysql 服务器:
#mysql -udean -h 192.168.0.200 -p123456
如果被拒绝那么就需要检查主机的用户 dean 的权限、防火墙等设置是否正确。(我的被拒绝了)
2)、检查权限。
用 root 登入 mysql 并选择 mysql 库
mysql use mysql;
查询用户的访问 www.2cto.com
mysql select host,user from user;
从查询数据看没有问题,有 dean 用户 接受 192.168.0.201 的访问
3)、防火墙设置
将端口为 3306 的访问设为允许
#sudo ufw allow 3306
将 ip 为 192.168.0 .201 的访问设为允许
#sudo ufw allow 192.168.0.201
查看状态
# sudo ufw status
设置完后还是从机还是不能直接远程访问主机
4)、查看端口监听
#netstat -anpy|grep 3306
发现当前的端口 3306 只在 127.0.0.1 监听,找到问题所在。修改 mysql 配置文件 my.cnf 将里面的 bind-address=127.0.0.1 注释调,重新察看端口监听发现监听是 0.0.0.0:3306,好了测试一下果真可以进行远程访问。
重新进行主机从机的操作,但是发现在从机中不能进行第 2 步 a 操作,执行下面命令
mysql stop slave;// 关闭 slave
mysql reset slave;// 重置 slave
继续执行 a 操作并往下继续操作。
最终完成了 Mysql 数据库的主从复制。
另:根据网上资料显示,如果主机在搭建主从复制前已经有数据需要先在主机上加锁:
mysql flush tables with read lock;
然后打包数据目录并拷贝到从机上,然后解锁。
感谢各位的阅读,以上就是“MySQL5.5 数据库的主从复制用法”的内容了,经过本文的学习后,相信大家对 MySQL5.5 数据库的主从复制用法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!