centos7 mysql 互为主从
1.设置my.cnf配置文件
输入命令 vi /etc/my.cnf进入编辑
在[mysqld]下输入
log-bin=mysql-bin
server-id = 21
如图
退出编辑
重启数据库 systemctl restart mysqld
2.登陆数据库
mysql -uroot -p’password’
其中root为用户名 password为密码
3.增加用户
mysql> CREATE USER ‘replication’@‘39.97.114.199’ IDENTIFIED BY “#BavDu…0928#”;
Query OK, 0 rows affected (0.01 sec) 里面包括重从数据库ip39.97.114.199 密码 #BavDu…0928#
mysql> GRANT REPLICATION SLAVE ON . TO ‘replication’@‘39.97.114.199’;
Query OK, 0 rows affected (0.00 sec)
mysql> SHOW MASTER STATUS;
±-----------------±---------±-------------±-----------------±------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
±-----------------±---------±-------------±-----------------±------------------+
| mysql-bin.000002 | 877 | | | |
±-----------------±---------±-------------±-----------------±------------------+
1 row in set (0.00 sec)
##------------------------------------主库设置------------------------------------##
##------------------------------------从库设置------------------------------------##
[root@slave ~]# vi /etc/my.cnf
[mysqld]
server_id=22
log-bin=mysql-bin
重启数据库 systemctl restart mysqld
mysql> CHANGE MASTER TO
-> MASTER_HOST=‘39.97.114.199’, --主数据库ip
-> MASTER_USER=‘replication’, --用户名
-> MASTER_PASSWORD=’#BavDu…0928#’, --密码
-> MASTER_LOG_FILE=‘mysql-bin.000003’, --主数据库日志文件所在位置
-> MASTER_LOG_POS=877; --主数据库日志文件所在位置
mysql> start slave;
mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.13.21
Master_User: replication
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 877
Relay_Log_File: slave-relay-bin.000002
Relay_Log_Pos: 649
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes (注意这两行是不是yes)
##------------------------------------从库设置---------------------------##
测试:主库创建一个数据库,查看从库会不会同步