之前搭建过一个Mysql Ndb cluster集群,但是mysql版本是5.7的,看到官网上mysql8的还是开发者版本,所以尝试搭建下mysql Innodb cluster集群。

  • MySQL的高可用架构无论是社区还是官方,一直在技术上进行探索,这么多年提出了多种解决方案,比如MMMMHANDB ClusterGalera ClusterInnoDB Cluster, 腾讯的PhxSQLMySQL Fabric ,aliSQL
  • NDB:基于集群的引擎-数据被自动切分并复制到数个机器上(数据节点), 适合于那些需要极高查询性能和高可用性的应用, 原来是为爱立信的电信应用设计的。 NDB提供了高达99.999%的可靠性,在读操作多的应用中表现优异。 对于有很多并发写操作的应用, 还是推荐用InnoDB
  • 本次部署采用InnoDB Cluster. 每台服务器实例都运行MySQL Group Replication(冗余复制机制,内置failover
  • MGR有两种模式,一种是Single-Primary,一种是Multi-Primary,即单主或者多主。
  • 注意:Multi-Primary模式中,所有的节点都是主节点,都可以同时被读写,看上去这似乎更好,但是因为多主的复杂性,在功能上如果设置了多主模式,则会有一些使用的限制,比如不支持Foreign Keys with Cascading Constraints。

一.工作原理

MySQL InnoDB集群提供了一个集成的,本地的,HA解决方案。Mysq Innodb Cluster是利用组复制的 pxos 协议,保障数据一致性,组复制支持单主模式和多主模式。

MySQL InnoDB集群由以下几部分组成:
-   MySQL Servers with Group Replication:向集群的所有成员复制数据,同时提供容错、自动故障转移和弹性。MySQL Server 5.7.17或更高的版本。
-   MySQL Router:确保客户端请求是负载平衡的,并在任何数据库故障时路由到正确的服务器。MySQL Router 2.1.3或更高的版本。
-   MySQL Shell:通过内置的管理API创建及管理Innodb集群。MySQL Shell 1.0.9或更高的版本。

各个组件的关系和工作流程如下:

二.集群方案

我创建了四台虚拟机,一台用来负责管理,另外三台是主从节点,一个主,两个从。

管理节点安装mysql-shell和mysql-router,主从节点三个均安装mysql和mysql-shell

后期名称都改为:manager,master和slave1,slave2

mysql,mysql shell 和mysql router的安装包如下:

mysql:mysql-8.0.17-linux-glibc2.12-x86_64.tar.xz

mysql-shell:mysql-shell-8.0.17-linux-glibc2.12-x86-64bit.tar.gz

mysql-router:mysql-router-8.0.17-linux-glibc2.12-x86_64.tar.xz

根据官方的文档 https://dev.mysql.com/doc/refman/8.0/en/mysql-innodb-cluster-userguide.html,mysql-shell需要python环境,至少在2.7版本以上,所以在安装使用前,需要提前部署好python环境。

三.环境准备(所有服务器都要操作)

1.关闭防火墙,关闭方法因系统不同,所以不列出

2.关闭selinux(Centos),关闭方法因系统不同,所以不列出

3.修改/etc/hosts文件,将四台服务器的ip分别映射成manager,master和slave1,slave2

4.优化配置

  1. [root@localhost ~]# cat>>/etc/sysctl.conf <<EOF
  2. fs.aio-max-nr =
  3. fs.file-max =
  4. kernel.shmmax =
  5. kernel.shmmni =
  6. kernel.sem =
  7. net.ipv4.ip_local_port_range =
  8. net.core.rmem_default =
  9. net.core.rmem_max =
  10. net.core.wmem_default =
  11. net.core.wmem_max =
  12. EOF
  13.  
  14. [root@localhost ~]# sysctl -p
  15.  
  16. [root@localhost ~]# cat>>/etc/security/limits.conf <<EOF
  17. mysql soft nproc
  18. mysql hard nproc
  19. mysql soft nofile
  20. mysql hard nofile
  21. EOF
  22.  
  23. [root@localhost ~]# cat>>/etc/pam.d/login <<EOF
  24. session required /lib/security/pam_limits.so
  25. session required pam_limits.so
  26. EOF
  27.  
  28. [root@localhost ~]# cat>>/etc/profile<<EOF
  29. if [ $USER = "mysql" ]; then
  30. ulimit -u -n
  31. fi
  32. EOF
  33.  
  34. [root@localhost ~]# source /etc/profile

四.在主节点安装mysql和mysql-shell

1.解压安装包

  1. tar xvf mysql-8.0.-linux-glibc2.-x86_64.tar.xz
  2. tar zxvf mysql-shell-8.0.-linux-glibc2.-x86-64bit.tar.gz
  3. mv mysql-8.0.-linux-glibc2.-x86_64 /usr/local/mysql/
  4. mv zxvf mysql-shell-8.0.-linux-glibc2.-x86-64bit /usr/local/mysql-shell/

2.添加用户并赋权

  1. groupadd mysql
  2. useradd -g mysql mysql
  3. cd /usr/local/mysql/
  4. mkdir data
  5. cd ..
  6. chown -R mysql:mysql mysql

3.修改环境变量

  1. vi /etc/profile
    ..........
  2. export PATH=$PATH:/usr/local/mysql-shell/bin/:/usr/local/mysql/bin/
    source /etc/profile

4.在/etc/下增加配置文件my.cnf

  1. [mysqld]
  2. character-set-server=utf8
  3. port=
  4. socket=/tmp/mysql.sock
  5. basedir=/usr/local/mysql
  6. datadir=/usr/local/mysql/data
  7. log-error=/usr/local/mysql/data/mysqld.log
  8. pid-file=/usr/local/mysql/data/mysql.pid
  9. user = mysql
  10. tmpdir = /tmp
  11. default-storage-engine=INNODB
  12.  
  13. #复制框架
  14. server_id=
  15. gtid_mode=ON
  16. enforce_gtid_consistency=ON
  17. master_info_repository=TABLE
  18. relay_log_info_repository=TABLE
  19. binlog_checksum=NONE
  20. log_slave_updates=ON
  21. log_bin=binlog
  22. binlog_format=ROW
  23. max_connections=
  24. max_allowed_packet=16M
  25.  
  26. #组复制设置
  27. #server必须为每个事务收集写集合,并使用XXHASH64哈希算法将其编码为散列
  28. transaction_write_set_extraction=XXHASH64
  29. #告知插件加入或创建组命名,UUID
  30. loose-group_replication_group_name="aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"
  31. #server启动时不自启组复制,为了避免每次启动自动引导具有相同名称的第二个组,所以设置为OFF。
  32. loose-group_replication_start_on_boot=off
  33. #告诉插件使用IP地址,端口33061用于接收组中其他成员转入连接
  34. loose-group_replication_local_address="master:33061"
  35. #启动组server,种子server,加入组应该连接这些的ip和端口;其他server要加入组得由组成员同意
  36. loose-group_replication_group_seeds="master:33061,slave1:33061,slave2:33061"
  37. loose-group_replication_ip_whitelist="master,slave1,slave2,manager"
  38. loose-group_replication_bootstrap_group=off
  39. # 使用MGR的单主模式
  40. loose-group_replication_single_primary_mode=on
  41. loose-group_replication_enforce_update_everywhere_checks=off
  42. disabled_storage_engines = MyISAM,BLACKHOLE,FEDERATED,CSV,ARCHIVE

5.安装mysql

  1. /usr/local/mysql/bin/mysqld --initialize-insecure --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

6.进入到mysql的base目录,设置开机自启动

  1. #加入到service服务
  2. cp support-files/mysql.server /etc/init.d/mysqld
  3. chmod +x /etc/init.d/mysqld
  4.  
  5. #加入到开机自启动列表
  6. chkconfig --add mysqld

7.登陆mysql,修改登陆密码(这里因为是不安全安装,所以密码为空,没有默认密码,登陆后直接回车就可以进入客户端页面)

  1. mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '';

五.创建cluster集群

1.进到master的 mysql-shell 的安装目录,登陆mysql-shell

  1. bin/mysqlsh
  1. mysql-js> shell.connect('root@localhost:3306');
  2. #连接成功后
  3. #配置实例
  4. dba.configureLocalInstance();
  5. #此时会让选择创建管理cluster的用户,我选1,使用root管理,并且允许远程登陆“%”
  6. #接着查看实例状态
  7. dba.checkInstanceConfiguration("root@localhost:3306");

如果出现:

  1. You can now use it in an InnoDB Cluster.
  2.  
  3. {
  4. "status": "ok"
  5. }

说明配置成功。

2.登陆manager管理节点,讲router和shell都解压到/usr/local/文件夹下分别为mysql-route和mysql-shell

3.登陆manager节点的shell,连接master,创建cluster

  1. bin/mysqlsh
  2.  
  3. # 连接01
  4. mysql-js> shell.connect('root@master:3306');
  5.  
  6. # 创建一个 cluster,命名为 'myCluster'
  7. mysql-js> var cluster = dba.createCluster('myCluster');
  8.  
  9. # 创建成功后,查看cluster状态
  10. mysql-js> cluster.status();

创建后,可以看到master已经添加进cluster,并且状态是读写,我这里用别人的状态图,表示一下:

  1. mysql-js> cluster.status();
  2. {
  3. "clusterName": "myCluster",
  4. "defaultReplicaSet": {
  5. "name": "default",
  6. "primary": "master:3306",
  7. "status": "OK_NO_TOLERANCE",
  8. "statusText": "Cluster is NOT tolerant to any failures.",
  9. "topology": {
  10. "master:3306": {
  11. "address": "master:3306",
  12. "mode": "R/W",
  13. "readReplicas": {},
  14. "role": "HA",
  15. "status": "ONLINE"
  16. }
  17. }
  18. }
  19. }

4.添加slave1节点

和上面一样的方法,先安装好mysql和mysql-shell,注意配置文件中server_id需要改成

  1. server_id=

同时,

  1. loose-group_replication_local_address="slave1:33061"

登陆shell,执行配置

  1. bin/mysqlsh
  2.  
  3. mysql-js> shell.connect('root@localhost:3306');
  4. mysql-js> dba.configureLocalInstance();

停掉mysql服务,在配置文件my.cnf末尾添加配置:

  1. loose-group_replication_allow_local_disjoint_gtids_join=ON

重启mysql后,通过manager节点的shell,将slave1添加到cluster:

  1. # 添加实例
  2. cluster.addInstance('root@slave1:3306');
  3.  
  4. # 创建成功后,查看cluster状态
  5. mysql-js> cluster.status();

成功后状态:

  1. mysql-js> cluster.status();
  2. {
  3. "clusterName": "myCluster",
  4. "defaultReplicaSet": {
  5. "name": "default",
  6. "primary": "master:3306",
  7. "status": "OK_NO_TOLERANCE",
  8. "statusText": "Cluster is NOT tolerant to any failures.",
  9. "topology": {
  10. "master:3306": {
  11. "address": "master:3306",
  12. "mode": "R/W",
  13. "readReplicas": {},
  14. "role": "HA",
  15. "status": "ONLINE"
  16. },
  17. "slave1:3306": {
  18. "address": "slave1:3306",
  19. "mode": "R/O",
  20. "readReplicas": {},
  21. "role": "HA",
  22. "status": "ONLINE"
  23. }
  24. }
  25. }
  26. }

5.和slave1一样,添加slave2节点,注意server_id和loose-group_replication_local_address需要修改成3和slave2:33061

六.安装mysql-router

在manager节点上,安装router:

  1. /usr/local/mysql-route/bin/mysqlrouter --bootstrap root@master: -d myrouter --user=root

这里会在当前目录下产生mysql-router 目录, 并生成router配置文件,默认通过route连接mysql后, 6446端口连接后可以进行读写操作. 6447端口连接后只能进行只读操作.

然后启动mysql-route

  1. myrouter/start.sh

查看route进程:

  1. ps -ef|grep myroute
  1. netstat -tunlp|grep routepid
这样就可以使用MySQL客户端连接router了.  下面验证下连接router:
 
a) 管理节点本机mysql-shell连接:
  1. mysqlsh --uri root@localhost:
