MySQL的主从配置步骤[2012更新版]

两台服务器
主库(Master)为: 10.0.4.158
从库(Slave)为:10.0.4.162
主从服务器的MySQL版本一致
主数据库配置

一、登录Master服务器
1、建立日志目录/opt/mysql/binlog/,设定777权限.
2、修改my.ini ,在[mysqld]添加如下内容:

   
    #数据库ID号, 为1时表示为Master,其中master_id必须为1到232–1之间的一个正整数值;
    server-id = 1
    #需要同步的数据库名,如果同步多个库,需要另行重写.如果不设置可以将其注释掉,
    #binlog-do-db=ultrax
    #不需要同步的数据库,与binlog-do-db相反,如果你有100个库,只想同步其中几个,那么你应该使用binlog-do-db,如果不想同步其中的几个,就使用binlog-ignore-db
    binlog-ignore-db=mysql
    binlog-ignore-db=information_schema
    #设定生成的log文件名;
    log-bin="/opt/mysql/binlog/mysql1log"
    #用来配置从服务器的更新是否写入二进制日志,这个选项默认是不打开的,但是,如果这个从服务器B是服务器A的从服务器,同时还作为服务器C的主服务器,或者AB互为主从,那么就需要打开这个选项,这样它的从服务器才能获得它的二进制日志进行同步信息
    log-slave-updates
    #跳过错误,继续执行复制;
    slave-skip-errors

配置完重启 mysql

二、在主库建立slave从库所要使用的用户;

mysql>grant replication slave on *.* to mslave@10.0.4.162 identified by '********';

三、查询master状态

mysql> show master status;


查看Master的状态,将上面的File和Position的值记录下来,下面从库会用的到。

四、将主库中以上配置的需要同步(或者除了排除库以外的)的 数据库的数据 备份到从库中

从数据库配置

一、登录Slave数据库服务器
1、建立日志目录/opt/mysql/binlog/,设定777权限.
2、修改my.ini ,在[mysqld]添加如下内容:

  
    #如果需要增加更多Slave库,则此id往后顺延;
    server-id = 2
    log-bin="/opt/mysql/binlog/mysql2log"
    #不需要备份的数据库;
    replicate-ignore-db=mysql
    replicate-ignore-db=information_schema
    #需要备份的数据库
    #replicate-do-db=webmaster.me
    log-slave-update
    slave-skip-errors

    #配置主库ip和上面刚才建立的用户
    master-host = 10.0.4.158
    master-user = mslave
    master-password = ******
    master-port = 3306
    #如果发现主服务器断线,重新连接的时间差;
    master-connect-retry=60

配置完成后,重启从库的mysql

二、启动 slave ,并查看slave 状态是否正常;

    mysql>slave stop;
    #配置master对象,master_log_file对象上面记录的File,master_log_pos对象上面记录的Position;
    mysql>change master to master_host='xx.xx.xx.xx',master_user='mslave',master_password='****',master_connect_retry=60,master_log_file='mysql1log.000001',master_log_pos= 106;
    mysql>slave start;
    mysql>show slave statusG;

状态如下图所示:

由图上可以查看 主库的 File 和 Position 与 从库的上设置Master_Log_File、Read_Master_Log_Pos 一致,确保状态中Slave_IO_Running: Yes 、Slave_SQL_Running: Yes ,则证明Slave的I/O和SQL进行正常,主从配置成功。

注:Slave_IO_Running: No 一般是可能原因是 主库服务器有防火墙等原因,从库服务器无法使用主库设置的复制帐号连接到主库

Discuz! X2 的读写分离的配置 参照 http://www.webmaster.me/php-it/discuz-x2-read-write-splitting.html