文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL5.5数据库的主从复制用法

2024-04-02 19:55

关注

这篇文章主要讲解了“MySQL5.5数据库的主从复制用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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数据库的主从复制用法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