MySQL主从集群配置

一、数据库集群技术:

1.集群由3个概念:

(1).sql节点  sql node

(2).数据节点 data node

(3).管理节点 ndb managerment

注:Sql语句发送"1sql节点", "1sql"节点发往"2数据节点",再由3管理节点完成数据节点的之间的同步,集群技术相对复杂,至少有3种节点,4台服务器才能完成

二、数据库复制 replication:

MySQL主从集群配置_第1张图片

1.数据库复制 replication 的实现原理

(1).主服务器凡运行语句,都产生一个二进制日志 binlog

(2).从服务器不断读取主服务器的binlog

(3).从主服务读取到的binlog,转换为自身可执行的relaylog

(4).执行relaylog

2.实现步骤:

(1).首先确保主服务器打开二进制日志功能,主服务器一旦有数据变化,立即产生二进制日志

(2).从服务器也需要开启二进制日志和relay日志功能,这样可以从主服务器读取binlog,并产生relaylog

(3).在主服务器建立一个从服务器的账号,并授予数得上权限

(4).指定从服务对应的主服务器,开启从服务器

3.具体实施 :

本人虚拟机下有两台linux,IP为199 200

(1).200做从服务器

(2).199做主服务器

(3).保证主从3306端口互通

(4).配置主服务器,打开binlog

#给服务器起一个唯一的id

server-id=1

#开启二进制日志

log-bin=mysql-bin

#指定日志格式

binlog-format=mixd/row/statement

重启mysql

MySQL主从集群配置_第2张图片

已经能够充当master服务器

(5).配置从服务器打开binlog和relaylog

MySQL主从集群配置_第3张图片

重启从服务器

(6).在主服务器上创建相应的复制账号

(7).在从服务器通过语句指定要复制的主服务器(注意,可以一主多从,不可一从多主).

MySQL主从集群配置_第4张图片

(8).启动从服务器功能

->start slave;

MySQL主从集群配置_第5张图片

4.常用语句:

show master status ; 查看master的状态, 尤其是当前的日志及位置

show slave stattus; 查看slave的状态.

reset slave ;  重置slave状态.

start slave ; 启动slave 状态(开始监听msater的变化)

stop slave; 暂停slave状态;

5.binlog_format的3种类型:statement、row、mixed3种,其中mixed是指前2种的混合

(1).以insert into xxtable values (x,y,z)为例:

影响: 1行,且为新增1行, 对于其他行没有影响.

这个情况,用row格式,直接复制磁盘上1行的新增变化.

(2).以update xxtable set age=21 where name='sss'为例:

这个情况,一般也只是影响1行,用row也比较合适.

(3).以过年发红包,全公司的人,都涨薪100元.

update xxtable set salary=salary+100;

这个语句带来的影响,是针对每一行的, 因此磁盘上很多row都发生了变化.

此处,适合就statment格式的日志.

注:2种日志,各有各的高效的地方,mysql提供了mixed类型,可以根据语句的不同,而自动选择适合的日志格式

你可能感兴趣的:(MySQL主从集群配置)