主从架构

  • 异步同步:效率高,安全性低,有延迟
  • 实时同步:效率低,安全性高,无延迟
  • 主节点:可读可写 (dump thread)
  • 从节点:只读不写 (sql thread, i/o thread)

原理:

从库生成两个线程,一个I/O线程,一个SQL线程;

i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中;

主库会生成一个 log dump 线程,用来给从库 i/o线程传binlog;

SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

主节点单点故障解决方案:

1.主主架构

互为主备,互相监控对方二进制日志文件进行同步

注意:当两个sql语句发生冲突的时候主主架构有可能出现数据不一致的现象

2.MHA(master high avalible)

需要多一台机器装上MHA,监控主从架构,当主节点宕了,会挑选数据与主节点最相近的从节点充当主节点。

MHA可以有多个配置文件,一个配置文件监控一个主从架构。

配置:

node1: 192.168.132.120

node2:192.168.132.121

主从关系:node1为主,node2为从

主节点

1. 修改配置文件

vim
/etc/my.cnf.d/server.cnf

在[mysqld]下加入以下

server-id=1

log-bin=mysql-bin

2. 重启mysql服务

systemctl restart mariadb

3.创建主从连接帐号与授权(sql命令行)

grant
replication slave on *.* to 'slave'@'%' identified by 'slave';

flush
privileges;

4.show
master status

从节点

1. 修改配置文件

vim
/etc/my.cnf.d/server.cnf

server-id=2

2. 重启mysql服务

service
mysqld restart

3.登录数据库

mysql
-uroot -proot

4. 建立主从连接

change
master to master_host='192.168.132.120', master_user='slave',
master_password='slave', master_log_file='mysql_bin.000001', master_log_pos=637;

#用的是当前的二进制日志文件与position

start
slave;      #同时启动I/O
线程和SQL线程

show slave
status\G      #\G竖排查看,后面不能再加分号

#如果Slave_IO_Running与 Slave_SQL_Running均为yes,则主从架构成功

可能出现的报错及解决方法:

报错1:

ERROR 1198
(HY000): This operation cannot be performed as you have a running slave ''; run
STOP SLAVE '' first

stop slave

执行建立主从连接的命令

start slave

报错2:

Got fatal
error 1236 from master when reading data from binary log: 'Could not find first
log file name in binary log index file'

stop slave;

reset
slave;

start slave

galera简介

  • galera集群又叫多主集群,用于数据库的同步,保证数据安全
  • 最少3台,最好是奇数台数,当一台机器宕掉时,因为仲裁机制,这台机器就会被踢出集群。
  • 通过wsrep协议监控其它节点状态
  • 实时同步,当一个事务在一台机器提交,所有机器同时提交。效率低,但是安全性高

galera集群搭建

准备

三台机器:

192.168.132.120

192.168.132.131

192.168.132.134

防火墙为开启状态,添加防火墙端口

setenforce
firewall-cmd --add-port=/tcp
firewall-cmd --add-port=/tcp
firewall-cmd --add-port=/tcp

配置

第一步:编辑配置文件

vim /etc/my.cnf.d/server.cnf
[galera]
wsrep_on=ON
wsrep_provider=/usr/lib64/galera/libgalera_smm.so #库文件
wsrep_cluster_address="gcomm://192.168.132.120,192.168.132.131,192.168.132.134"
binlog_format=row #二进制日志指定为行模式,精确

第二步:初始化

其中1个节点执行,关机重启不需要再初始化,初始化一次就行。

mysqld_safe --wsrep_cluster_address=gcomm://192.168.132.120,192.168.132.131,192.168.132.134     #等待大约一分钟

第三步:启动数据库

执行初始化的节点:
systemctl stop mariadb
galera_new_cluster
其它节点:
systemctl restart mariadb

如果数据库启动失败,

vim /var/lib/mysql/grastate.dat

查看UUID是否是集群的UUID,如果不是需要手动修改为集群的UUID之后在启动

集群的UUID从执行初始化的节点查看

第四步:查看状态

show status like '%wsrep%';

关键参数:

wsrep_cluster_size | 3 | ##集群成员

wsrep_cluster_status | Primary | ##主服务器

wsrep_connected | ON | ##当前是否连接中

wsrep_incoming_addresses | 192.168.132.120:3306,192.168.132.131:3306,192.168.132.134:3306 | ##连接中的数据

wsrep_ready | ON | ##插件是否应用中

wsrep_cluster_state_uuid | b8ecf355-233a-11e8-825e-bb38179b0eb4 | ##UUID 集群唯一标记,每个节点UUID相同

| wsrep_received | 35 | ##数据复制接收次数

注意

如果启动集群出错可参考以下方案

哪个节点最后关闭,就在哪个节点执行galera_new_cluster,其余节点systemctl start mariadb

