MySQL8.0 innodb Cluster 高可用集群部署(MySQL、MySQL Shell、MySQL Router安装)

简介

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

InnoDB Cluster组件:

MySQL Group Replication,简称MGR,是MySQL的主从同步高可用方案,包括数据同步及角色选举

Mysql Shell 是InnoDB Cluster的管理工具,用来创建和管理集群

Mysql Router 是业务流量入口,支持对MGR的主从角色判断,可以配置不同的端口分别对外提供读写服务,和单端口读写分离。

innoDB Cluster将三个MySQL数据库实例构成一个高可用集群。其中一个实例是具有读/写能力的主要成员,其他两个实例是具有只读能力的次要成员。组复制将数据从主要成员复制到次要成员。MySQL Router将客户端应用程序连接到集群的主要成员。

为什么选择InnoDB Cluster:

InnoDB **集群(Cluster)**是InnoDB 副本集(ReplicaSet) 与 组复制(Group Replication) 的合成版,是InnoDB 副本集(ReplicaSet) 的高可用版,是 组复制(Group Replication) 的简易、自动化故障转移、可编程的增强版。

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

一、基础环境配置

1.1 部署规划:

IP

主机名

角色

安装软件

172.31.0.115

Mysql01

primary

mysql-shell,mysql8.3.0

172.31.0.116

Mysql02

secondary

mysql-shell,mysql8.3.0,mysqlroute

172.31.0.117

Mysql03

secondary

mysql-shell,mysql8.3.0,mysqlroute

1.2 部署资源:

下载地址:https://www.mysql.com/downloads

mysql-8.3.0-linux-glibc2.17-x86_64.tar.xz

mysql-router-8.3.0-linux-glibc2.17-x86_64.tar.xz

mysql-shell-8.3.0-linux-glibc2.17-x86-64bit.tar.gz

1.3 设置主机名:

每个节点都要设置

#配置主机名

vi /etc/hosts

#写入主机名信息

172.31.0.115 mysql01

172.31.0.116 mysql02

172.31.0.117 mysql03

#也可通过命令设置主机名:

sudo hostnamectl set-hostname mysql01

sudo hostnamectl set-hostname mysql02

sudo hostnamectl set-hostname mysql03

系统相关优化(自选):

cat>>/etc/sysctl.conf <<EOF

fs.aio-max-nr = 1048576

fs.file-max = 681574400

kernel.shmmax = 137438953472

kernel.shmmni = 4096

kernel.sem = 250 32000 100 200

net.ipv4.ip_local_port_range = 9000 65000

net.core.rmem_default = 262144

net.core.rmem_max = 4194304

net.core.wmem_default = 262144

net.core.wmem_max = 1048586

EOF

#执行生效

sysctl -p

cat>>/etc/security/limits.conf <<EOF

mysql soft nproc 65536

mysql hard nproc 65536

mysql soft nofile 65536

mysql hard nofile 65536

EOF

cat>>/etc/pam.d/login <<EOF

session required /lib/security/pam_limits.so

session required pam_limits.so

EOF

cat>>/etc/profile<<EOF

if [ $USER = “mysql” ]; then

ulimit -u 16384 -n 65536

fi

EOF

检查防火墙:

# 关闭

systemctl stop firewalld

# 开机禁用

systemctl disable firewalld

1.4 设置SSH免登录:

用ssh-keygen生成公钥,用ssh-copy-id将本地公钥复制到远程主机的authorized_keys文件。每台机器都要执行,注意执行时修改远程机器ip。

cd ~

ssh-keygen -t rsa

#一路回车

ssh-copy-id -i ~/.ssh/id_rsa.pub 172.31.0.117

ssh-copy-id -i ~/.ssh/id_rsa.pub 172.31.0.116

测试免登陆在mysql1上ssh mysql02

[root@mysql01 ~]# ssh mysql02

二、MySQL安装

2.1 查看系统是否自带mariadb并卸载(防止mysql与mariadb的文件发生冲突)

rpm -qa | grep mariadb

rpm -e mariadb-libs-X(更换查出来的信息) --nodeps

上传到 /usr/local/ 路径下,解压

cd /usr/local

ls

tar -xvf mysql-8.3.0-linux-glibc2.17-x86_64.tar.xz

2.2 删除压缩包,并将解压的mysql文件夹重命名为mysql