b) 管理节点本机mysql连接:
  1. mysql -u root -h 127.0.0.1 -P -p
c) 远程客户机通过route连接mysql
  1. mysql -u root -h manager_ip -P -p

七.验证cluster集群

1.登陆后,新建一个表,往里面写进数据,查看从节点数据会不会同步;

2.关闭master的mysql服务,route将主节点自动切换到slave1,slave1从只读变为可读写,重新启动master mysql后,master变为只读模式。

参考链接:

https://www.cnblogs.com/shc336/p/9537904.html

https://blog.csdn.net/chiweiliu4439/article/details/100860080

https://www.cnblogs.com/kevingrace/p/10466530.html

https://blog.csdn.net/qq_15092079/article/details/82665307

https://www.jianshu.com/p/6e2918845ec8

https://blog.csdn.net/weixin_41850404/article/details/84615842

https://www.cnblogs.com/williamzheng/p/11347362.html

https://dev.mysql.com/doc/refman/8.0/en/mysql-innodb-cluster-userguide.html

https://blog.csdn.net/KokJuis/article/details/78401022

https://blog.csdn.net/Enmotech/article/details/78809282

Mysql Innodb cluster集群搭建的更多相关文章

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

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

  2. 重要参考步骤---ProxySQL Cluster 集群搭建步骤

    环境 proxysql-1:192.168.20.202 proxysql-2:192.168.20.203 均采用yum方式安装 # cat <<EOF | tee /etc/yum.r ...

  3. Redis Cluster集群搭建与应用

    1.redis-cluster设计 Redis集群搭建的方式有多种,例如使用zookeeper,但从redis 3.0之后版本支持redis-cluster集群,redis-cluster采用无中心结 ...

  4. MySQL之PXC集群搭建

    一.PXC 介绍 1.1 PXC 简介 PXC 是一套 MySQL 高可用集群解决方案,与传统的基于主从复制模式的集群架构相比 PXC 最突出特点就是解决了诟病已久的数据复制延迟问题,基本上可以达到实 ...

  5. MySQL优化之——集群搭建步骤具体解释

    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/46833179 1 概述 MySQL Cluster 是MySQL 适合于分布式计算 ...

  6. MariaDB Galera Cluster集群搭建

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

  7. Innodb Cluster集群部署配置

    目录 一.简介 二.环境声明 三.部署 安装(均操作) 配置(均操作) 开启group_replication(均操作) 启动group_replication 创建集群(在mysql-1执行) 创建 ...

  8. redis 学习笔记(6)-cluster集群搭建

    上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...

  9. Redis Cluster集群搭建与配置

    Redis Cluster是一种服务器sharding分片技术,关于Redis的集群方案应该怎么做,请参考我的另一篇博客http://www.cnblogs.com/xckk/p/6134655.ht ...

