一、安装环境准备

  1、系统:

    CentOS Linux release 7.4.1708 (Core)

  2、hosts

    10.6.32.51  openstack1

    10.6.32.52  openstack2

    10.6.32.53  openstack3

  3、关闭防火墙和Selinux

  4、同步时间:

    博客:http://www.cnblogs.com/weijie0717/p/8549204.html

  5、查看和卸载 系统原有的 mariadb、mysql (必须卸载,否则后期会有问题):

    #  rpm -qa | grep -i maria

    #  rpm -qa | grep -i mysql

    #  yum remove mariiadb

    #  yum remove mysql 

二、集群部署

  1、包安装

    # yum install  MariaDB-Galera-server galera

    # yum install percona-xtrabackup -y

    #  yum install perl-Time-HiRes.x86_64  socat percona-toolkit -y

  2、修改基础配置文件 (所有节点操作)

      # cp /usr/share/mysql/my-medium.cnf /etc/my.cnf

      # vim /etc/my.cnf        

注释以下行:
binlog_format=mixed
server-id =

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

添加或取消注释如下行:
[mysqld]
#....
datadir=/var/lib/mysql
log-error=/var/log/mysqld.log [galera]
#...
binlog_format=row
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=2

  3、启动服务,修改密码  (节点1操作)

    # systemctl start mysql   

    # mysql     # mariadb 默认没有密码,可以直接进入

    MariaDB [(none)]> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass');

    MariaDB [(none)]> GRANT ALL ON  *.* TO 'galera'@'localhost' IDENTIFIED BY 'yourpasswd';   (添加用户:galera,后期集群配置文件用到 )

  4、配置集群文件 (所有节点)

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

添加如下行,红色字体为个节点的差异配置,和自定义配置。
bind-address=10.6.32.51
server-id=101
wsrep_cluster_name=openstack_cluster
wsrep-provider=/usr/lib64/galera/libgalera_smm.so
wsrep_node_name = openstack1
wsrep_cluster_address=gcomm://10.6.32.51,10.6.32.52,10.6.32.53
wsrep_node_address=10.6.32.51
wsrep_provider_options =gmcast.listen_addr=tcp://10.6.32.51:4567
wsrep_sst_donor=openstack1,openstack2,openstack3
wsrep_sst_method=xtrabackup-v2 #集群数据同步方式( xtrabackup-v2或rsync 都需要安装所匹配的插件)
wsrep_sst_auth=galera:yourpasswd
slow_query_log=on

  5、集群启动

    a、当集群中还没有节点启动时,确认所有节点上没有mysql进程,如果有请关闭。(所有节点操作)

      # ps -aux | grep mysql

      # kill -9 mysql-id

    b、启动集群中第一个节点。(openstack1 上操作)  

      #   /usr/libexec/mysqld  --wsrep-new-cluster     (当且仅当 集群中没有任何节点开启,启动第一个节点时使用)

    c、启动其他节点,逐台启动,然后查看集群状态

      # systemctl start mysqld    (集群中有节点后就可以正常启动。openstack2 和openstack3 上依次启动,启动一台查看依次集群状态)

      

    d、重新启动第一个节点的数据库(opoenstsck1上操作)

      # kill -i mysq-id    (因为第一次为非正常启动,需要使用kill 杀掉进程来关闭mysql)

      # systemctl restart mysqld

        (如果重启失败,请查看/var/lib/mysql/mysql.sock.lock 是否存在,如果存在,删除后重新启动。)

    e、在各节点使用 数据同步用户galera登录,如果可以正常启动并登录成功。到此,Galera Cluster 已经成功部署。

 三、测试

  参考:Centos 7 下 Mysql 5.7 Galera Cluster 集群部署

  

  谢谢!!!