rm -rf mysql-8.3.0-linux-glibc2.17-x86_64.tar.xz

mv mysql-8.3.0-linux-glibc2.17-x86_64/ ./mysql
qwqw

2.3 进入mysql目录,创建data文件夹

cd mysql

mkdir data

2.4 创建mysql用户和组并修改权限

groupadd mysql

useradd -g mysql mysql

chown -R mysql.mysql /usr/local/mysql

2.5 创建编辑my.cnf配置文件

vim /etc/my.cnf

[client]

port = 3306

#根据实际情况调整mysql.sock配置

socket = /tmp/mysql.sock

[mysqld]

#Mysql服务的唯一编号 每个mysql服务Id需唯一

server-id = 1

report_host = mysql01

#服务端口号 默认3306

port = 3306

#mysql安装根目录

basedir = /usr/local/mysql

#mysql数据文件所在位置

datadir = /usr/local/mysql/data

#pid

pid-file = /usr/local/mysql/mysql.pid

#设置socke文件所在目录

socket = /tmp/mysql.sock

#设置临时目录

tmpdir = /tmp

# 用户

user = mysql

# 允许访问的IP网段

bind-address = 0.0.0.0

#错误日志

log_error=/usr/local/mysql/data/mysql-error.log

#设置认证插件(mysql8以上默认为caching_sha2_password 如果使用mysql_native_password则在后续配置mysql router的时候会有问题,我在这里搞错了后面配mysql router的时候有问题掉过头来把mysql重装了)

#default_authentication_plugin=mysql_native_password

#设置sqlmode(根据需求自定义)

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

# 跳过密码登录

#skip-grant-tables

#主要用于MyISAM存储引擎,如果多台服务器连接一个数据库则建议注释下面内容

skip-external-locking

#只能用IP地址检查客户端的登录,不用主机名

skip_name_resolve = 1

#数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用4个字节)

character-set-server = utf8mb4

#数据库字符集对应一些排序等规则,注意要和character-set-server对应

collation-server = utf8mb4_general_ci

#设置client连接mysql时的字符集,防止乱码

init_connect=‘SET NAMES utf8mb4’

#是否对sql语句大小写敏感,1表示不敏感

lower_case_table_names = 1

#最大连接数

max_connections = 15000

#最大错误连接数

max_connect_errors = 20000

#TIMESTAMP如果没有显示声明NOT NULL,允许NULL值

explicit_defaults_for_timestamp = true

#SQL数据包发送的大小,如果有BLOB对象建议修改成1G

max_allowed_packet = 128M

#MySQL连接闲置超过一定时间后(单位:秒)将会被强行关闭

#MySQL默认的wait_timeout 值为8个小时, interactive_timeout参数需要同时配置才能生效

interactive_timeout = 30

wait_timeout = 30

#内部内存临时表的最大值 ,设置成128M。

#比如大数据量的group by ,order by时可能用到临时表,

#超过了这个值将写入磁盘,系统IO压力增大

innodb_buffer_pool_size = 32G

table_open_cache = 4096

max_heap_table_size = 256M

sort_buffer_size = 32M

tmp_table_size = 256M

slow-query-log = 1

long_query_time = 4

max_allowed_packet = 32M

innodb_lock_wait_timeout = 120

open-files-limit = 30000

#mysql binlog日志文件保存的过期时间,过期后自动删除

#expire_logs_days = 5

#每个节点server_id要保障不一样

server_id = 4000000161

loose-group_replication_group_name=“a38e32fd-5fb6-11e8-ad7a-00259015d941”

#每个节点下面的配置信息不太一样,注意修改

loose-group_replication_local_address= “172.31.0.115:3306”

loose-group_replication_group_seeds= “172.31.0.115:3306,172.31.0.116:3306,172.31.0.117:3306”

loose-group_replication_single_primary_mode=TRUE

2.6 进入mysql文件夹的bin目录下,初始化mysql

cd /usr/local/mysql/bin

./mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/ --initialize

2.7 添加mysql服务,设置开机自启

#查看是是否有MySQL服务

chkconfig --list

#将MySQL的服务脚本放到系统服务中,/etc/init.d是 /etc/rc.d/init.d的软链接

cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

#授予可执行权限

chmod +x /etc/rc.d/init.d/mysql

#添加mysql服务

chkconfig --add mysql

#使MySQL开机自启

chkconfig --level 345 mysql on

