MySQL Master&Slave

运行环境

主机:

Master操作系统:Windows 2003 x64

IP地址:192.168.1.5

数据库版本:mysql-essential-5.1.61 x64

从机:

Slave操作系统:Windows XP x32

IP地址:192.168.1.25

数据库版本:mysql-essential-5.1.61 x32

MySQL单向同步复制

一、准备

注意:由于MySQL不同版本之间的(二进制日志)binlog格式可能会不一样,因此最好的搭配组合是Master的MySQL版本和Slave的版本相同或者更低,Master的版本肯定不能高于Slave版本。

分别登陆Master和Slave的MySQL创建数据库:

create database repl;

二、设置主服务器

  • 修改数据库的配置文件(Linux默认名为my.cnf; windows默认名为my.ini),在[mysqld]下面增加以下几行:

    log-bin=log #设置需要记录log

    server-id=1 #标识为主服务器数据库编号
    binlog-do-db=root #
    需要同步的数据库,如果没有本行,即表示同步所有的数据库

    binlog-ignore-db=mysql //被忽略的数据库

  • 在Master机上为Slave机添加一个同步帐号

    grant replication slave on *.* to 'root'@'192.1681.25' identified by '123456';

    重新启动Master机的MySQL服务。

  • 在Master机上进入MySQL查看日志情况:

mysql>show master status;

显示信息如下:

+-----------------+------------+-------------------+-----------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+-----------------+------------+-------------------+-----------------------+

| log.000003 | 106 | repl | mysql |

+-----------------+------------+-------------------+-----------------------+

1 row in set (0.00 sec)

三、设置从服务器

 

  • 同样在my.ini文件中[mysqld] 字段下添加如下内容:

server-id=2 #从服务器标识ID,不能和主服务器重复

master-host=192.168.1.5 #主服务器地址/主服务器名

master-user=root #同步主服务器账户名

master-password=123456 #同步主服务器帐户密码

master-port=3306 #主服务器的 TCP/IP 端口号,默认是3306

master-connect-retry=10 #设置在和主服务器连接丢失的时候,重度的时间间隔.

replicate-do-db=repl #同步的数据库,不写本行表示同步所有数据库

然后重启slave机的mysql 。

  • 接下来在Slave上检验一下是否能正确连接到Master上,并且具备相应的权限。

    在从服务器连接到主服务器MySQL,

    root$mysql -hroot -urep -p123456

    mysql>SHOW GRANTS;
    +------------------------------------------------------------------------------+
    |Grants for root@192.168.1.25 |    
    +------------------------------------------------------------------------------+
    | GRANT Select, FILE, REPLICATION SLAVE ON *.* TO 'root'@'192.168.1.25' IDENTIFIED     BY PASSWORD '*9FF2C222F44C7BBA5CC7E3BE8573AA4E1776278C' |
    +------------------------------------------------------------------------------+

  • 现在,可以启动Slave了。启动成功后,登录Slave,查看一下同步状态:

mysql>start slave;

mysql>show slave status\G;

如果Slave_IO_Running、Slave_SQL_Running状态为Yes则表明设置成功。

查看当前mysql查询进程,显示完整的SQL命令

mysql>show processlist\G

  1. 出现问题

  • 改完配置文件如启动MySQL服务失败,错误编号1067

将配置文件my.ini中的default-storage-engine=InnoDB

修改为default-storage-engine=MyISAM

  • 当我在执行start slave这条命令时,系统提示

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

执行

slave stop;

再执行

change master to

master_host='192.168.1.5',

master_user='root',

master_password='123456',

master_port=3306,

master_log_file='log.000003',

master_log_pos=106;

然后执行

slave start;

再执行

show slave status\G

  • "Slave_IO_Running: Yes" " Slave_SQL_Running:No"

    解决办法一:

    Slave_SQL_Running: No
    1.程序可能在slave上进行了写操作

  1. 也可能是slave机器重起后,事务回滚造成的.
    解决办法:
    mysql> slave stop;
    mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
    mysql> slave start;

    方法一说白了就是如果碰到错误的sql执行语句的时候,故障的表象是slave不会去同步主库,所以要手工让这个语句不去执行,跳N个事件步骤后处理下一个事件,而这个跳过去的事件对数据完整性是没什么影响的。一般设置SET GLOBAL sql_slave_skip_counter = 1(1可以为N.)就可以过去了,如果过不去,就要具体判断要跳多少步才能正确了。

解决办法二:

首先停掉Slave服务:

slave stop;
到主服务器上查看主机状态:
记录File和Position对应的值

进入master服务器

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

然后到slave服务器上执行手动同步:
mysql> change master to
> master_host='192.168.1.5',
> master_user='root',
> master_password='123456',
> master_port=3306,
> master_log_file='log.000003',
> master_log_pos=106 ;
1 row in set (0.00 sec)
mysql> slave start;
1 row in set (0.00 sec)

方法二是强制性从某一个点开始同步,会有部分没有同步的数据丢失,后续主服务器上删除记录同步也会有一些错误信息,不会影响使用.

 

  1. 测试同步是否成功

  • 在主服务器上面新建一个表,必须在选择同步的数据库下

    mysql> use repl

    Database changed

    mysql> create table test(id int,name char(10));

    Query OK, 0 rows affected (0.00 sec)

    mysql>

    mysql> insert into test values(1,'zaq');

    Query OK, 1 row affected (0.00 sec)

    mysql>

    mysql> select * from test;

    +------+------+

    | id | name |

    +-------+------+

    | 1 | zaq |

    +-------+------+

    2 rows in set (0.00 sec)

  • 在从服务器查看是否同步过来

    mysql> use repl;

    Database changed

    mysql> select * from test;

    +------+------+

    | id | name |

    +------+------+

    | 1 | zaq |

    | 1 | xsw |

    +------+------+

    2 rows in set (0.00 sec)

    说明已经配置成功。

  • 测试同步速度

    Read_Master_Log_PosExec_Master_Log_Pos位置之间的时间差值吧.这个值只能在一定程度上说明复制良好,但是经常不准确,比如主从之间网络环境很差的时候,可能主和从的数据差异很大,但是复制过来的日志都能被slavesql线程执行完成,seconds_behind_master此时为0。可以通过在主上show master status\GPosition,和从执行show slave status\G Read_Master_Log_PosExec_Master_Log_Pos进行比较得出复制是否能跟上主的状态。

  • 还需要做的一些优化与监视:
    show full processlist; //
    查看mysql当前同步线程号
    skip-name-resolve //
    跳过dns名称查询,有助于加快连接及同步的速度
    max_connections=1000 //
    增大Mysql的连接数目,(默认100)
    max_connect_errors=100 //
    增大Mysql的错误连接数目,(默认10)

 

posted @ 2013-04-21 21:56  Mr.Leo  阅读(372)  评论(0编辑  收藏  举报