1、首先要在本地建立两个MySQL服务(首先正常使用安装包安装第一个,第二个使用免安装版,参考这里),指定不同的端口。我

这里一个主(3306),一个从(3307)。

2、然后修改主配置文件:

[mysqld]
 #建议使用ip.port方便区分
 server-id = 1   #不设定同步数据库时,默认是全部同步
 binlog-do-db=test #要同步的数据库#binlog-ignore-db=mysql   #不同步的数据库,如果指定了binlog-do-db这里应该可以不用指定的
log-bin=mysql-bin #要生成的二进制日记文件名称
修改从配置文件:
[mysqld]
 #建议使用ip.port方便区分
 server-id = 2log-bin    = mysql-bin

#不设定同步数据库时,默认是全部同步

replicate-do-db=test

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

create user 'repl'@'127.0.0.1' identified by 'asdf';   ----创建用户,并制定用户登录使用的ip,密码(如果是不同机器上,则指定对应机器上的ip)
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'127.0.0.1'; -- --这里我指定数据库(test.*)时报错,而指定全库(*.*)时会成功。(如果是不同机器上,则指定对应机器上的ip)

附:如果账号需要在多台机器上使用,可以不指定对应的ip;或者可以根据情况创建多个账号

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

一般是先将所有的表加读锁,然后copy磁盘上的数据库文件夹。我这里直接停止服务,然后将数据文件拷贝过去。

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

mysql> show master status;--查看主库master配置信息
 +------------------+----------+--------------+------------------+
 | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
 +------------------+----------+--------------+------------------+
 | mysql-bin.000001 | 107 | test | |
 +------------------+----------+--------------+------------------+
 1 row in set (0.00 sec)6、在从库设置它的master:
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; --设置从库master配置
Query OK, 0 rows affected (0.19 sec)
这里的master_log_file和master_log_pos为步骤5中查看到的参数。
7、在从库开启从数据库复制功能。
start slave;
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)

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

附:1.如果slave_io_running   no 可能是配置错误,可以查看一下5,6两个步骤是否配置错误;
    2.如果slave_io_running connetting 原因可能:网络不通;分配的用户名与密码不正确;pos配置错误
    3.如果slave_sql_running no,可以尝试执行:STOP SLAVE ;--停止同步  SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;--设置成yes  START SLAVE;--重新启动同步

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

-- 主库

mysql> create table test1(b int);
Query OK, 0 rows affected (0.16 sec)
mysql> insert into test1 values(2013);
Query OK, 1 row affected (0.13 sec)
-- 从库
mysql> show tables;
 +----------------+
 | test|
 +----------------+
 | test1|
 | test2|
 +----------------+
 2 rows in set (0.00 sec)mysql> select * from test2;
 +------+
 | 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或端口进行设置,好用来区分。

注意:

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

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

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

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