mariadb主从

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

mysql主从配置
yum配置
[mariadb]
name=MariaDB
baseurl=http://mirrors.ustc.edu.cn/mariadb/yum/10.3/centos7-amd64/
gpgkey=http://mirrors.ustc.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck=1 服务器1: MariaDB01 192.168.254.28

服务器2: MariaDB02 192.168.254.29

操作系统: CentOS7.3

数据库版本: MariaDB-10.3.7

主从关系: MariaDB01为主,MariaDB02为从 MariaDB01

1. 修改配置文件

vi /etc/my.cnf.d/server.cnf

在[mysqld]下加入以下

server-id=1

log-bin=mysql-bin 2. 重启mysql服务

service mysqld restart 3.创建主从连接帐号与授权

CREATE USER 'slave'@'%' IDENTIFIED BY 'slave';

GRANT REPLICATION SLAVE ON . TO 'slave'@'%';

flush privileges; 4.show master status MariaDB02

1. 修改配置文件

vi /etc/my.cnf.d/server.cnf
server-id=2
2. 重启mysql服务

service mysqld restart 3.登录数据库

mysql -uroot -proot4. 建立主从连接

CHANGE MASTER TO MASTER_HOST='192.168.254.28', MASTER_USER='slave', MASTER_PASSWORD='slave', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=1443;

start slave; 5.验证!!!

create database test01

use test01

create table students(id int(10), name char(20), age int(10))

之后查看从节点是否有test01数据库和students表 6.查看mysql二进制log

mysqlbinlog /var/lib/mysql/mysql-bin.000001

如果出现不同步可以执行以下步骤

stop slave

set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;

start slave

或者

stop slave;

mysql> change master to

master_host='192.168.254.28',

master_user='user',

master_password='pwd',

master_port=3306,

master_log_file='mysql-bin.000008',

master_log_pos=483;

start slave

mariadb galera集群(多主)

galera集群多用于关键性业务,因为galera集群为了数据的一致性,采用的是同步的机制,这就使galera牺牲了一部分性能来换取数据一致性。

实战Mariadb10.(.3自带galera软件) galera Cluster集群架构
Mariadb galera Cluster安装:
操作系统:Centos7.3版本
集群数量:3个节点
主机信息:
192.168.153.142 node1 selinux=disabled firewalld关闭
192.168.153.143 node2 selinux=disabled firewalld关闭
192.168.153.144 node3 selinux=disabled firewalld关闭 搭建步骤

.主机之间互相解析:三台节点都要执行

vim /etc/hosts

192.168.153.142 node1

192.168.153.143 node2

192.168.153.144 node3 .安装软件包

第一种方法:(yum install -y MariaDB-server MariaDB-client galera)

配置yum安装源和配置mariadb galera安装源

yum源配置挂iso

设置mariadb的yum源并安装(所有节点都要)

修改yum源文件

vi /etc/yum.repos.d/mariadb.repo

[mariadb]

name = MariaDB

baseurl = http://yum.mariadb.org/10.3.5/centos74-amd64

gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB

gpgcheck=

enabled=

安装galera软件时需要解决它的依赖包:boost-program-options.x86_64 (直接yum源安装即可) .mariadb初始化 (三个节点都需要执行)

安装完成后会提示需要对mariadb进行初始化(设置密码)

systemctl start mariadb

mysql_secure_installation (按提示设置mysql密码)

systemctl stop mariadb .配置galera

主节点配置文件server.cnf

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

[galera]

wsrep_on=ON

wsrep_provider=/usr/lib64/galera/libgalera_smm.so #galera的库文件的地址

wsrep_cluster_address="gcomm://192.168.153.142,192.168.153.143,192.168.153.144" #各节点的ip

wsrep_node_name=node1         #节点主机名  

wsrep_node_address=192.168.153.142 #节点ip

binlog_format=row          #二进制日志设置为行模式

default_storage_engine=InnoDB    #使用的默认引擎

innodb_autoinc_lock_mode=     #性能最好

wsrep_slave_threads= #并行复制线程数

innodb_flush_log_at_trx_commit= #.log buffer将每秒一次地写入log file中,并且log file的flush(刷到磁盘)操作同时进行。该模式下在事务提交的时候,不会主动触发写入磁盘的操作。

                     #:每次事务提交时MySQL都会把log buffer的数据写入log file,并且flush(刷到磁盘)中去,该模式为系统默认。

                     #:每次事务提交时MySQL都会把log buffer的数据写入log file,但是flush(刷到磁盘)操作并不会同时进行。该模式下,MySQL会每秒执行一次 flush(刷到磁盘)操作

innodb_buffer_pool_size=120M #设置缓存池大小

wsrep_sst_method=rsync #远程同步

wsrep_causal_reads=ON         #避免各个节点的数据不一致,这种情况需要等待全同步复制

将此文件复制到mariadb-、mariadb-,注意要把 wsrep_node_name 和 wsrep_node_address 改成相应节点的 hostname 和 ip。 .启动集群服务:

