文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL进阶——主从复制

2019-05-12 21:07

关注

MySQL进阶——主从复制

attachments-2020-03-nSwxNjkM5e79698370399.jpg

 

1.主从复制的基本原理

slave会从master读取binlog来进行数据同步。主要有以下三个步骤:

①master将改变记录到二进制日志(binary log),这些记录过程叫做二进制日志事件(binary log events)。

②slave将master的binary log events拷贝到中继日志(relay log)。

③slave重做中继日志中的事件,将改变应用到自己的数据库中。MySQL的复制是异步且串行化的。

v2-45e6eb9a8cd6849617e55274bd6fc898_720w.jpg

 

2.主从复制的规则

①每个slave只能有一个master。(一对一)

②每个slave只能有一个唯一的服务器ID。

③每个master可以有多个slave。(一对多)

在主从复制过程中,最大的问题就是延时。

 

3.一主一从的常见配置

#1.要求。

MySQL版本最好一致且后台以服务运行。并且保证主机与从机互相ping通。主从配置都在[mysqld]结点下,都是小写。

#2.主机修改my.ini配置文件

①server-id=1,主机服务器id。(必须)

②必须启用二进制文件。

log-bin="E:devSoftmysql-5.7.22-winx64datamysql-bin"

配置该项后,重新启动mysql服务,可看到如下内容。

v2-6e7f3fe2702869c5591a33da7f28c4f5_720w.jpg

③启用错误日志。(可选)

log_error ="E:devSoftmysql-5.7.22-winx64datalogerrorloglog_error.log"

④根目录、数据目录。(可选)

#mysql安装根目录 basedir ="E:devSoftmysql-5.7.22-winx64"   #mysql数据文件所在位置 datadir ="E:devSoftmysql-5.7.22-winx64data"

⑤临时目录。(可选)

tmpdir  ="E:devSoftmysql-5.7.22-winx64"

⑥read-only=0,表示主机读写都可以。

⑦可设置不需要复制的数据库。(可选)

binlog-ignore-db=mysql

⑧可设置需要复制的数据库。(可选)

binlog-do-db=databasename

#3.从机修改my.cnf配置文件

①从服务器ID。(必须)

②启用二进制日志。(可选)

#4.主机与从机都关闭防火墙,其实也可配置ip规则,但关闭防火墙更快速。

#5.在Windows主机上建立账户并授权给slave。

a.首先在主机上创建账户:

#%表示任何客户端都可以连接 grant all privileges on *.* to slaveaccount(用户名)@"%(或者指定ip)" identified by "你想设置的密码" with grant option;

b.然后刷新权限表:

flush privileges;

c.然后授权给slave:

GRANT REPLICATION SLAVE ON *.* TO "slaveaccount(上面创建的用户名)"@"从机数据库ip" IDENTIFIED BY "你想设置的密码"

d.利用b步骤命令再次刷新权限表。

#6.查询master的状态。

v2-19db90cdc229112b893405e6d9ff9302_720w.jpg

File和Position这两个字段非常重要,File告诉从机需要从哪个文件进行复制,Position告诉从机从文件的哪个位置开始复制,在从机上配置时需用到。执行完此操作后,尽量不要在操作主服务器MySQL,防止主服务器状态变化(File和Position状态变化)。

#7.在Linux从机上配置需要的主机。

CHANGE MASTER TO MASTER_HOST="主机IP",MASTER_USER="salveaccount",MASTER_PASSWORD="主机授权的密码",MASTER_LOG_FILE="File名字",MASTER_LOG_POS=Position数字;

#8.启动从服务器复制功能。

start slave;

启动复制功能后,需要查看主从复制配置是否成功。

v2-077f8c6214b6133b9ce88309c45b07a5_720w.jpg

注:只有当Slave_IO_Running:Yes和Slave_SQL_Running:Yes,这两个都为Yes的时候,主从复制配置才成功。

#9.进行测试。

①首先在主机上建立数据库并插入数据。

v2-665fd3357cc93c0c46386bd79cd94343_720w.jpgv2-f28ad22e77ddd2271ff6a8ee2b02a5e6_720w.jpg

②在从机中查看是否有相应数据库。

v2-b1fa5aaca4b06da8d0822418bbf800ec_720w.jpgv2-3d74d18d443b6aab86b50f8bc533aeb2_720w.jpg

通过从机上查看相应数据,可知主从复制配置成功。

#10.停止从服务复制功能。

stop slave;

 

4.总结

#1.主从复制的配置,大部分都在主机上,注意查看相关步骤。

#2.这里将主从机的防火墙都关闭是为了更好的演示,实际生产环境中一般不会出现windows主机和linux从机这种情况,因此不应该关闭防火墙,而是根据具体情况配置防火墙规则。

 

attachments-2020-03-bve1h1635e7969bff1c5b.jpg

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