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