红帽7—Mysql路由部署

MySQL Router 是一个对应用程序透明的InnoDB Cluster连接路由服务,提供负载均衡、应用连接故障转移和客户端路 由。

利用路由器的连接路由特性,用户可以编写应用程序来连接到路由器,并令路由器使用相应的路由策略 来处理连接,使其连接到正确的MySQL数据库服务器

准备工作

本实验以虚拟机Linux-7作为测试,在官网上下载软件包

准备三台虚拟机172.25.254.10,172.25.254.20和172.25.254.30各自安装数据库

轮询路由策略

“routing_strategy = round-robin” 表示路由策略为 “轮询”。

轮询策略是一种在多个资源或目标之间平均分配负载的方法。当有多个可选的路由、服务器或处理单元时,系统按照一定的顺序依次选择每个选项,以实现较为均衡的资源利用。

采用轮询策略时,第一个请求会被发送到第一个服务器,第二个请求被发送到第二个服务器,以此类推。当到达最后一个服务器后,下一个请求又会回到第一个服务器,形成一个循环。

策略的优点:

  1. 负载均衡:可以较为平均地将工作负载分配到各个资源上,避免某些资源过度负载而其他资源闲置的情况。
  2. 简单易实现:不需要复杂的算法和状态管理,易于理解和实现。

策略的缺点:

  1. 不能限制数据库的读写和访问分流
  2. 无法动态调整:如果某些资源在运行过程中出现故障或性能下降,轮询策略可能无法及时做出调整,导致请求分配不合理。

部署

172.25.254.10

主机从数据库官网上安装软件

[root@nginx ~]# rpm -ivh mysql-router-community-8.4.0-1.el7.x86_64.rpm

172.25.254.10主机上模拟mysql不存在将172.25.254.10主机的流量发送到172.25.254.20和172.25.254.30主机上

配置轮询路由策略

[root@nginx ~]# vim /etc/mysqlrouter/mysqlrouter.conf

[routing:ro]   #名称路由可读
bind_address = 0.0.0.0 #监控端口为当前主机端口
bind_port = 7001 #通过端口7001访问数据库
destinations=172.25.254.10:3306,172.25.254.20:3306,172.25.254.30:3306#访问主机的IP地址及端口
routing_strategy = round-robin#表示路由策略为轮询策略

启动mysql-router

[root@nginx ~]# systemctl start mysqlrouter.service

查看端口是否开启

[root@nginx ~]# netstat -antlupe |grep 7001

172.25.254.20

创建远程连接访问用户

mysql> create user root@'%' identified by 'lee';

mysql> grant all ON . to root@'%';

查询当前数据库服务器的唯一标识符为20

mysql> SELECT @@server_id;

172.25.254.30

创建远程连接访问用户

mysql> create user root@'%' identified by 'lee';

mysql> grant all ON . to root@'%';

查询当前数据库服务器的唯一标识符为30

mysql> SELECT @@server_id;

测试

172.25.254.10

在172.25.254.10主机上远程连接

[root@nginx ~]# mysql -uroot -plee -h172.25.254.10 -P 7001

查询当前数据库服务器的唯一标识符

mysql> SELECT @@server_id;

唯一标识符显示为30,说明172.25.254.10远程连接到172.25.254.30主机上。

\q退出mysql后再重新登录

再查询当前数据库服务器的唯一标识符

mysql> SELECT @@server_id;

唯一标识符显示为20,说明172.25.254.10远程连接到172.25.254.20主机上。

实现了路由轮询策略,注意mysql轮询策略不能限制数据库的读写和访问分流

优先使用路由策略

“routing_strategy = first-available” 表示路由策略为 “优先使用第一个可用的”。

这种路由策略通常在多个路径或资源中进行选择时使用。当有多个可选的路由或处理方式时,系统会优先选择第一个被确定为可用的选项。

如果采用 “first-available” 策略,网络设备会首先尝试第一个路径,如果该路径可用,则使用该路径进行数据传输;如果第一个路径不可用,则继续检查下一个路径,直到找到一个可用的路径。

