Ubuntu 14.04 MySQL同步

主服务器:192.168.2.212

从服务器:192.168.2.211
 
主服务器(192.168.2.212):
先到/etc/mysql/my.cnf下 将
bind-address 127.0.0.1

注释掉

#bind-address 127.0.0.1

允许非本机访问。

登陆mysql

mysql -uroot -p
grant replication slave,reload,super on *.* to slave@192.168.2.211 identified by ''

可以在从服务器(192.168.2.211)远程测试一下

mysql -uslave -h192.168.2. -p

修改主服务器my.cnf

sudo nano /etc/mysql/my.cnf

以下内容必须在[mysqld]模块中

server-id=1
log_bin=/var/log/mysql/mysql-bin.log
binlog_do_db=ccs
binlog_ignore_db=mysql

do_db和ignore_db分别是同步的数据库和不同步的数据库,有多条就写多行。

重启mysql

sudo /etc/init.d/mysql restart

进mysql

mysql -uroot -p
show variables like 'log%';

log_bin应该为ON

show master status;

则能看到对应得file position 信息,这些在从机设置的时候要用到。

从服务器(192.168.2.211):

配置my.cnf

server-id=2
log_bin=/var/log/mysql/mysql-bin.log
replicate_do_db=ccs

重启mysql

sudo /etc/init.d/mysql restart

进mysql:

mysql -uroot -p
stop slave;

然后设置从master复制日志配置

CHANGE MASTER TO
MASTER_HOST='192.168.2.212',
MASTER_USER='slave',
MASTER_PASSWORD='',
MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.000006',
MASTER_LOG_POS=277,
MASTER_CONNECT_RETRY=10;

LOG_FILE和LOG_POS则是在master下show master status时候看到的file position信息。

CONNECT_RETRY是每次重连的时间间隔

start slave;
show slave status\G

在出现的信息中找到 Slave_IO_Running/Slave_SQL_Running ,都为YES则成功了。

上一篇:Centos 6.6 下搭建php5.2.17+Zend Optimizer3.3.9+Jexus环境


下一篇:从零开始编写自己的C#框架(17)——Web层后端首页