2.8 创建mysql下bin目录的同步链接,设置后无需进入mysql的bin目录就可以执行mysql命令

ln -s /usr/local/mysql/bin/mysql /usr/bin

2.9 启动MySQL

#查看状态

service mysql status

#启动

service mysql start

#停止

service mysql stop

2.10 设置密码

MySQL成功启动后可以通过mysql下data目录下的日志文件可以找到root用户初始化密码,将密码复制粘贴,我们就可以成功登录mysql了

cat /usr/local/mysql/data/mysql-error.log

#修改root用户密码

#三台主机的root密码要一样

mysql -uroot -p

alter user 'root'@'localhost' identified by '你的密码';
use mysql;
#授权root用户任何IP访问
update user set host = '%' where user = 'root';
#刷新权限
FLUSH PRIVILEGES;
#查看用户信息是否被修改
select host, user, authentication_string, plugin from user;

到此mysql server 8 数据库的安装配置完成了!

2.11 给MySQL root用户授权(才能配置InnoDB集群实例)
grant all privileges on *.* to `root`@`%` with grant option;flush privileges;
2.12 组复制配置

修改各个节点/etc/my.cnf 配置MGR, 组复制信息,注意每台机器server_id,loose-group_replication_local_address需要不同

server_id = 4000000161

loose-group_replication_group_name=“a38e32fd-5fb6-11e8-ad7a-00259015d941”

loose-group_replication_local_address= “172.31.0.115:3306”

loose-group_replication_group_seeds= “172.31.0.115:3306,172.31.0.116:3306,172.31.0.117:3306”

loose-group_replication_single_primary_mode=TRUE

三、MySQL Shell安装

3.1将压缩包上传到每台机器/usr/local下,解压、授权并配置环境变量

#解压并配置

tar xvf mysql-shell-8.3.0-linux-glibc2.17-x86-64bit.tar.gz

#重命名

mv mysql-shell-8.3.0-linux-glibc2.17-x86-64bit mysql-shell

#授权给mysql用户–必须

chown -R mysql.mysql mysql-shell

#设置环境变量

vi /etc/profile

export PATH=/usr/local/mysql-shell/bin:$PATH

#:wq保存后使环境变量生效

source /etc/profile

3.2 节点配置检查

进入MySQL shell

mysqlsh

进去mysqlsh后进入js模式

js

在MySQL shell中执行,每台机器都要执行,注意修改主机名为当前节点

dba.configureInstance();

dba.checkInstanceConfiguration(‘root@mysql01:3306’);

3.3 创建并添加集群

在mysql shell中

var cluster = dba.createCluster(‘testCluster’);

cluster.addInstance(‘root@mysql02:3306’);

cluster.addInstance(‘root@mysql03:3306’);

3.4 查看集群状态

在MySQL shell 中

var cluster=dba.getCluster(‘testCluster’);

cluster.status();

四、安装MySQL Router

4.1 上传资源并配置环境

压缩包上传到/usr/local下,解压、授权并配置环境变量**。**

#解压并配置

tar xvf mysql-router-9.1.0-linux-glibc2.17-x86_64.tar.xz

mv mysql-router-9.1.0-linux-glibc2.17-x86_64 mysql-router

#授权 – 必须

chown -R mysql.mysql mysql-router

#设置环境变量

vi /etc/profile

export PATH=/usr/local/mysql-shell/bin:/usr/local/mysql-router/bin:$PATH

#:wq保存后使环境变量生效

source /etc/profile

4.2 初始化MySQL Router

mysql router主备节点都要执行

mysqlrouter --bootstrap root@localhost:3306 -d /usr/local/mysql-router/myrouter --user=root

注:这里会生成/usr/local/mysql-router/myrouter目录, 并在里面生成 mysqlrouter.conf 配置文件,接着可以根据实际修改端口等配置。

cat /usr/local/mysql-router/myrouter/mysqlrouter.conf

4.3 启动mysql router

cd /usr/local/mysql-router/myrouter

sh start.sh

集群及Router安装结束

五、MySQL集群维护

5.1 集群节点扩容

MySQL、MySQL Shell及MySQL Router 安装配置见上

#进去mysqlsh

mysqlsh

#切换到js模式

js

#获取集群

var cluster = dba.getCluster();

#查看集群状态

cluster.status();

#检查扩容机器是否符合加入,如果不符合根据提示修改配置。