“first-available” 路由策略的优点是简单直接,可以快速找到一个可用的选项。然而,它也可能存在一些缺点,比如可能没有充分考虑各个选项的性能、负载等因素,可能导致某些情况下不是最优的选择。

部署

配置轮询路由策略

172.25.254.10

[root@nginx ~]# vim /etc/mysqlrouter/mysqlrouter.conf

[routing:rw]
bind_address = 0.0.0.0
bind_port = 7002
destinations = 172.25.254.20:3306,172.25.254.30:3306
routing_strategy = first-available

启动mysql-router

[root@nginx ~]# systemctl start mysqlrouter.service

测试

172.25.254.10

在172.25.254.10主机上远程连接

[root@nginx ~]# mysql -uroot -plee -h172.25.254.10 -P 7002

查询当前数据库服务器的唯一标识符

mysql> SELECT @@server_id;

唯一标识符显示为20,说明172.25.254.10远程连接到172.25.254.20主机上。

\q退出mysql后再重新登录

再查询当前数据库服务器的唯一标识符

mysql> SELECT @@server_id;

唯一标识符显示依然为20,说明系统会优先选择第一个(172.25.254.20)被确定为可用的选项后,再次退出不会切换到172.25.254.30主机上,当172.25.254.20主机发生故障时会切换至172.25.254.30主机上。

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

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

相关文章

Jedis多线程环境报错:redis Could not get a resource from the pool 的主要原因及解决办法。

本篇文章主要讲解,Jedis多线程环境报错:redis Could not get a resource from the pool 的主要原因及解决办法。 作者:任聪聪 日期:2024年10月6日01:29:21 报错信息: 报文: redis Could not get a resou…

云原生日志ELK( logstash安装部署)

logstash 介绍 LogStash由JRuby语言编写,基于消息(message-based)的简单架构,并运行在Java虚拟机 (JVM)上。不同于分离的代理端(agent)或主机端(server)&…

Spring Boot驱动的现代医院管理系统

1系统概述 1.1 研究背景 如今互联网高速发展,网络遍布全球,通过互联网发布的消息能快而方便的传播到世界每个角落,并且互联网上能传播的信息也很广,比如文字、图片、声音、视频等。从而,这种种好处使得互联网成了信息传…

【斯坦福CS144】Lab5

一、实验目的 在现有的NetworkInterface基础上实现一个IP路由器。 二、实验内容 在本实验中,你将在现有的NetworkInterface基础上实现一个IP路由器,从而结束本课程。路由器有几个网络接口,可以在其中任何一个接口上接收互联网数据报。路由…

【uniapp小程序】使用cheerio去除字符串中的HTML标签并获取纯文本内容

【uniapp小程序】使用cheerio去除字符串中的HTML标签并获取纯文本内容 参考资料安装引入使用 参考资料 【博主:AIpoem】uniapp小程序 使用cheerio处理网络请求拿到的dom数据 cheerio文档:https://github.com/cheeriojs/cheerio/wiki/Chinese-README 安…

Sequelize 做登录查询数据

在 Sequelize 中处理登录请求通常意味着你需要根据提供的用户名或电子邮件以及密码来查询数据库中的用户。由于密码在数据库中应该是以哈希形式存储的,因此你还需要验证提供的密码是否与存储的哈希密码匹配。 以下是一个简单的例子,展示了如何使用 Sequ…

SpringBoot美发门店系统:提升服务质量

摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了美发门店管理系统的开发全过程。通过分析美发门店管理系统管理的不足,创建了一个计算机管理美发门店管理系统的方案。文章介绍了美发门店管理系统的系…

SpringBoot访问web中的静态资源

SpringBoot访问web中的静态资源,有两个方式: 1、SpringBoot默认指定了一些固定的目录结构,静态资源放到这些目录中的某一个,系统运行后浏览器就可以访问到 ① 关键是SpringBoot默认指定的可以存放静态资源的目录有哪些&#xff…

U mamba配置问题;‘KeyError: ‘file_ending‘