随机推荐

  1. resin部署安装

    Resin是CAUCHO公司的产品,是一个非常流行的application server,对servlet和JSP提供了良好的支持,性能也比较优良,resin自身也是采用JAVA语法开发,功能近似于t ...

  2. C# 中的IComparable和IComparer

    前言 在开发过程中经常会遇到比较排序的问题,比如说对集合数组的排序等情况,基本类型都提供了默认的比较算法,如string提供了按字母进行排序,而int整数则是根据整数大小进行排序.但是在引用类型中(具 ...

  3. SpringBoot源码学习系列之启动原理简介

    本博客通过debug方式简单跟一下Springboot application启动的源码,Springboot的启动源码是比较复杂的,本博客只是简单梳理一下源码,浅析其原理 为了方便跟源码,先找个Ap ...

  4. 【他山之石】jenkins忘记初始化密码解决办法

    没有太好的方式,网上有的是这样子的,找到 /var/lib/jenkins/users/username/config.xml, 修改为一个已知的 hash 值 #jbcrypt:$2a$10$Dda ...

  5. vc++调用msscript.ocx解析实现C++与JavaScript脚本交互

    ScriptControl接口 属性名称 类型 备注 AllowUI BOOL 检测是否允许运行用户的接口元素.如果为False,则诸如消息框之类的界面元素不可见. CodeObject Object ...

  6. 【题解/模板】P1248 加工生产调度(贪心)

    [题解/模板]P1248 加工生产调度(贪心) 分析: \(A\)流水线的时间是确定的,所以现在就是要让\(b\)的时间尽量短 \(tB > tA\),除非所有东西都不需要\(b\).(t指结束 ...

  7. python的一些高阶用法

    map的用法 def fn(x): return x*2 L1 = [1,2,3,4,5,6] L2 = list(map(fn,L1)) L2 [2, 4, 6, 8, 10, 12] 通过上面的运 ...

  8. 1090 危险品装箱 (25分)C语言

    集装箱运输货物时,我们必须特别小心,不能把不相容的货物装在一只箱子里.比如氧化剂绝对不能跟易燃液体同箱,否则很容易造成爆炸. 本题给定一张不相容物品的清单,需要你检查每一张集装箱货品清单,判断它们是否 ...

  9. 钱包开发经验分享:ETH篇

    # 钱包开发经验分享:ETH篇 [TOC] ## 开发前的准备 > 工欲善其事,必先利其器 一路开发过来,积累了一些钱包的开发利器和网站,与大家分享一下.这些东西在这行开发过的人都知道,只是给行 ...

  10. Win10系统下应用窗口任务栏居中效果

    实现步骤: 在资源管理器中新建文件夹,一定要保证文件夹内无任何文件 任务栏上鼠标右键,移动到工具栏上,选择新建工具栏 选择新建的空文件夹 空文件夹出现在任务栏后,鼠标可以拖动工具栏前的两条竖线(图片上 ...