MySQL主从复制原理:


master(主服务器),slave(从服务器)

  1. MySQL master 将数据变更写入二进制日志( binary log, 其中记录叫做二进制日志事binary log events,可以通过 show binlog events 进行查看)
  2. MySQL slave 将 master 的 binary log events 拷贝到它的中继日志(relay log)
  3. MySQL slave 重放 relay log 中事件,将数据变更反映它自己的数据

1.MySQL下载安装

2.本地搭建主从复制

  • 首先需要在本地安装至少两个MySQL服务器,为了避免端口冲突,可以把mysql的服务器的端口设置不同,这里我设置一个为3306,另一个服务器的端口号为3307,端口号在mysql的配置文件my.ini中配置。
  • 主服务器配置

    [mysqld]
    port=3306
    basedir="D:/master/MySQL/"
    datadir="D:/master/MySQL/data/"
    character-set-server=utf8
    server_id=1
    log-bin=mysql-bin#要生成的二进制日记文件名称
    binlog-do-db=test#同步的数据库
    binlog-ignore-db=mysql#不参与同步的数据库 ,例如mysql

  • 从服务器配置

    [mysqld]
    port=3307
    basedir=D:\slave\mysql2
    datadir=D:\slave\mysql2\data
    server-id=2 
    log-bin=mysql-bin#开启了二进制文件
    binlog_do_db=follow#主从复制的数据库
    binlog_ignore_db=mysql#不参与主从复制的数据库,例如mysql

  • 接下来在主服务器登录mysql,创建用于主从复制的用户并授权
    create user 'xiao'@'127.0.0.1' identified by 'password';
    grant replication slave on . to xiao@'127.0.0.1';

  • 在从服务器上用创建的用户登录主服务器,看能不能成功,成功继续下面的步骤

  • 在主服务器上执行命令:
    show master status;(此命令查看主服务器的bin-log日志文件名称和position点)

mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | mysql |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

  • 在从服务器上执行以下命令:

在从库设置它的master:

mysql> change master to

master_host='127.0.0.1',master_port=3306,master_user='xiao',master_password='password',master_log_file='mysql-bin.000001',master_log_pos=107;

Query OK, 0 rows affected (0.19 sec)

这里的master_log_file和master_log_pos对应刚才show master status记下的参数。

  • 在从库开启从数据库复制功能。

mysql>start slave;

Query OK, 0 rows affected (0.00 sec)

  • 在从库可以通过show slave status\G来查看一些参数。

当Slave_IO_Running和Slave_SQL_Running线程都为yes是主从复制配置成功!

  • 此时在主库创建表或插入数据,在从库就会很快也能看到了。

-- 主库

mysql> create table tianyc_02(b int);

Query OK, 0 rows affected (0.16 sec)

mysql> insert into tianyc_02 values(2013);

Query OK, 1 row affected (0.13 sec)

-- 从库

mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| tianyc_01 |
| tianyc_02 |
+----------------+
2 rows in set (0.00 sec)

mysql> select * from tianyc_02;
+------+
| b |
+------+
| 2013 |
+------+
1 row in set (0.00 sec)

同理,可以搭建第二、第三个从节点。

备注:两个服务的serve_id必须不同,否则在开启复制功能时会提示错误

mysql> slave start;

ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO

我这里设置的主节点id为1,从节点id为2。也可以按照ip或端口进行设置,好用来区分。
注意: 主从同步,只是在建立同步后,之后主的修改会同步到从上。 但主上以前有的数据库内容需要在建立同步前先导出并导入到从上,否则由于主从原始数据不一致,当主上进行删除新增的操作,在从上因为没有对应数据库,会报错,导致同步中断,失去同步效果了。

最新文章

  1. Html 基础介绍 基础标签
  2. [译]SQL Server分析服务的权限配置
  3. 基于MVC4+EasyUI的Web开发框架形成之旅--框架总体界面介绍
  4. ABA problem
  5. css案例学习之id要唯一
  6. Android应用开发基础篇(10)-----Menu(菜单)
  7. Delphi透明组件开发(去掉自己的csOpaque,去掉父控件的WS_CLIPCHILDREN,增加WS_EX_TRANSPARENT,截获WM_ERASEBKGND,然后在WM_DRAWITEM里画) good
  8. 我的 MarkDown 学习笔记
  9. Last-Modified和ETag以及Apache和Nginx中的配置
  10. windows下vue.js开发环境搭建教程
  11. 使用GDAL将下载的Google卫星图像转为带坐标的tif
  12. 【题解】P2922 [USACO08DEC]秘密消息Secret Message
  13. 快速排序 and 拉格朗日插值查找
  14. iOS 出现内存泄漏的几种原因
  15. windows对象 document对象 的一些操作 9.23
  16. Flightphp了解一下
  17. 微信小程序 --- 设置页面的标题
  18. HUD 2544 最短路 迪杰斯特拉算法
  19. 找出数组中的最小值(es5/es6)
  20. VisualSVN的安装使用

热门文章

  1. dozer工具类
  2. mybatis 一对多,多对一配置
  3. 电脑磁盘分区助手:DiskGenius磁盘管理与数据恢复软件
  4. easyui-numberspinner实现双箭头效果
  5. 第一章:mysql的介绍与安装
  6. NOIp 2009:靶形数独
  7. Java面试 - final、finally、finalize的区别?
  8. 部署Harbor私有镜像仓库
  9. [转帖]Apache、Tomcat与Catalina作为软件名字的含义与关系
  10. docker容器端口号、时区修改