BJ:一台Windows主机搭建mysql主从配置

转自:http://blog.csdn.net/white_ice/article/details/52598106

1、在本地创建两个mysql数据库服务,具体详见http://blog.csdn.net/u013490585/article/details/54172960。分别给主从指定不同的端口,我这里主3306,从3307

2、修改主配置文件,打开主mysql目录下面的my.ini文件 ,在[mysqld]下面添加以下几行配置

server-id=1 #区分服务
binlog-do-db=market  #要同步的数据库
log-bin=master-bin #要生成的二进制日记文件名称
log-bin-index=master-bin.index

3、修改从配置文件,打开从mysql目录下面的my.ini文件,在[mysqld]下面添加以下几行配置

server-id=2
replicate-do-db=market
log-bin=relay-bin
relay-log-index=slave-relay-bin.index
relay-log=slave-relay-bin 

4、在主库添加一个用户 repl 并指定replication权限

在主库添加一个用户 repl 并指定replication权限

mysql> create user 'repl'@'127.0.0.1' identified by 'repl';

mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'127.0.0.1'; -- --这里我指定数据库(market.*)时报错,而指定全库(*.*)时会成功。

5、保持主从mysql的test数据库初始状态一致。

我是将主数据库导出成sql文件,从数据库导入执行,这样保证主从的market数据库中数据状态一致。

6、重启服务

7、在主数据库里面运行show master status;记下file和position字段对应的参数。

mysql> show master status;
+-------------------+----------+--------------+------------------+
| File         | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000003 |    658 | market   |             |
+-------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

8、在从库设置它的master:

mysql> change master to

master_host='127.0.0.1',master_port=3306,master_user='repl',master_password='repl',master_log_file='master-

bin.000003',master_log_pos=658;

Query OK, 0 rows affected (0.19 sec)

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

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

slave start;

mysql> slave start;

Query OK, 0 rows affected (0.00 sec)

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

10、测试 在主库中添加一条数据,在从库中很快就能看到。

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

备注:两个服务的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或端口进行设置,好用来区分。

注意:

    * 主从间的数据库不是实时同步,就算网络连接正常,也存在瞬间,主从数据不一致。 

    * 如果主从的网络断开,从会在网络正常后,批量同步。 

    * 如果对从进行修改数据,那么很可能从在执行主的bin-log时出现错误而停止同步,这个是很危险的操作。所以一般情况

下,非常小心的修改从上的数据。


猜你喜欢

转载自blog.csdn.net/Yanci_/article/details/77477930