dba.checkInstanceConfiguration(‘user@主机名:3306’);

#加入集群

cluster.addInstance(user@主机名:3306’);

5.2 集群节点删除

#进去mysqlsh

mysqlsh

#切换到js模式

js

#获取集群

var cluster = dba.getCluster();

#查看集群状态

cluster.status();

#要移除的节点主机名或IP

var memberToBeRemoved = “mysql03”;

#删除

cluster.removeMemberFromMetadata(memberToBeRemoved);

#移除后保存配置

cluster.saveConfiguration();

#查看集群状态

cluster.status()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/69731.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity-Mirror网络框架-从入门到精通之LagCompensation示例

文章目录 前言什么是滞后补偿Lag Compensation示例延迟补偿原理ServerCubeClientCubeCapture2DSnapshot3D补充LagCompensation.cs 独立算法滞后补偿器组件注意:算法最小示例前言 在现代游戏开发中,网络功能日益成为提升游戏体验的关键组成部分。本系列文章将为读者提供对Mir…

初窥强大,AI识别技术实现图像转文字(OCR技术)

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ &#x1f434;作者&#xff1a;秋无之地 &#x1f434;简介&#xff1a;CSDN爬虫、后端、大数据、人工智能领域创作者。目前从事python全栈、爬虫和人工智能等相关工作&#xff0c;主要擅长领域有&#xff1a;python…

不小心删除服务[null]后,git bash出现错误

不小心删除服务[null]后&#xff0c;git bash出现错误&#xff0c;如何解决&#xff1f; 错误描述&#xff1a;打开 git bash、msys2都会出现错误「bash: /dev/null: No such device or address」 问题定位&#xff1a; 1.使用搜索引擎搜索「bash: /dev/null: No such device o…

k8s部署logstash

1. 编写logstash.yaml配置文件 --- apiVersion: v1 kind: Service metadata:name: logstash spec:type: ClusterIPclusterIP: Noneports:- name: logstash-tcpport: 5000targetPort: 5000- name: logstash-beatsport: 5044targetPort: 5044- name: logstash-apiport: 9600targ…

【JVM详解一】类加载过程与内存区域划分

一、简介 1.1 概述 JVM是Java Virtual Machine&#xff08;Java虚拟机&#xff09;的缩写&#xff0c;是通过在实际的计算机上仿真模拟各种计算机功能来实现的。由一套字节码指令集、一组寄存器、一个栈、一个垃圾回收堆和一个存储方法域等组成。JVM屏蔽了与操作系统平台相关…

25考研电子信息复试面试常见核心问题真题汇总,电子信息考研复试没有项目怎么办?电子信息考研复试到底该如何准备?

你是不是在为电子信息考研复试焦虑&#xff1f;害怕被老师问到刁钻问题、担心专业面答不上来&#xff1f;别慌&#xff01;作为复试面试92分逆袭上岸的学姐&#xff0c;今天手把手教你拆解电子信息类复试通关密码&#xff01;看完这篇&#xff0c;让你面试现场直接开大&#xf…

【leetcode 32】1047. 删除字符串中的所有相邻重复项

