mysql实现主从复制

1、两台服务器安装同一版本mysql,centos7 yum安装方法上篇文章有。

2、主数据库配置

a、在/etc/my.cnf 中配置:

[mysqld]

               server-id=1 (服务器id-唯一)

log-bin=mysql-bin (启用二进制日志

b、增加用户,给从数据库(slave)权限用

mysql>grant replication slave on *.* to 'name'@'host' identified by 'password';

注意:name:用户名(登录名)如: deng,password:密码 如:123456, host:从服务器ip,如,115.128.134.02

让权限生效

mysql>flush privileges;

执行以下语句查看权限列表,确认权限添加成功:

SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

c、查询主服务器二进制文件的文件名和状态

mysql>show master status

记录其中的File、Position、后面需要使用

File:mysql-bin.000001

       Position:104

File: mysql-bin.000001 (二进制文件名)

Position:104. 表示当前的文件偏移量, 就是写入在mysql-bin.000001文件的记录位置

3、从数据库配置

a、同样在/etc/my.cnf 中配置:

[mysqld]

               server-id=2 (服务器id-唯一)

b、配置从服务器

mysql>change master to master_host='115.128.134.01',

master_user='deng',

                               master_password='123456',

master_log_file='mysql-bin.000001',

                               master_log_pos=104;

注:master_host:主服务器ip

master_user:刚才主服务器创建权限用户名

master_password:刚才主服务器创建权限密码

master_log_file:主服务器二进制文件的文件名

master_log_pos:主服务器状态

启动从数据库复制功能:

mysql>start slave;

查看从服务器复制状态:

·mysql>show slave status \G

注意查看:

Slave_IO_Running: Yes    //此状态必须YES

  Slave_SQL_Running: Yes     //此状态必须YES

如果都为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;

            查询用户的访问

                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;

            然后打包数据目录并拷贝到从机上,然后解锁。




下一篇我将实现读写分离。

阅读更多
个人分类: liunx学习
上一篇centos7下快速安装mysql-yum安装
下一篇mysql 每日备份
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