最近想对公司的数据库做个从数据库,除了每天定时备份外,再多出一个同步数据库,双保险,这样也可以用从数据库就行比较耗资源的数据统计。

  技术手段最好能记住,然后就是做笔记了,但是每次都查笔记也不好,希望能记住,这样知识才会变成自己的,这里总结了一下记忆点。

  1,要在主,从服务器上改mysql的数据库配置(确定身份,这个好记)

    a.改主服务器mysql配置,vim /etc/my.conf

      

      log-bin=mysql-bin #要启用二进制日志
      server-id = 1
      binlog-do-db = lk_homepage #确定要操作的数据库

      

    改完要重启mysql,如果mysql重启失败,说明配置有问题

    进入mysql控制台,show master status\G,可以看到对应的状态,要记住是通过哪个二进制日志进行同步,以及位置

      File: mysql-bin.000035
      Position: 2093322
      Binlog_Do_DB: lk_homepage

        b.改从服务器mysql配置,vim /etc/my.conf

      log-bin=mysql-bin #要启用二进制日志
      server-id = 2 #这个千万要和主的 server-id不一样才行
    重启mysql

  2,在主服务器mysql里赋权限给从

    GRANT REPLICATION SLAVE ON *.* TO '用户名' @'对方主机ip' IDENTIFIED BY '密码'

    给slave一个操作权限,所谓同步,其实就是和认定的主机进行数据交互,当然要赋予目标权限。

  

3,接下来就是 从服务器的更改了,进入从服务器mysql控制台运行

    change master to master_host='192.168.xxx.xxx',master_user='xxx',master_password='xxx',
         master_log_file='mysql-bin.000004',master_log_pos=308;

    其中这些参数应该和主服务器上的对应的设置匹配上才行。

    然后要 start slave,  如果前面已经运行了slave,要先 stop slave 一下。

       >>show slave status\G

    可以看到slave转台,以下两行都为Yes才表示处于可同步状态,如果同步过程出了sql错误,清理掉sql出错后,重新同步,此时需要在前面的master_log_pos里修改为新的位置,再从新启动slave,然后看下两个是否变成了Yes

     Slave_IO_Running: Yes    //此状态必须YES
            Slave_SQL_Running: Yes     //此状态必须YES

    

  从以上可以看出,从服务器会去主服务器找对应的日志,从日志里找到要做的更改,然后同步到从服务器,从服务器再进行对应的sql操作,为此上网验证了下,大致是这样的原理

图片来自互联网

最新文章

  1. LINUX 忘记root密码如何修改
  2. 【BZOJ】3916: [Baltic2014]friends
  3. hdu 1047 (big integer sum, fgets or scanf, make you func return useful infos) 分类: hdoj 2015-06-18 08:21 39人阅读 评论(0) 收藏
  4. RHCS集群理论暨最佳实践
  5. PHP与MySQL交互
  6. JS 节流阀
  7. CALayer --> UIView
  8. 最常见的三个排序(冒泡、直接插入、快速)的JS实现
  9. Vux配置指南
  10. C语言--第0周作业
  11. 解决Fragment中使用地图,切换会闪一下黑屏的问题
  12. Storm——Android SQLite数据库管理类库
  13. .net core使用配置文件
  14. operator笔记
  15. PHP——大话PHP设计模式——PSR-0规范
  16. C/S架构系统自动化测试入门
  17. weblogic 12C 安全加强:更改Console及管理端口
  18. JS正则判断输入框是否仅仅含有汉字、字母和数字
  19. C#取得页面URL信息
  20. PPTP

热门文章

  1. socket 进程通讯理解
  2. Aira搭建
  3. Linux环境相关
  4. 【安装】Mac rabbitMQ
  5. Delphi GDI对象之脱屏位图(Offscreen Bitmaps)
  6. NX二次开发-UF_MODL_intersect_objects获取两个对象的交点
  7. [JZOJ 5817] 抄代码
  8. faster-rcnn代码阅读-rpn-data层
  9. Spring随笔-核心知识DI与AOP
  10. android:两个应用之间怎样传值之activity