windows单机搭建mysql主从
2016-11-16 00:00
555 查看
在本地建立两个mysql服务,指定不同的端口。例:一个主(3308),一个从(3307)。
一、配置Master
1.打开master目录下的my.ini文件,在文件中添加如下内容:
server-id = 1
binlog-do-db = test
log-bin=master-bin
log-bin-index=master-bin.index
2.启动master
命令行切换到master的bin目录下,执行mysqld --console命令
3.在master上创建一个复制用户
进入到mysql数据库客户端中
mysql> create user repl_user;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> grant replication slave on *.* to repl_user identified by 'psw';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql>
说明:replication slave这个权限没有什么特别之处,只是这个用户可以从master上取得二进制的日志转储数据,完全可以给一个常规帐号赋予replication slave权限,但是最好还是将replication slave权限和其他用户权限分开,这样的话,如果后期想禁止某些slave的链接,只要删除该用户就可以了
4.保持主从mysql的test数据库初始状态一致一般是先将所有的表加读锁,然后copy磁盘上的数据库文件夹。我这里直接停止服务,然后将数据文件拷贝过去。
5.在主数据库里面运行show master status;记下file和position字段对应的参数。
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
二、配置slave
1.打开slave目录下的my.ini文件,在文件中添加如下内容:
server-id = 2
replicate-do-db=test
log-bin = mysql-bin
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index
与master一样,slave也要配置一个唯一的服务器id,relay-log和relay-log-index表示中继日志文件和中继日志索引文件
2.启动slave
命令行切换到slave的bin目录下,执行mysqld --console命令
3.将slave连接到master上
进入到mysql数据库客户端中
mysql>change master to master_host='127.0.0.1',master_port=3306,master_user='repl',master_password='asdf',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>change master to master_host='localhost',master_port=3310,master_user='repl_user',master_password='111111';
Query OK, 0 rows affected, 2 warnings (0.45 sec)
mysql>
mysql> start slave;
Query OK, 0 rows affected (0.05 sec)
mysql>
4.开启从数据库复制功能slave start;
mysql> slave start;
Query OK, 0 rows affected (0.00 sec)
在从库可以通过show slave status来查看一些参数。
三、测试
在主库创建表或插入数据
-- 主库
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)
同理,可以搭建第二、第三个从节点。
一、配置Master
1.打开master目录下的my.ini文件,在文件中添加如下内容:
server-id = 1
binlog-do-db = test
log-bin=master-bin
log-bin-index=master-bin.index
2.启动master
命令行切换到master的bin目录下,执行mysqld --console命令
3.在master上创建一个复制用户
进入到mysql数据库客户端中
mysql> create user repl_user;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> grant replication slave on *.* to repl_user identified by 'psw';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql>
说明:replication slave这个权限没有什么特别之处,只是这个用户可以从master上取得二进制的日志转储数据,完全可以给一个常规帐号赋予replication slave权限,但是最好还是将replication slave权限和其他用户权限分开,这样的话,如果后期想禁止某些slave的链接,只要删除该用户就可以了
4.保持主从mysql的test数据库初始状态一致一般是先将所有的表加读锁,然后copy磁盘上的数据库文件夹。我这里直接停止服务,然后将数据文件拷贝过去。
5.在主数据库里面运行show master status;记下file和position字段对应的参数。
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
二、配置slave
1.打开slave目录下的my.ini文件,在文件中添加如下内容:
server-id = 2
replicate-do-db=test
log-bin = mysql-bin
relay-log = slave-relay-bin
relay-log-index = slave-relay-bin.index
与master一样,slave也要配置一个唯一的服务器id,relay-log和relay-log-index表示中继日志文件和中继日志索引文件
2.启动slave
命令行切换到slave的bin目录下,执行mysqld --console命令
3.将slave连接到master上
进入到mysql数据库客户端中
mysql>change master to master_host='127.0.0.1',master_port=3306,master_user='repl',master_password='asdf',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>change master to master_host='localhost',master_port=3310,master_user='repl_user',master_password='111111';
Query OK, 0 rows affected, 2 warnings (0.45 sec)
mysql>
mysql> start slave;
Query OK, 0 rows affected (0.05 sec)
mysql>
4.开启从数据库复制功能slave start;
mysql> slave start;
Query OK, 0 rows affected (0.00 sec)
在从库可以通过show slave status来查看一些参数。
三、测试
在主库创建表或插入数据
-- 主库
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)
同理,可以搭建第二、第三个从节点。
相关文章推荐
- 如何在一台windows主机上搭建mysql主从复制
- 如何在一台windows主机上搭建mysql主从复制
- windows上搭建mysql的主从复制测试环境
- Windows中MySQL主从数据库搭建(一)
- Windows中MySQL主从数据库搭建(三)
- 如何在一台windows主机上搭建mysql主从配置
- windows MySQL主从复制搭建
- ccc如何在一台windows主机上搭建mysql主从复制
- windows下成功搭建mysql的主从关系
- mysql 5.7.15单机主从快速搭建并配置复制表到不同库
- windows 下mysql主从搭建 io 线程出现no
- windows系统单机安装mysql两实例并配置为主从关系
- Mysql主从搭建-Windows版
- Windows中MySQL主从数据库搭建(二)
- mysql 5.7 for win 7 主从搭建 -单机多实例
- mysql主从数据库搭建(系统均为windows)
- mysql windows下搭建mysql主从+注意事项
- MySQL主从复制配置-windows单机环境
- redis在Windows下以后台服务一键搭建哨兵(主从复制)模式(单机)
- [z]如何在一台windows主机上搭建mysql主从复制