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. Python之文件和目录操作

    1.文件基本操作 python内置了打开文件的函数open(),使用规则如下:   File_object=open(filename[,access_mode][,buffering]) Filen ...

  2. WPF DesiredSize & RenderSize

    DesiredSize DesiredSize介绍 关于DesiredSize的介绍,可以查看最新微软文档对DesiredSize的介绍 DesiredSize,指的是元素在布局过程中计算所需要的大小 ...

  3. Android开发——Notification通知的各种Style详解

    本来是想与之前讲解使用Notification通知使用一起写的,查看了资料,觉得有必要将这Style部分单独拿出来讲解 前篇:Android开发——Notification通知的使用及Notifica ...

  4. Java设计模式之【工厂模式】(简单工厂模式,工厂方法模式,抽象工厂模式)

    Java设计模式之[工厂模式](简单工厂模式,工厂方法模式,抽象工厂模式) 工厂模式出现的原因 在java中,创建一个对象最简单的方法就是使用new关键字.但在一些复杂的业务逻辑中,创建一个对象不只需 ...

  5. jsp基础语言-jsp注释

    JSP注释可分为客户端注释和服务器端注释. 客户端注释:用户可通过浏览器中的源代码查看,且这种注释可以加入JSP表达式. 语法:<!-- 客户端注释[<%=表达式%>] --> ...

  6. 欧洲AI规范先行,值得肯定与借鉴 --- 我看欧盟发布AI道德规范

    欧洲AI规范先行,值得肯定与借鉴 --- 我看欧盟发布AI道德规范 [事件回放] 近日,据外媒报道,欧盟委员会(EC)任命的人工智能高级专家小组发布了AI开发和使用的道德草案,内容长达37页,提出可信 ...

  7. 设置抓包工具Fiddler的host

    大家都知道在电脑本地上有一个Host文件. Hosts文件主要作用是定义IP地址和主机名的映射关系,是一个映射IP地址和主机名的规定.可以用文本文件打开!当用户在浏览器中输入一个需要登录的网址时,系统 ...

  8. 多层json的构造,取值,还有使用bootstrap的tree view在前端展示的相关问题

    bootstrap-tree view是一款非常好用的插件,它可以添加任意多层节点,效果如下所示: 使用之前需要在HTML页面添加依赖文件: <link href="bootstrap ...

  9. SQL Server Log Shipping学习总结

      SQL Server的日志传送(log shipping)技术一直比较鸡肋,尤其当SQL Server 推出了Always On技术以后,估计使用日志传送(log shipping)这种技术方案的 ...

  10. python 迭代器协议和生成器

    一.什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个stoplteration异常,以终止迭代(只能往后走,不能往前退) 2.可迭代 ...