1. 我在192.168.3.102 和192.168.3.98上各自建了个mysql,然后各自建了个DSPUSER用户和DSPDATA库
建mysql: apt-get install mysql-server mysql-client
然后初始化
mysql_install_db --user=mysql --datadir=/usr/local/mysql/var
加用户和库并赋权
CREATE USER 'DSPUSER'@'localhost' IDENTIFIED BY 'DSPUSER';
GRANT USAGE ON *.* TO 'DSPUSER'@'localhost' IDENTIFIED BY 'DSPUSER' WITH MAX_QUERIES_PER_HOUR 0 MAX_CONNECTIONS_PER_HOUR 0 MAX_UPDATES_PER_HOUR 0 MAX_USER_CONNECTIONS 0 ;
CREATE DATABASE IF NOT EXISTS `DSPDATA` ;
GRANT ALL PRIVILEGES ON `DSPDATA`.* TO 'DSPUSER'@'localhost';
ALTER DATABASE `DSPDATA` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;
flush privileges;
2、修改主服务器master:
#vi /etc/my.cnf
[mysqld]
log-bin=mysql-bin //[必须]启用二进制日志
server-id=102 //[必须]服务器唯一ID,默认是1,一般取IP最后一段
log-slave-updates
slave-skip-errors=all
auto_increment_increment=2
auto_increment_offset=1
3、修改从服务器slave:
#vi /etc/my.cnf
[mysqld]
log-bin=mysql-bin //启用二进制日志
server-id=98 //[必须]服务器唯一ID,默认是1,一般取IP最后一段
log-slave-updates
slave-skip-errors=all
auto_increment_increment=2
auto_increment_offset=2
4、重启两台服务器的mysql
/etc/init.d/mysql restart
5、在主服务器上建立帐户并授权slave:
#/usr/local/mysql/bin/mysql -uroot -plocust
mysql>GRANT REPLICATION SLAVE,FILE,SELECT ON *.* to 'tuyou'@'192.168.3.98' identified by '123456';
#/usr/local/mysql/bin/mysql -uroot -plocust
mysql>GRANT REPLICATION SLAVE,FILE,SELECT ON *.* to 'tuyou'@'192.168.3.102' identified by '123456';
6、登录主服务器的mysql,查询master的状态
mysql>show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000170 | 261| | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
注:执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化
7、配置从服务器Slave:
mysql>change master to master_host='192.168.3.102',master_user='tuyou',master_password='123456',
master_log_file='mysql-bin.000170',master_log_pos=261; //注意不要断开,308数字前后无单引号。
Mysql>start slave; //启动从服务器复制功能
8、检查从服务器复制功能状态:
mysql> show slave status\G
其他信息与上面的相同
Slave_IO_Running: Yes //此状态必须YES
Slave_SQL_Running: Yes //此状态必须YES
......
注:Slave_IO及Slave_SQL进程必须正常运行,即YES状态,否则都是错误的状态(如:其中一个NO均属错误)。
以上操作过程,主从服务器配置完成。
9. 在102上建一张表,在98从库上也能看到,而在98上建个表,在102上却不会看到
注:如果要进行主主复制,则需以上操作再做一次