启动 MariaDB Galera Cluster 服务:
(第一次启动要用初始化:mysqld_safe --wsrep_cluster_address=gcomm://192.168.254.24,192.168.254.27,192.168.254.36 >/dev/null &)

[root@node1 ~]# /bin/galera_new_cluster

剩余两节点启动方式为:

[root@node1 ~]# systemctl start mariadb

查看集群状态:(集群服务使用了4567和3306端口))

[root@node1 ~]# netstat -tulpn | grep -e -e

tcp 0.0.0.0: 0.0.0.0: LISTEN /mysqld

tcp6 ::: ::: LISTEN /mysqld .验证集群状态:

在node1上执行:

[root@node1 ~]# mysql -uroot -p ##进入数据库

查看是否启用galera插件

连接mariadb,查看是否启用galera插件

MariaDB [(none)]> show status like "wsrep_ready";

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| wsrep_ready | ON |

+---------------+-------+

row in set (0.004 sec)

目前集群机器数

MariaDB [(none)]> show status like "wsrep_cluster_size";

+--------------------+-------+

| Variable_name | Value |

+--------------------+-------+

| wsrep_cluster_size | |

+--------------------+-------+

row in set (0.001 sec)

查看集群状态

MariaDB [(none)]> show status like "wsrep%";

+------------------------------+----------------------------------------------------------------+

| Variable_name | Value |

+------------------------------+----------------------------------------------------------------+

| wsrep_apply_oooe | 0.000000 |

| wsrep_apply_oool | 0.000000 |

| wsrep_apply_window | 1.000000 |

| wsrep_causal_reads | |

| wsrep_cert_deps_distance | 1.200000 |

| wsrep_cert_index_size | |

| wsrep_cert_interval | 0.000000 |

| wsrep_cluster_conf_id | |

| wsrep_cluster_size | | ##集群成员

| wsrep_cluster_state_uuid | b8ecf355-233a-11e8-825e-bb38179b0eb4 | ##UUID 集群唯一标记

| wsrep_cluster_status | Primary | ##主服务器

| wsrep_commit_oooe | 0.000000 |

| wsrep_commit_oool | 0.000000 |

| wsrep_commit_window | 1.000000 |

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

| wsrep_desync_count | |

| wsrep_evs_delayed | |

| wsrep_evs_evict_list | |

| wsrep_evs_repl_latency | //// |

| wsrep_evs_state | OPERATIONAL |

| wsrep_flow_control_paused | 0.000000 |

| wsrep_flow_control_paused_ns | |

| wsrep_flow_control_recv | |

| wsrep_flow_control_sent | |

| wsrep_gcomm_uuid | 0eba3aff--11e8-b45a-f277db2349d5 |

| wsrep_incoming_addresses | 192.168.153.142:,192.168.153.143:,192.168.153.144: | ##连接中的数据库

| wsrep_last_committed | | ##sql 提交记录

| wsrep_local_bf_aborts | | ##从执行事务过程被本地中断

| wsrep_local_cached_downto | |

| wsrep_local_cert_failures | | ##本地失败事务

| wsrep_local_commits | | ##本地执行的sql

| wsrep_local_index | |

| wsrep_local_recv_queue | |

| wsrep_local_recv_queue_avg | 0.057143 |

| wsrep_local_recv_queue_max | |

| wsrep_local_recv_queue_min | |

| wsrep_local_replays | |

| wsrep_local_send_queue | | ##本地发出的队列

| wsrep_local_send_queue_avg | 0.000000 | ##队列平均时间间隔

| wsrep_local_send_queue_max | |

| wsrep_local_send_queue_min | |

| wsrep_local_state | |

| wsrep_local_state_comment | Synced |

| wsrep_local_state_uuid | b8ecf355-233a-11e8-825e-bb38179b0eb4 | ##集群ID

| wsrep_protocol_version | |

| wsrep_provider_name | Galera |

| wsrep_provider_vendor | Codership Oy <info@codership.com> |

| wsrep_provider_version | 25.3.(r3789) |

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

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

| wsrep_received_bytes | |

| wsrep_repl_data_bytes | |

| wsrep_repl_keys | |

| wsrep_repl_keys_bytes | |

| wsrep_repl_other_bytes | |

| wsrep_replicated | | ##随着复制发出的次数

| wsrep_replicated_bytes | | ##数据复制发出的字节数

| wsrep_thread_count | |

+------------------------------+----------------------------------------------------------------+

rows in set (0.003 sec)

查看连接的主机

MariaDB [(none)]> show status like "wsrep_incoming_addresses";

+--------------------------+----------------------------------------------------------------+

| Variable_name | Value |

+--------------------------+----------------------------------------------------------------+

| wsrep_incoming_addresses | 192.168.153.142:,192.168.153.143:,192.168.153.144: |

+--------------------------+----------------------------------------------------------------+

row in set (0.002 sec) .测试集群mariad数据是否同步

MariaDB [(none)]> create database lizk;

Query OK, row affected (0.010 sec) MariaDB [(none)]> show databases;

+--------------------+

| Database |

+--------------------+

| china |

| hello |