Java中的queue、deque、ArrayDeque的区别 使用 Deque 作为堆栈(ArrayDeque是双端队列&#xff0c;当仅使用栈操作时push/pop&#xff0c;就是栈) class Solution {public String removeDuplicates(String s) {//使用 Deque 作为堆栈(ArrayDeque是双端队列&#xff0c;当仅使用栈…

redis项目

短信登录 这一块我们会使用redis共享session来实现 商户查询缓存 通过本章节&#xff0c;我们会理解缓存击穿&#xff0c;缓存穿透&#xff0c;缓存雪崩等问题&#xff0c;让小伙伴的对于这些概念的理解不仅仅是停留在概念上&#xff0c;更是能在代码中看到对应的内容 优惠…

Ubuntu 多版本 gcc 配置常用命令备忘

用的频率不高&#xff0c;总忘记具体参数 1&#xff0c;安装多版本 gcc 以 gcc-11 和12 为例&#xff1a; sudo apt-get install gcc-11 gcc-12 sudo apt-get install gcc-11 gcc-12 2&#xff0c;配置多版本 gcc gcc 与 g 一起配置进数据库中&#xff1a; sudo update-a…

【kubernetes组件合集】深入解析Kubernetes组件之三:client-go

深入解析Kubernetes组件之三&#xff1a;client-go 目录 深入解析Kubernetes组件之三&#xff1a;client-go 引言 1. client-go简介 2. client-go的功能 2.1 资源操作 2.2 资源监听 2.3 认证和授权 2.4 错误处理和重试 2.5 扩展性和定制化 3. 使用client-go与Kubern…

多项式插值(数值计算方法)Matlab实现

多项式插值&#xff08;数值计算方法&#xff09;Matlab实现 一. 原理介绍二. 程序设计1. 构建矩阵2. 求解矩阵方程3. 作出多项式函数4. 绘制插值曲线5. 完整代码 三. 图例 一. 原理介绍 关于插值的定义及基本原理可以参照如下索引 插值原理&#xff08;数值计算方法&#xff…

vite + axios 代理不起作用 404 无效

vite axios 代理不起作用 先看官方示例 export default defineConfig({server: {proxy: {// 字符串简写写法/foo: http://localhost:4567,// 选项写法/api: {target: http://jsonplaceholder.typicode.com,changeOrigin: true,rewrite: (path) > path.replace(/^\/api/, )…

国产编辑器EverEdit - 编辑辅助功能介绍

1 编辑辅助功能 1.1 各编辑辅助选项说明 1.1.1 行号 打开该选项时&#xff0c;在编辑器主窗口左侧显示行号&#xff0c;如下图所示&#xff1a; 1.1.2 文档地图 打开该选项时&#xff0c;在编辑器主窗口右侧靠近垂直滚动条的地方显示代码的缩略图&#xff0c;如下图所示&…

深入理解Java对接DeepSeek

其实&#xff0c;整个对接过程很简单&#xff0c;就四步&#xff0c;获取key&#xff0c;找到接口文档&#xff0c;接口测试&#xff0c;代码对接。 1.获取 KEY https://platform.deepseek.com/transactions 直接付款就是了&#xff08;现在官网暂停充值2025年2月7日&#xf…

调用DeepSeek官方的API接口

效果 前端样式体验链接&#xff1a;https://livequeen.top/deepseekshow 准备工作 1、注册deepseek官网账号 地址&#xff1a;DeepSeek 点击进入右上角【API开放平台】&#xff0c;并进行账号注册。 2、注册完成后&#xff0c;依次点击【API keys】-【生成API key】&#x…

香港中文大学 Adobe 推出 MotionCanvas:开启用户掌控的电影级图像视频创意之旅。

简介&#xff1a; 亮点直击 将电影镜头设计引入图像到视频的合成过程中。 推出了MotionCanvas&#xff0c;这是一种简化的视频合成系统&#xff0c;用于电影镜头设计&#xff0c;提供整体运动控制&#xff0c;以场景感知的方式联合操控相机和对象的运动。 设计了专门的运动条…

01.Docker 概述

Docker 概述 1. Docker 的主要目标2. 使用Docker 容器化封装应用程序的意义3. 容器和虚拟机技术比较4. 容器和虚拟机表现比较5. Docker 的组成6. Namespace7. Control groups8. 容器管理工具9. docker 的优缺点10. 容器的相关技术 docker 官网: http://www.docker.com 帮助文档…

【DeepSeek】deepseek可视化部署

目录 1 -> 前文 2 -> 部署可视化界面 1 -> 前文 【DeepSeek】DeepSeek概述 | 本地部署deepseek 通过前文可以将deepseek部署到本地使用&#xff0c;可是每次都需要winR输入cmd调出命令行进入到命令模式&#xff0c;输入命令ollama run deepseek-r1:latest。体验很…

开启对话式智能分析新纪元——Wyn商业智能 BI 携手Deepseek 驱动数据分析变革

2月18号&#xff0c;Wyn 商业智能 V8.0Update1 版本将重磅推出对话式智能分析&#xff0c;集成Deepseek R1大模型&#xff0c;通过AI技术的深度融合&#xff0c;致力于打造"会思考的BI系统"&#xff0c;让数据价值触手可及&#xff0c;助力企业实现从数据洞察到决策执…

Response 和 Request 介绍

怀旧网个人博客网站地址&#xff1a;怀旧网&#xff0c;博客详情&#xff1a;Response 和 Request 介绍 1、HttpServletResponse 1、简单分类 2、文件下载 通过Response下载文件数据 放一个文件到resources目录 编写下载文件Servlet文件 public class FileDownServlet exten…