在线QQ客服:1922638
专业的SQL Server、MySQL数据库同步软件
1.配置MySQL主服务器的my.cnf文件(192.168.1.128)
vi/etc/my.cnf? #编辑配置文件,在[mysqld]部分中添加以下内容
服务器ID = 1? #将主服务器的服务器ID设置为1。注意:如果此行已在原始配置文件中,则无需添加它。
log-bin = mysql-bin吗? #启动MySQ二进制日志系统。注意:如果此行已在原始配置文件中,则无需添加它。
binlog-do-db = osyunweidb? #需要同步的数据库名称。如果有多个数据库,则可以重复此参数,每个数据库一行
binlog-ignore-db = mysql? #不同步mysql系统数据库
:wq ! #保存并退出
服务mysqld?重新开始? #重新启动MySQL
mysql-u root-p吗? #进入mysql控制台
显示类似” server_id”的变量? #检查server-id的值是否为1
mysql \ gt;显示类似” server_id”的变量;
+—————+——-+
|变量名|价值|
+—————+——-+
| server_id? | 1 ?? |
+—————+——-+
设置1行(0.00秒)
显示主人身份;? #查看主服务器,出现以下类似信息
mysql \ gt;显示主人身份;
+——————+———-+————–+——————+
|文件?????? |职位| Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———-+————–+——————+
| mysql-bin.000011 | 107 | osyunweidb? | mysql |
+——————+———-+————–+——————+
设置1行(0.00秒)
注意:在这里记住File的值:mysql-bin.000011和Position:107,将在以后使用。
2.配置MySQL从属服务器的my.cnf文件(192.168.21.129)
vi/etc/my.cnf? #编辑配置文件,在[mysqld]部分中添加以下内容
服务器ID = 2? #设置服务器ID,将其值修改为2,这意味着它来自数据库
log-bin = mysql-bin吗? #启动MySQ二进制日志系统。注意:如果此行已在原始配置文件中,则无需添加它。
复制-do-db = osyunweidb? #需要同步的数据库名称。如果有多个数据库,则可以重复此参数,每个数据库一行
复制-ignore-db = MySQL的? #不同步mysql系统数据库
只读? #将数据库设置为只读
slave-skip-errors =所有
:wq! #保存并退出
服务mysqld重启? #重新启动MySQL
MySQL的?-u root-p? #进入MySQL控制台
显示类似” server_id”的变量? #查看server-id的值,该值必须为2以上,否则请返回以修改配置文件
mysql \ gt;显示类似” server_id”的变量;
+—————+——-+
|变量名|价值|
+—————+——-+
| server_id? | 2 |
+—————+——-+
设置1行(0.01秒)
奴隶站;? #停止从属同步过程
将master更改为master_host =” 192.168.1.128″,master_user =” osyunweidbbak”,master_password =” 123456″,master_log_file =” mysql-bin.000011″,master_log_pos = 107 ;? #执行同步语句
奴隶开始; #启动从站同步过程
显示从站状态\\\\ G? #查看从站同步信息,出现以下内容
mysql \ gt;显示从属状态\\\\ G
*************************** 1.行******************** *******
Slave_IO_State:等待主机发送事件
Master_Host:192.168.1.128
主用户:osyunweidbbak
Master_Port:3306
Connect_Retry:60
Master_Log_File:mysql-bin.000011
Read_Master_Log_Pos:107
Relay_Log_File:mysqlslave-relay-bin.000004
Relay_Log_Pos:253
Relay_Master_Log_File:mysql-bin.000011
Slave_IO_Running:是
Slave_SQL_Running:是
Replicate_Do_DB:osyunweidb
Replicate_Ignore_DB:mysql
Replicate_Do_Table
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno:0
Last_Error:
Skip_Counter:0
Exec_Master_Log_Pos:107
Relay_Log_Space:560
直到条件:无
直到日志文件:
直到Log_Pos:0
Master_SSL_Allowed:否
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master:0
Master_SSL_Verify_Server_Cert:否
Last_IO_Errno:0
Last_IO_Error:
Last_SQL_Errno:0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id:1
设置1行(0.00秒)
mysql \ gt;
查看注意事项:
Slave_IO_Running:是
Slave_SQL_Running:是
以上两个参数的值为”是”,表示配置成功!
测试文章
测试MySQL主从服务器是否正常运行
1.输入MySQL主服务器(192.168.21.128)
mysql-u root-p吗? #进入MySQL控制台
使用osyunweidb? #输入数据库
CREATE TABLE test(id int不为null的主键,名称为char(20)); #创建测试表
2.输入MySQL从服务器
mysql-u root-p吗? #进入MySQL控制台
使用osyunweidb? #输入数据库
显示?桌子;? #查看osyunweidb表结构,您将看到一个新的表测试,表明数据库同步成功
mysql \ gt;显示?桌子;
+———————-+
| Tables_in_osyunweidb |
+———————-+
|测试???????
+———————-+
设置1行(0.00秒)
错误处理
mysql主从集群准备就绪后,不小心从master数据库中删除了数据库数据,slave数据库没有此数据库,则Slave_SQL_Running:NO,它将变为NO,有两种解决方法
记录与文件和位置相对应的值。
mysql \ gt;显示主人身份;
+——————+———–+————–+—————-+
|档案|职位| Binlog_Do_DB | Binlog_Ignore_DB |
+——————+———–+————–+—————-+
| mysql-bin.000013 | 330748356 | | |
+——————+———–+————–+—————-+
设置1行(0.00秒)
在从属服务器上执行手动同步:
mysql \ gt;从站
mysql>更改主机为? master_log_file =” mysql-bin.000013″ , master_log_pos = 330748356;
设置1行(0.00秒)
mysql \ gt;从属启动
设置1行(0.00秒)
再次检查从站状态并找到:
Slave_IO_Running:是
Slave_SQL_Running:是
…
Seconds_Behind_Master:0
解决方案二:
mysql \ gt;从站
mysql \ gt;设置GLOBAL SQL_SLAVE_SKIP_COUNTER = 1;
mysql \ gt;从属启动