MySQL主从搭建 和 主从不同步的解决方案

mysql配置文件

etc/my.conf

错误日志

在msql里面的

find -name  ‘*.err’  就会找到

一、实验目标

搭建两台MySQL服务器,一台作为主服务器,一台作为从服务器,主服务器进行写操作,从服务器进行读操作。

 

二、测试环境

主数据库: CentOS7, MySQL15.1 , 192.168.1.233

从数据库: CentOS7, MySQL15.1 , 192.168.1.234

 

三、主从配置步骤

1、确保主数据库与从数据库里的数据一样

例如:主数据库里的a的数据库里有b,c,d表,那从数据库里的就应该有一个模子刻出来的a的数据库和b,c,d表

我这里在两台MySQL上都创建了个名为“test”的数据库来测试,如图:

clipboard.png

 

2、在主数据库里创建一个同步账号

1)每个从数据库会使用一个MySQL账号来连接主数据库,所以我们要在主数据库里创建一个账号,并且该账号要授予 REPLICATION SLAVE 权限,你可以为每个从数据库分别创建账号,当然也可以用同一个!)

2)你可以用原来的账号不一定要新创账号,但你应该注意,这个账号和密码会被明文存放在master.info文件中,因此建议单独创一个只拥有相关权限的账号,以减少对其它账号的危害!)

3)创建新账号使用“CREATE USER”,给账号授权使用“GRANT”命令,如果你仅仅为了主从复制创建账号,只需要授予REPLICATION SLAVE权限。

4)下面来创建一个账号,账号名:repl,密码:repl123,只允许192.168.1.的IP段登录,如下:

1.mysql> CREATE USER ‘repl’@’192.168.1.%’ IDENTIFIED BY ‘repl123’;

2.mysql> GRANT REPLICATION SLAVE ON *.* TO ‘repl’@’192.168.1.%’;

5)如果开发防火墙,可能要配置下端口,如下: (如果这个不开,会在下面提到问题,你的武器可能不是这个方法,但是也应该差不多)

1.firewall-cmd –zone=public –add-port=3306/tcp –permanent

2.firewall-cmd –reload

 

3、配置主数据库

1)要主数据库,你必须要启用二进制日志(binary logging),并且创建一个唯一的Server ID,这步骤可能要重启MySQL。

2)主服务器发送变更记录到从服务器依赖的是二进制日志,如果没启用二进制日志,复制操作不能实现(主库复制到从库)。

3)复制组中的每台服务器都要配置唯一的Server ID,取值范围是1到(232)−1,你自己决定取值。

4)配置二进制日志和Server ID,你需要关闭MySQL和编辑my.cnf或者my.ini文件,在 [mysqld] 节点下添加配置。

5)下面是启用二进制日志,日志文件名以“mysql-bin”作为前缀,Server ID配置为1,如下:

上面的解释代码如下:

{

提示1:如果你不配置server-id或者配置值为0,那么主服务器将拒绝所有从服务器的连接。

提示2:在使用InnoDB的事务复制,为了尽可能持久和数据一致,你应该在my.cnf里配置innodb_flush_log_at_trx_commit=1 和 sync_binlog=1;

For the greatest possible durability and consistency in a replication setup using InnoDB with transactions, you should useinnodb_flush_log_at_trx_commit=1 and sync_binlog=1 in the master my.cnf file.

提示3:确保主服务器里的skip-networking选项未启用,如果网络被禁用,你的从服务器将不能与主服务器通信并且复制失败。

}

在mysql配置文件里面:一般的是在 etc/my.coonf

[mysqld]

log-bin=mysql-bin

server-id=1

#网络上还有如下配置

#binlog-do-db=mstest //要同步的mstest数据库,要同步多个数据库,就多加几个replicate-db-db=数据库名 #binlog-ignore-db=mysql //要忽略的数据库

重启mysql

查看主服务器状态

mysql> show master status;

2.png

 

4、配置从数据库

(1)从服务器,同理,要分配一个唯一的Server ID,需要关闭MySQL,修改好后再重启,如下:

[mysqld]

server-id=2

#可以指定要复制的库

replicate-do-db = test #在master端不指定binlog-do-db,在slave端用replication-do-db来过滤

replicate-ignore-db = mysql #忽略的库

#网上还有下面配置

#relay-log=mysqld-relay-bin

提示1:如果有多个从服务器,每个服务器的server-id不能重复,跟IP一样是唯一标识,如果你没设置server-id或者设置为0,则从服务器不会连接到主服务器。

提示2:一般你不需要在从服务器上启用二进制日志,如果你在从服务器上启用二进制日志,那你可用它来做数据备份和崩溃恢复,或者做更复杂的事情(比如这个从服务器用来当作其它从服务器的主服务器)。

(2)配置连接主服务器的信息

mysql> stop slave;

mysql> CHANGE MASTER TO

mysql-> MASTER_HOST=’192.168.1.233′,

mysql-> MASTER_USER=’repl’,

mysql-> MASTER_PASSWORD=’repl123′,

mysql-> MASTER_LOG_FILE=’mysql-bin.000002′,

mysql-> MASTER_LOG_POS=313;

mysql> start slave;

(3)查看从服务器状态

mysql> show slave status \G;

3.png

在这里,大多数人都会卡在这里,标记红色的都是yes为正确。

如果不行,看下下面的error参数说的是什么。

错误测试:如果是连接不成功, mysql -usxm -p -h(你的主机的ip) 测试下看看是否连接的上,如果不行

你可以在windos cmd命令上进行连接 telnet ip 端口

如果都是连接不上,那就是主库的原因,多半是防火墙,上面的说到的没有禁止。

解决之后:数据还是不同步,但是能连接上,那就是多半是建的user里面的账户关

测试的时候

 

5.测试

在主库建表或者添加数据,从库会同步。。。。。。。。。。。。。。。

公司经常会出现主从出现问题,主从突然不同步,我测试了下,

故意测试失败,故意让主从不同步!!!:

解决办法:

主库

flush privileges;

show master status;(生成新的连接file数据)

从库:

stop slave;

change master to master_host=’140.143.228.88′,master_user=’sxm’,master_password=’123′,master_log_file=’mysql-bin.000001′,master_log_pos=107;

start slave;

show slave status \G; (看看成功与否)

暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