可以查看/var/lib/mysql/grastate.dat文件的safe_to_bootstrap: 1参数,如果为1代表此节点最后关闭

搭建数据库galera集群的更多相关文章

  1. Linux下MySQL/MariaDB Galera集群搭建过程【转】

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  2. Linux下MySQL/MariaDB Galera集群搭建过程

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  3. 使用GTID给Galera集群做数据库异步复制

    一.为什么要做Galera集群异步复制 Galera集群解决了数据库高可用的问题,但是存在局限性,例如耗时的事务处理可能会导致集群性能急剧下降,甚至出现阻塞现象.而不幸的是,类似报表等业务需求就需要做 ...

  4. 基于keepalived搭建MySQL热机集群

    背景 MySQL的高可用方案一般有如下几种: keepalived+双主,MHA,MMM,Heartbeat+DRBD,PXC,Galera Cluster 比较常用的是keepalived+双主,M ...

  5. mysql主从配置和galera集群

    mariadb主从 主从多用于网站架构,因为主从的同步机制是异步的,数据的同步有一定延迟,也就是说有可能会造成数据的丢失,但是性能比较好,因此网站大多数用的是主从架构的数据库,读写分离必须基于主从架构 ...

  6. Docker 版ansible galera集群

    1. 部署galera集群 利用四台主机cicd.node1.node2.node3来搭建galera集群. 1> 上传压缩包至cicd,解压得到ansible配置文件 [root@cicd ~ ...

  7. mysql基础之mariadb galera集群(多主)

    一.概念 galera集群多用于关键性业务,因为galera集群为了数据的一致性,采用的是同步的机制,这就使galera牺牲了一部分性能来换取数据一致性. galera集群是基于wsrep协议(端口4 ...

  8. Linux下搭建Lotus Domino集群

    Linux下搭建Lotus Domino 集群 本文内容是Linux平台下Lotus Domino服务器部署案例(http://chenguang.blog.51cto.com/350944/1334 ...

  9. MariaDB Galera集群部署--技术流ken

    Galera集群介绍 MariaDB集群是MariaDB同步多主机集群.它仅支持XtraDB/ InnoDB存储引擎. 主要功能 同步复制 真正的multi-master,即所有节点可以同时读写数据库 ...

随机推荐

  1. mybatis 源码分析(六)StatementHandler 主体结构分析

    分析到这里的时候,mybatis 初始化.接口.事务.缓存等主要功能都已经讲完了,现在就还剩下 StatementHandler 这个真正干活的家伙没有分析了:所以接下来的博客内容主要和数据库的关系比 ...

  2. Unity之SDK接入(Unity与Android通信)

    首先介绍一点关于Android与unity通信的知识: 完成通信主要靠unity中的class.jar包(在unity的安装目录下). 在unity中调用android的方法: jo.call(&qu ...

  3. .Net之微信小程序获取用户UnionID

    前言: 在实际项目开发中我们经常会遇到账号统一的问题,如何在不同端或者是不同的登录方式下保证同一个会员或者用户账号唯一(便于用户信息的管理).这段时间就有一个这样的需求,之前有个客户做了一个微信小程序 ...

  4. JSP学习笔记(1)——Jsp指令、动作元素和内置对象

    简单来说,javaweb技术就是让服务器端能够执行Java代码,之后返回数据给客户端(浏览器)让客户端显示数据 jsp页面中可以嵌套java代码(java小脚本)和嵌套Web前端(html,css,j ...

  5. MySql优化相关概念的理解笔记

    MySQL架构 查询执行流程 查询执行的流程是怎样的: 连接1.1客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求1.2将请求转发到‘连接进/线程模块’1.3调用‘用户模块’来进行授 ...

  6. VMware虚拟机安装Linux系统详细教程

    VMware14虚拟机安装RedHad6系统步骤 redhat网盘资源:链接:https://pan.baidu.com/s/1GlT20vevqbZ9qTxsGH1ZzA 提取码:oh57 如果网盘 ...

  7. ACM-ICPC 2017 Asia Urumqi:A. Coins(DP) 组合数学

    Alice and Bob are playing a simple game. They line up a row of nn identical coins, all with the head ...

  8. CodeForces Round 521 div3

    A:Frog Jumping 代码: #include<bits/stdc++.h> using namespace std; #define Fopen freopen("_i ...

  9. webstrom 内存溢出,软件崩溃卡死解决的方法

    今天用gulp搭建了一个工程,准备做一个体育h5的项目,其中需要用到sass代码压缩,加版本号等功能. gulpfile.js和package.json都是已经写好的.我用CMD命令窗口cnpm安装n ...

  10. 【Offer】[22] 【链表中倒数第k个结点】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 输入一个链表,输出该链表中倒数第k个结点. 思路分析 采用双指针的方法,第一个指针首先向前移动k-1个位置,第二个指针指向头节点,然后将 ...