这个错误仍然是因为在 dataset_json 中找不到 file_ending 键。请尝试以下步骤: 检查 JSON 文件:确认 JSON 文件中确实有 file_ending,并且它的拼写完全正确。 打印 JSON 内容:在抛出异常之前,添加打印语句输出 datas…

JavaScript 数组简单学习

目录 1. 数组 1.1 介绍 1.2 基本使用 1.2.1 声明语法 1.2.2 取值语法 1.2.3 术语 1.3 案例 1. 数组 1.1 介绍 1.2 基本使用 1.2.1 声明语法 1.2.2 取值语法 1.2.3 术语 1.3 案例

Python知识点:如何应用Python工具,使用NLTK进行语言模型构建

开篇,先说一个好消息,截止到2025年1月1日前,翻到文末找到我,赠送定制版的开题报告和任务书,先到先得!过期不候! 如何使用NLTK进行语言模型构建 在自然语言处理(NLP)中&a…

pikachu靶场总结(三)

五、RCE 1.RCE(remote command/code execute)概述 RCE漏洞,可以让攻击者直接向后台服务器远程注入操作系统命令或者代码,从而控制后台系统。 远程系统命令执行 一般出现这种漏洞,是因为应用系统从设计上需要给用户提供指定的远程命令操作的…

基于SpringBoot和Vue的餐饮管理系统

基于springbootvue实现的餐饮管理系统 (源码L文ppt)4-078 第4章 系统设计 4.1 总体功能设计 一般个人用户和管理者都需要登录才能进入餐饮管理系统,使用者登录时会在后台判断使用的权限类型,包括一般使用者和管理者,一…

星融元P4交换机:在全球芯片短缺中,为您的网络可编程之路保驾护航

当数字化转型成为新常态,云计算、物联网、5G和人工智能等技术正以惊人的速度进步,重塑了我们对网络设备性能和适应性的预期。在这场技术革新的浪潮中,网络的灵活性、开放性和编程能力成为了推动行业发展的关键。P4可编程交换机,以…

飞驰云联入围2024西门子Xcelerator公开赛50强

近日,备受瞩目的西门子 Xcelerator公开赛公布结果,经过激烈的筛选,Ftrans飞驰云联《Ftrans制造业数据交换安全管控解决方案》凭借优异的表现,成功入围 Xcelerator公开赛50强! Xcelerator 公开赛以工信部智能制造典型场…

胤娲科技:00后揭秘——AI大模型的可靠性迷局

当智能不再“靠谱”,我们该何去何从? 想象一下,你向最新的GPT模型提问:“9.9和9.11哪个大?”这本应是个小菜一碟的问题,却足以让不少高科技的“大脑”陷入沉思, 甚至给出令人啼笑皆非的答案。近…

实战逆向RUST语言程序

实战为主,近日2024年羊城杯出了一道Rust编写的题目,这里将会以此题目为例,演示Rust逆向该如何去做。 题目名称:sedRust_happyVm 题目内容:unhappy rust, happy vm 关于Rust逆向,其实就是看汇编&#xff…

太阳诱电电感选型方法及产品介绍

功率电感在电子电路中被广泛应用,太阳诱电的功率电感从原材料开始进行研发,生产和销售。 本次研讨会将带领大家更加了解功率电感的选型方法,以及各种功率电感的种类和特征。 此外,也将介绍太阳诱电的最新产品阵容。本次研讨会预计…

边学边用docker-为什么要进到容器里面修改权限

在 Docker 容器中修改文件夹权限,通常需要进入容器内部来执行命令,这是因为 Docker 容器提供了一个隔离的环境,其内部的文件系统与宿主机是隔离的。 1. 隔离性:Docker 容器设计为轻量级的隔离环境,每个容器都有自己的…

如何在表中设置主键约束?

主键约束是数据库表设计中的一种完整性约束,用于唯一标识表中的每一行。 每个表只能有一个主键,且主键值必须是唯一的,并且不能为NULL。主键可以由一个字段或多个字段组成。 主键的存在有助于提高数据检索的速度和确保数据的完整性和一致性…