MySQL主从复制以及在本地环境搭建
mysql主从复制原理:
master(主服务器),slave(从服务器)
- mysql master 将数据变更写入二进制日志( binary log, 其中记录叫做二进制日志事binary log events,可以通过 show binlog events 进行查看)
- mysql slave 将 master 的 binary log events 拷贝到它的中继日志(relay log)
- mysql slave 重放 relay log 中事件,将数据变更反映它自己的数据
1.mysql下载安装
- mysql官方下载地址:,选择自己需要的版本以及对应的平台。这里本人选择最新版本8.0.17,下载免安装的zip包。
- 具体安装步骤参照:
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或端口进行设置,好用来区分。
推荐阅读
-
MySQL主从复制以及在本地环境搭建
-
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程,_PHP教程
-
在Mac OS上搭建Nginx+PHP+MySQL开发环境的教程,
-
在CentOS上安装搭建PHP+Apache+Mysql的服务器环境
-
在Windows系统上搭建Nginx+Python+MySQL环境的教程
-
在cmder下安装ipython以及环境的搭建
-
Linux系统下搭建MantisBT环境以及Apache+PHP+MySql的安装
-
在Windows系统上搭建Nginx+Python+MySQL环境的教程
-
在Mac上利用VirtualBox搭建本地虚拟机环境的方法
-
基于Docker的MySQL主从复制环境搭建的实现步骤