实现MySQL主从复制须要进行的配置:
mysql
主服务器:linux
开启二进制日志sql
配置惟一的server-idshell
得到master二进制日志文件名及位置数据库
建立一个用于slave和master通讯的用户帐号服务器
从服务器:ide
配置惟一的server-id日志
使用master分配的用户帐号读取master二进制日志server
启用slave服务进程
具体实现过程以下:
1、准备工做:
1.主从数据库版本最好一致
2.主从数据库内数据保持一致
主数据库:182.92.172.80 /linux
从数据库:123.57.44.85 /linux
2、主数据库master修改:
1.修改mysql配置
找到主数据库的配置文件my.cnf(或者my.ini),个人在/etc/mysql/my.cnf,在[mysqld]部分插入以下两行:
[mysqld]
log-bin=mysql-bin #开启二进制日志
server-id=1 #设置server-id
2.重启mysql,建立用于同步的用户帐号
打开mysql会话shell>mysql -hlocalhost -uname -ppassword
建立用户并受权:用户:rel1密码:slavepass
mysql> CREATE USER 'repl'@'123.57.44.85' IDENTIFIED BY 'slavepass';#建立用户
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'123.57.44.85';#分配权限
mysql>flush privileges; #刷新权限
3.查看master状态,记录二进制文件名(mysql-bin.000003)和位置(73):
复制代码
mysql > SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 | 73 | test | manual,mysql |
+------------------+----------+--------------+------------------+
复制代码
2、从服务器slave修改:
1.修改mysql配置
一样找到my.cnf配置文件,添加server-id
[mysqld]
server-id=2 #设置server-id,必须惟一
2.重启mysql,打开mysql会话,执行同步SQL语句(须要主服务器主机名,登录凭据,二进制文件的名称和位置):
mysql> CHANGE MASTER TO
-> MASTER_HOST='182.92.172.80',
-> MASTER_USER='rep1',
-> MASTER_PASSWORD='slavepass',
-> MASTER_LOG_FILE='mysql-bin.000003',
-> MASTER_LOG_POS=73;
3.启动slave同步进程:
mysql>start slave;
4.查看slave状态:
复制代码
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 182.92.172.80
Master_User: rep1
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000013
Read_Master_Log_Pos: 11662
Relay_Log_File: mysqld-relay-bin.000022
Relay_Log_Pos: 11765
Relay_Master_Log_File: mysql-bin.000013
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
...
复制代码
当Slave_IO_Running和Slave_SQL_Running都为YES的时候就表示主从同步设置成功了。