Mysql的复制(replication)是一个异步的复制。
实现整个复制操作主要由三个进程完成的,其中两个进程在Slave(Sql进程和IO进程),另外一个进程在 Master(IO进程)上。
要实施复制,首先必须打开Master端的binary log(bin-log)
功能,否则无法实现。
因为整个复制过程实际上就是Slave从Master端获取该日志然后再在自己身上完全顺序的执行日志中所记录的各种操作。
复制的详细过程:
(1)Slave上面的IO进程连接上Master,并请求从指定日志文件的指定位置(或者从最开始的日志)之后的日志内容;
(2)Master接收到来自Slave的IO进程的请求后,通过负责复制的IO进程根据请求信息读取制定日志指定位置之后的日志信息,返回给Slave 的IO进程。返回信息中除了日志所包含的信息之外,还包括本次返回的信息已经到Master端的
bin-log
文件的名称以及bin-log
的位置;
(3)Slave的IO进程接收到信息后,将接收到的日志内容依次添加到Slave端的
relay-log
文件的最末端,并将读取到的Master端的 bin-log的文件名和位置记录到master-info
文件中,以便在下一次读取的时候能够清楚的高速Master“我需要从某个bin-log的哪个位置开始往后的日志内容,请发给我”;
(4)Slave的Sql进程检测到relay-log中新增加了内容后,会马上解析relay-log的内容成为在Master端真实执行时候的那些可执行的内容,并在自身执行。
原则:
-
每个slave只有一个master;
-
每个slave只能有一个唯一的服务器ID;
-
每个master可以有多个salve;
演示主机为Windows
(配置文件为my.ini
文件),从机为Linux
(配置文件为my.cnf
)
1、主机配置(windows的my.ini)
-
1)、[必须]主服务器唯一ID;
-
2)、[必须]启用二进制日志;
-
log-bin=自己本地的路径/data/mysqlbin
。 -
log-bin=D:/devSoft/MySQLServer5.5/data/mysqlbin
。 -
3)、[可选]启用错误日志
-
log-err=自己本地的路径/data/mysqlerr
。 -
log-err=D:/devSoft/MySQLServer5.5/data/mysqlerr
。 -
4)、[可选]根目录
-
basedir="自己本地路径"
。 -
basedir="D:/devSoft/MySQLServer5.5/"
。 -
5)、[可选]临时目录
-
tmpdir="自己本地路径"
。 -
tmpdir="D:/devSoft/MySQLServer5.5/"
。 -
6)、[可选]数据目录
-
datadir="自己本地路径/Data/"
。 -
datadir="D:/devSoft/MySQLServer5.5/Data/"
。 -
7)、[可选]设置不要复制的数据库
-
binlog-ignore-db=mysql
。 -
8)、[可选]设置需要复制的数据库
-
binlog-do-db=需要复制的主数据库名字
。
2、从机配置(linux的my.cnf)
-
[必须]从服务器唯一ID;
-
[可选]启用二进制日志;
3、因修改过配置文件,请主机+从机都重启后台mysql服务
4、主从机都关闭linux防火墙
-
windows手动关闭;
-
关闭虚拟机linux防火墙
service iptables stop
;
5、在Windows主机上建立帐户并授权slave
-
GRANT REPLICATION SLAVE ON *.* TO 'zhangsan'@'从机器数据库IP' IDENTIFIED BY '123456';
。 -
刷新一下配置
flush privileges;
。 -
查询master的状态。
-
show master status;
-
记录下File和Position的值;
-
执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
总结
上述知识点,囊括了目前互联网企业的主流应用技术以及能让你成为“香饽饽”的高级架构知识,每个笔记里面几乎都带有实战内容。
很多人担心学了容易忘,这里教你一个方法,那就是重复学习。
打个比方,假如你正在学习 spring 注解,突然发现了一个注解@Aspect,不知道干什么用的,你可能会去查看源码或者通过博客学习,花了半小时终于弄懂了,下次又看到@Aspect 了,你有点郁闷了,上次好像在哪哪哪学习,你快速打开网页花了五分钟又学会了。
从半小时和五分钟的对比中可以发现多学一次就离真正掌握知识又近了一步。
人的本性就是容易遗忘,只有不断加深印象、重复学习才能真正掌握,所以很多书我都是推荐大家多看几遍。哪有那么多天才,他只是比你多看了几遍书。
点郁闷了,上次好像在哪哪哪学习,你快速打开网页花了五分钟又学会了。
从半小时和五分钟的对比中可以发现多学一次就离真正掌握知识又近了一步。
[外链图片转存中…(img-ABNRmONE-1712099764204)]
人的本性就是容易遗忘,只有不断加深印象、重复学习才能真正掌握,所以很多书我都是推荐大家多看几遍。哪有那么多天才,他只是比你多看了几遍书。