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. 第30章 部署 - Identity Server 4 中文文档(v1.0.0)

    您的身份服务器只是一个标准的ASP.NET Core应用程序,包括IdentityServer中间件.首先阅读有关发布和部署的官方Microsoft 文档(尤其是有关负载平衡器和代理的部分). 30. ...

  2. [心得] SQL Server Partition(表分區) 資料分佈探討

    最近在群裡有個朋友問了個問題是這樣的 用户表有一千多万行,主键是用户ID,我做了分区.但经常查询时,其它的表根据用户ID来关联,这样跨区查询,reads非常高.有什么好的处理办法?不分区的话,索引维护 ...

  3. .NET LINQ 实现跨数据库数据的整合

    如果要在不同的数据库之间,要把数据整合到一起,或者对数据进行统计分析的话,实现起来比较麻烦. 一般情况下我们第一时间想到的方法是通过前置机实现,在前置机上安装一个数据库和同步数据程序,定时的把数据同步 ...

  4. Linux命令行对文件某(些)行的提取

    [一]从第3000行开始,显示1000行.即显示3000~3999行 cat filename | tail -n +3000 | head -n 1000 [二]显示1000行到3000行 cat ...

  5. Dynamics CRM项目实例之六:积分管理,汇总字段,计算字段,快速查看视图

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复137或者20141228可方便获取本文,同时可以在第一时间得到我发布的最新的博文信息,follow me!        博文讲述的主要是如 ...

  6. Neutron server的运行原理(未完待续)

    1.Neutron server首先是一个web server, 对于http和https协议的报文进行响应. 2.Neutron server进程里面包含了一个WSGI 应用程序,以及不同模块的pl ...

  7. (简单)华为荣耀9i LLD-AL20的Usb调试模式在哪里开启的方法

    每当我们使用pc通过数据线连接上安卓手机的时候,如果手机没有开启Usb开发者调试模式,pc则没法成功检测到我们的手机,有时,我们使用的一些功能较好的应用如以前我们使用的一个应用引号精灵,老版本就需要开 ...

  8. 如何关闭tornado.web的Application

    研究热更新Python程序时,需要将已有的HTTP服务器重启. 我的HTTP服务器是用tornado.web.Application生成的,这样很简单: import tornado.web weba ...

  9. SQLServer之通过视图修改数据

    通过视图增删改数据注意事项 需要对目标表的 UPDATE.INSERT 或 DELETE 权限(取决于执行的操作). 如果视图引用多个基表,则不能删除行. 如果视图引用多个基表,只能更新属于单个基表的 ...

  10. windows下查看端口被占用及处理

    一.通过命令行查找端口被谁占用 1.window+R组合键,调出命令窗口 2.输入命令:netstat -ano,列出所有端口的情况.在列表中我们观察被占用的端口 3.查看被占用端口对应的PID,输入 ...