数据库同步linux,linux 数据库主从同步配置

bc3f9276acf88283a0569b9b9ef9ee92.png

在线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;从属启动

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值