| hi |

| information_schema |

| lizk |

| mysql |

| performance_schema |

| test |

+--------------------+

rows in set (0.001 sec)

在其他两个节点上可以查看lizk库已经同步。 注意:

如果galera_new_cluster 报错

vim /var/lib/mysql/grastate.dat

把safe_to_bootstrap更改为1

GALERA saved state

version: 2.1

uuid: a393feef-f639-11e8-9b89-4e75f9b8fb0f

seqno: -

safe_to_bootstrap:

mariadb集群配置(主从和多主)的更多相关文章

  1. MariaDB集群配置(主从和多主)

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

  2. redis sentinel 集群配置-主从切换

    1.配置redis master,redis slave(配置具体操作见上文http://www.cnblogs.com/wangchaozhi/p/5140469.html). redis mast ...

  3. mongodb集群配置主从模式

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 master-node 从服务器IP地址:192.168.197.22 slave-node 关闭 ...

  4. mariadb 数据库集群配置

    mariadb集群配置(主从和多主)   mariadb主从 主从多用于网站架构,因为主从的同步机制是异步的,数据的同步有一定延迟,也就是说有可能会造成数据的丢失,但是性能比较好,因此网站大多数用的是 ...

  5. mariadb集群与nginx负载均衡配置--centos7版本

    这里配置得是单nginx主机..先准备4台主机,三台mariadb集群,一台nginx. ------------------------------------------------------- ...

  6. Docker:docker搭建redis一主多从集群(配置哨兵模式)

    角色 实例IP 实例端口 宿主机IP 宿主机端口 master 172.19.0.2 6382 192.168.1.200 6382 slave01 172.19.0.3 6383 192.168.1 ...

  7. redis学习五 集群配置

    redis集群配置 0,整体概述      整体来说就是:      1,安装redis      2,配置多个redis实例      3,安装 ruby和rubygems      4,启动red ...

  8. mongoDB Replica集群配置(1主+1从+1仲裁)

    1.mongoDB节点介绍 主节点(Primary) 在复制集中,主节点是唯一能够接收写请求的节点.MongoDB在主节点进行写操作,并将这些操作记录到主节点的oplog中.而从节点将会从oplog复 ...

  9. redis主从同步故障切换及集群配置

    一.redis是一中高性能的缓存数据库, 原理:1. 从服务器向主服务器发送 SYNC 命令.2. 接到 SYNC 命令的主服务器会调用BGSAVE 命令,创建一个 RDB 文件,并使用缓冲区记录接下 ...

随机推荐

  1. 记一次vue长列表的内存性能分析和优化

    好久没写东西,博客又长草了,这段时间身心放松了好久,都没什么主题可以写了 上周接到一个需求,优化vue的一个长列表页面,忙活了很久也到尾声了,内存使用和卡顿都做了一点点优化,还算有点收获 写的有点啰嗦 ...

  2. webpack4.0各个击破(2)—— CSS篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  3. webpack4.0各个击破(9)—— karma篇

    webpack作为前端最火的构建工具,是前端自动化工具链最重要的部分,使用门槛较高.本系列是笔者自己的学习记录,比较基础,希望通过问题 + 解决方式的模式,以前端构建中遇到的具体需求为出发点,学习we ...

  4. Mybatis框架基础支持层——日志模块(8)

    前言: java开发中常用的日志框架有Log4j,Log4j2,Apache Commons Log,java.util.logging,slf4j等,这些工具对外的接口不尽相同.为了统一这些工具的接 ...

  5. 前端导出excel数据-jsonToExcel

    咳咳,好久没有写博了... 在工作中遇到了纯前端,将数据导出为excel文件.正文开始: 第一步 安装依赖: npm i xlsx 第二步 写导出函数: import XLSX from 'xlsx' ...

  6. 【代码笔记】Web-CSS-CSS Positioning

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  7. Microsoft Dynamics CRM 9.0 OP 版本 安装 的那些 雷

    天天讲安装过程好无聊了,还是搞点有营养的东西来,那么后面来说说刚出来的MSCRM OP 9.0 版本安装的那些雷: 雷1:操作系统要求Windows 2016 Server 这点还好,因为之前安装MS ...

  8. 从.Net到Java学习第十二篇——SpringBoot+JPA提供跨域接口

    从.Net到Java学习系列目录 最近又撸了半个月的前端代码,做app离线存储,然后又花了一周去将过去的wcf项目转webapi,java又被落下了,总感觉我特么像斗地主中的癞子牌,变来变去..... ...

  9. linux下执行QT可执行文件报错

    老样子,不多BiBi,直接进入主题! 有时候在linux下编译好QT程序,用QTCreator运行没问题,打包移植到另一台机器上,用命令./XX执行就会报错:error while loading s ...

  10. ASP.NET Core 入门教程 10、ASP.NET Core 日志记录(NLog)入门

    一.前言 1.本教程主要内容 ASP.NET Core + 内置日志组件记录控制台日志 ASP.NET Core + NLog 按天记录本地日志 ASP.NET Core + NLog 将日志按自定义 ...