Centos 7 MariaDB Galera cluster 部署的更多相关文章

  1. MariaDB Galera Cluster部署手册

    MariaDB Galera Cluster部署手册 galara保证双主数据库的同步及一致性 1.环境准备 基于新部署.最小化安装centos6.5 1>  yum install opens ...

  2. MariaDB Galera Cluster 部署(如何快速部署MariaDB集群)

    MariaDB Galera Cluster 部署(如何快速部署MariaDB集群) [日期:--] 来源:Linux社区 作者:Linux [字体:大 中 小] MariaDB作为Mysql的一个分 ...

  3. MariaDB Galera Cluster 部署(如何快速部署 MariaDB 集群)

    MariaDB Galera Cluster 部署(如何快速部署 MariaDB 集群)  OneAPM蓝海讯通7月3日 发布 推荐 4 推荐 收藏 14 收藏,1.1k 浏览 MariaDB 作为 ...

  4. MariaDB Galera Cluster 部署 + keepalived实现高可用

    MariaDB Galera Cluster 部署 MariaDB作为Mysql的一个分支,在开源项目中已经广泛使用,例如大热的openstack,所以,为了保证服务的高可用性,同时提高系统的负载能力 ...

  5. MariaDB Galera Cluster 部署

    原文  http://code.oneapm.com/database/2015/07/02/mariadb-galera-cluster/MariaDB作为Mysql的一个分支,在开源项目中已经广泛 ...

  6. MariaDB Galera Cluster部署实践

    原理 官方地址:http://galeracluster.com/documentation-webpages/index.html Galera Cluster与传统的复制方式不同,不通过I/O_t ...

  7. 【原】基于 HAproxy 1.6.3 Keeplived 在 Centos 7 中实现mysql mariadb galera cluster 集群分发读写 —— 上篇

    前言 有一段时间没有写blogs,乘着周末开始整理下haproxy + keeplived 实现 mysql mariadb galera cluster 集群访问环境的搭建工作. 本文集中讲hapr ...

  8. Mariadb Galera Cluster 群集 安装部署

    #Mariadb Galera Cluster 群集 安装部署 openstack pike 部署  目录汇总 http://www.cnblogs.com/elvi/p/7613861.html # ...

  9. MariaDB Galera Cluster集群搭建

    MariaDB Galera Cluster是什么?   Galera Cluster是由第三方公司Codership所研发的一套免费开源的集群高可用方案,实现了数据零丢失,官网地址为http://g ...

随机推荐

  1. url查询参数解析

    url查询参数解析 1.获取url的各部分值 举例http://i.cnblogs.com/EditPosts.aspx?opt=1 1.window.location.href(设置或获取整个 UR ...

  2. eclipse gradle插件 org.gradle.tooling.GradleConnectionException: Could not install Gradle distribution from 'https://services.gradle.org/distributions/gradle-3.4-bin.zip'.

    eclipse安装gradle后出现如下异常: org.gradle.tooling.GradleConnectionException: Could not install Gradle distr ...

  3. Linux下源码编译安装PostgreSQL数据库

    我使用的Postgres的源码版本为 postgresql-9.3.5.系统为 CentOS6.5 ,是64位. 下载以后直接阅读其中的 README然后阅读其中的INSTALL,按照其中将的步骤做就 ...

  4. 基于Redis的Spring cache 缓存介绍

    目录 Cache API及默认提供的实现 demo 依赖包安装 定义实体类.服务类和相关配置文件 Cache注解 启用Cache注解 @CachePut @CacheEvict @Cacheable ...

  5. HashMap.put()和get()原理

    /** * Returns the value to which the specified key is mapped, * or if this map contains no mapping f ...

  6. mysql 日期时间运算函数

    时期时间函数 DAYOFWEEK(date) 返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1998-02-0 ...

  7. Linux:条件变量

    条件变量:     条件变量本身不是锁!但它也可以造成线程阻塞.通常与互斥锁配合使用.给多线程提供一个会合的场所. 主要应用函数:     pthread_cond_init函数     pthrea ...

  8. RabbitMQ系列教程之二:工作队列(Work Queues)(转载)

    RabbitMQ系列教程之二:工作队列(Work Queues)     今天开始RabbitMQ教程的第二讲,废话不多说,直接进入话题.   (使用.NET 客户端 进行事例演示)          ...

  9. openwrt多wan限上下行速脚本,基于qosv4,imq模块替换成ifb模块[ZT]

    转自: http://www.right.com.cn/forum/thread-169414-1-1.html ,本人未经测试,转来自已备用 由于树莓派2装openwrt官方没有imq模块, 好像说 ...

  10. AnimCheckBox按钮点击动画效果《IT蓝豹》

    AnimCheckBox按钮点击动画效果 AnimCheckBox按钮点击动画效果,点击选中后勾选框选择效果,很不错的动画功能.项目来源:https://github.com/lguipeng/Ani ...