8.16 mysql读写分离架构+MyCAT实现读写分离

news2024/12/26 11:20:59

1、读写分离的目的
数据库负载均衡:
当数据库请求增多时,单例数据库不能够满足业务
需求。需要进行数据库实例的扩容。多台数据库同时相
应请求。也就是说需要对数据库的请求,进行负载均衡 但是由于数据库服务特殊原因,数据库扩容基本要
求为:数据的一致性和完整性。所以要保证多台数据库
实例的数据一致性和完整性,以MySQL为例来说,官方
提供了主从复制机制。
读写分离:
数据库的负载均衡不同于其他服务的负载均衡,数
据要求一致性。基于主从复制的基础上,常见的数据库
负载均衡使用的是读写分离方式。写入主数据库,读取
到从数据库。可以认为数据库读写分离,是一种特殊的
负载均衡实现。
实际业务中,读写分离存在的一个问题,不够实时性。
对于要求实时性高的业务
①缓存 写主库 写缓存 读缓存
②可以读主
③添加完数据之后,有一个跳转等待的时间(5s),数
据正在审核中
2、读写分离常见的实现方式
①业务代码的读写分离
需要在业务代码中,判断数据操作是读还是写,读连接
从数据服务器操作,写连接主数据库服务器操作
以当前LNMP为例,需要通过PHP代码实现读写分离MySQL
②中间件代理方式的读写分离
在业务代码中,数据库的操作,不直接连接数据库,而
是先请求到中间件服务器(代理)
由代理服务器,判断是读操作去从数据服务器,写操作
去主数据服务器
MySQL读写分离案
列实现
0、搭建M-S复制
主从复制的原理 :主服务器开启bin-log(记录了写操
作) 从服务器获取到主服务器的bin-log 记录到relay
log中。从服务器在通过异步的线程方式,对于relay-log
进行重放操作。

server02 mysql master 192.168.17.100
server06 mysql slave 192.168.17.105
1、master配置
①在master服务器授权,slave服务器replication
slave权限
slave是通过MySQL连接登录到master上来读取二进制
日志的,因此需要在
master上给slave配置权限
②master服务器打开bin-log日志,并标识server-id
mysql > grant replication slave on *.* to
'slave'@'192.168.17.%'identified by
'123456';参数
作用
File
记录到的bin-log日志文件名称
Position
bin-log日志文件所记录的位置
配置文件内容
注意重启mysql使配置生效
③制作一个完整的备份
如果确认主从的数据库,默认开始数据是一致的,可以
不做备份
④查看master上的bin-log及其position位置
查看并记录File的值,Position的值。之后需要在从服务
器上,指向这些信息
shell > vim /etc/my.cnf
[mysqld]
log-bin = mysql-index
server-id = 1
shell > mysqldump -uroot -p'123456' --all
databases > /root/mysql.sql
mysql > show master status;2、slave配置
①恢复备份文件
如果slave和master的数据本身就是相同的,可以不选择
备份和导入
②配置server-id,标识服务器
配置文件内容
由于是克隆获取的MySQL实例,所以auto.conf里记录的
UUID一样,需要删除/usr/local/mysql/data/auto.conf
文件,否则主从无法识别互相身份,重启自动生成新的
即可。
③配置slave replication
参数说明
shell > vim /etc/my.cnf
[mysqld]
server-id=2
mysql > stop slave;
mysql> change master to
master_host='192.168.17.101' ,master_user='sl
ave1' ,master_password='123456' ,master_log_fi
le='mysql-bin.000002' ,master_log_pos=333;
mysql > start slave;master_host 主master的IP
master_user 主master允许登录,拥有replication
slave权限
master_password 用户的密码
需要通过mysql > show master status; 在master执

master_log_file 主master记录的bin-log日志文件名

master_log_pos 主master记录的bin-log日志文件对
应的位置
④启动replication,并检查结果
查看到两个yes,主从复制成功。否则,查看显示最下面
信息,通过error信息进行排查问题。
1、简单业务代码实现
示例语法代码:
mysql > show slave status\G;
<?php
//创建类
class Mysql {
//构造方法
//当类被实例化时,会触发此方法public function __construct(){
$this->master = @new
mysqli('192.168.17.100' , 'tp5shop' , '$Abc3721'
, 'tp5shop');
$this->slave = @new
mysqli('192.168.17.105' , 'tp5shop' , '$Abc3721'
, 'tp5shop');
// 如果从连接报错,就连接主
if($this->slave->connect_errno){
$this->slave=$this->master;
}
}
// SQL执行方法
public function query($sql){
//判断语句中是否存在selete
if(strpos($sql, 'select') !== false){
//这是查询操作
$rs = $this->slave->query($sql);
}else{
$rs = $this->master->query($sql);
}
return $rs;
}
}
$mysql = new Mysql();
$sql = "select * from tpshop_goods";
$rs = $mysql->query($sql);
while($row = $rs->fetch_assoc()){
var_dump($row['goods_name']);
}将此代码上传到web服务器,测试是否可以实现读写分
离。注意修改对应的连接地址、用户名称、密码等信
息。
#命令行执行php代码的方式
#php需要提前配置环境变量 xxx.php为需要执行的php
脚本文件
shell > php xxx.php
2、框架配置实现读写分离
①通过查看thinkphp5手册找到处理方案
②修改项目配置文件
一定要先去确定主从数据库的数据一致(tp5shop),
用户名称和密码可以进行登录使用
shell > vim
/usr/local/nginx/html/tp5shop/application/da
tabase.php
配置文件示例
return [
// 数据库类型
'type' => 'mysql' ,
// 服务器地址
// 1、主从数据库的连接地址 主在前 从在后
'hostname' =>
'192.168.17.100,192.168.17.105' ,// 2、主从数据库的名称、用户、密码一样的话,只
配置一份即可。如果不一样,按照先后顺序,逗号分隔
// 数据库名
'database' => 'tp5shop' ,
// 用户名
'username' => 'tp5shop' ,
// 密码
'password' => '$Abc3721' ,
// 端口
'hostport' => '3306' ,
// 连接dsn
'dsn' => '' ,
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8' ,
// 数据库表前缀
'prefix' => 'tpshop_' ,
// 数据库调试模式
'debug' => true,
// 3、项目框架的业务代码实现读写分离,使用的是
分布式(主从服务器) 配置为1
// 数据库部署方式:0 集中式(单一服务器),1 分布
式(主从服务器)
'deploy' => 1,
// 4、数据库读写分离是业务代码实现的,配置为
true
// 数据库读写是否分离 主从式有效
'rw_separate' => true,
// 读写分离后 主服务器数量测试down主库,看从库是否可以访问。thinkphp5中,
如果slave宕机,master提供读服务。
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '' ,
// 是否严格检查字段是否存在
3、MyCAT实现读写分离
3.1、介绍

准备一台服务器,作为数据库的中间件服务器,配置基
本环境,网卡、FQDN
server01 web1 192.168.17.102
server02 master 192.168.17.100
server06 slave 192.168.17.105
server07 mycat 192.168.17.106
Mycat 数据库中间件
国内最活跃的、性能最好的开源数据库中间件!
官方网址:http://www.mycat.io/
https://github.com/MyCATApache/MyCAT-Server/
因为mycat是由java语言开发,必须使用java的运行环境
才能进行启动和操作
3.2、jdk安装
①下载安装jdk
https://www.oracle.com/technetwork/java/javase/do
wnloads/jdk8-downloads-2133151.html
选择下载x64架构.tar.gz包
上传mycat和jdk到soft目录下
shell > tar xvf jdk-8u192-linux-x64.tar.gz
shell > mv jdk1.8.0_192 /usr/local/java
②配置环境变量
#追加环境变量
shell > echo
"PATH=/usr/local/java/bin:$PATH" >>
/etc/profile
shell > source /etc/profile
#检测java环境变量 如果看到版本信息即为成功
shell > java -version目录或文件
3.3、mycat安装和测试启动
①解压安装MyCAT
shell > tar xvf Mycat-server-1.6.5-release-
20180122220033-linux.tar.gz -C /usr/local
实际解压到目录即可,无需安装
③启动mycat
默认情况下启动mycat是可以启动的
#通过控制台 进行前端启动 可以看到执行过程
shell > /usr/local/mycat/bin/mycat console
注意如果启动不成功,可能是由于没有解析主机名称。
需要在hosts文件中进行解析。
3.4、配置读写分离
读写分离的配置文件

Mycat是由java开发,java开发的软件大部分配置文件是
xml格式。注意它的基本格式。
xml格式注意点:
1、xml声明信息
2、具有一个根标签
3、双标签和单标签格式
4、注意闭合标签
5、注释格式为
①查看server.xml
默认server.xml可以不用修改
shell > /usr/local/mycat/conf
shell > vim server.xml
修改server.xml
配置mycat对外的使用用户信息

②修改schema.xml
schema标签里配置name的server.xml里的虚拟数据库
名称,dataNode 填写后面使用的dataNode名称
dataNode标签和dataHost指定配置使用
dataHost标签里配置writeHost和readHost(密码,地
址,用户名称)
schema=>dataNode=>dataHost=>writeHost=>rea
dHost
可以使用给大家精简过的配置文件
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema
xmlns:mycat="http://io.mycat/"><!-- 1、TESTDB和server.xml配置文件中的映射
的数据库名称要一致 dataNone填写下面的dataNode名
称 -->
<schema name="TESTDB"
checkSQLschema="false" sqlMaxLimit="100"
dataNode="dn3"></schema>
<!-- 2、dataNode name和上面的一致
dataHost填写下面的dataHost的name名称 database
填写后端真实数据库名称-->
<dataNode name="dn3"
dataHost="localhost1" database="tp5shop" />
<!-- 3、可以配置负载均衡、读写分离算法 暂时
可以不用动-->
<dataHost name="localhost1"
maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql"
dbDriver="native" switchType="1"
slaveThreshold="100">
<!-- 对后端数据库服务器 发送的心跳检测 --
>
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<!-- 4、配置后端真实数据库的相关登录信息
-->
<writeHost host="hostM1"
url="192.168.17.100:3306" user="tp5shop"
password="$Abc3721">
<!-- can have multi read hosts -
->
<readHost host="hostS2"
url="192.168.17.105:3306" user="tp5shop"
password="$Abc3721" />
</writeHost>
<!-- <writeHost host="hostS1"
url="localhost:3316" user="root"
password="123456" />-->
<!-- <writeHost host="hostM2"
url="localhost:3316" user="root"
password="123456"/> -->
</dataHost>
</mycat:schema>
注意修改第7行,真实数据库的名称
③启动mycat服务
shell > /usr/local/mycat/bin/mycat start
#确认mycat是否真的启动,查看它的端口 9066 8066
shell > netstat -lntp|grep 8066
Tip:如果配置之后,启动mycat,不能够启动
通过查看/usr/local/mycat/logs/wrapper.log
3.5、mycat客户端
连接mycat客户端
<readHost host="hostS2"
url="192.168.17.105:3306" user="tp5shop"
password="$Abc3721" />
</writeHost>
<!-- <writeHost host="hostS1"
url="localhost:3316" user="root"
password="123456" />-->
<!-- <writeHost host="hostM2"
url="localhost:3316" user="root"
password="123456"/> -->
</dataHost>
</mycat:schema>
shell > /usr/local/mycat/bin/mycat start
#确认mycat是否真的启动,查看它的端口 9066 8066
shell > netstat -lntp|grep 8066
shell > mysql -h127.0.0.1 -uroot -p123456 -
P8066执行查询命令测试结果
mysql > show databases;
mysql > use TESTDB;
mysql > show tables;
#3.6、mycat管理端
连接mycat管理端
shell > mysql -h127.0.0.1 -uroot -p123456 -
P9066
执行管理命令查看
mysql > show @@help; //查看管理监控端的所有帮助
命令
mysql > show @@heartbeat; //查看服务器状态
3.7、业务代码配置
使用数据库中间件服务器实现读写分离和后端真实
数据库的管理。对于前端业务来说,数据操作需要连接
的是数据库中间件服务器。操作连接的是数据库中间件
服务器,而不直接连接多实例的真实服务器了。
①修改项目数据库配置文件
shell > vim
/usr/local/nginx/html/tp5shop/application/da
tabase.php配置文件示例
return [
// 数据库类型
'type' => 'mysql' ,
// 服务器地址
// 1、连接mycat数据库中间件服务器
'hostname' => '192.168.17.106' ,
// 2、mycat对外映射的数据库名称
// 数据库名
'database' => 'TESTDB' ,
// 3、mycat对外映射的用户
// 用户名
'username' => 'root' ,
// 4、mycat对外映射的密码和端口
// 密码
'password' => '123456' ,
// 端口
'hostport' => '8066' ,
// 连接dsn
'dsn' => '' ,
// 数据库连接参数
'params' => [],
// 数据库编码默认采用utf8
'charset' => 'utf8' ,
// 数据库表前缀
'prefix' => 'tpshop_' ,
// 数据库调试模式
'debug' => true,// 5、使用数据库中间件,对于前端业务服务器来
说,属于使用集中式单一服务器 配置为0
// 数据库部署方式:0 集中式(单一服务器),1 分布
式(主从服务器)
'deploy' => 0,
// 6、集中式单一服务器 不在业务代码进行读写分
离,交由数据库中间件去做 配置为false
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '' ,
// 是否严格检查字段是否存在
②测试访问
mycat默认writeHost和readHost,如果writeHost不可
用,则readHost也不可用。用两个writeHost,从的
writeHost变成可写的了,要在slave服务器上设置
readonly
3.8、balance属性和writeType属性
balance 属性
负载均衡类型,目前的取值有 3 种:1、balance="0", 不开启读写分离机制,所有读操作都
发送到当前可用的 writeHost 上。
2、balance="1", 全部的 readHost 与 stand by
writeHost 参与 select 语句的负载均衡,简单的说,当
双主双从模式(M1->S1,M2->S2,并且 M1 与 M2 互为
主备),正常情况下,M2,S1,S2 都参与 select 语句的负
载均衡。
3、balance="2", 所有读操作都随机的在
writeHost、readhost 上分发。
4、balance="3", 所有读请求随机的分发到
writerHost 对应的 readhost 执行,writerHost 不负担
读压力,注意 balance=3 只在 1.4 及其以后版本有,1.3
没有。
writeType 属性
负载均衡类型,目前的取值有 3 种:
1、writeType="0", 所有写操作发送到配置的第一个
writeHost,第一个挂了切到还生存的第二个
writeHost,重新启动后已切换后的为准.
2、writeType="1",所有写操作都随机的发送到配置的
writeHost,1.5 以后废弃不推荐
switchType 属性
-1 表示不自动切换
1 默认值,自动切换2 基于 MySQL 主从同步的状态决定是否切换

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

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

相关文章

《SPSS零基础入门教程》学习笔记——05.模型入门

文章目录 5.1 回归模型5.2 分类模型5.3 降维和刻度模型5.4 生存分析和时间序列模型 5.1 回归模型 线性回归&#xff08;分析 -> 回归 -> 线性&#xff09;曲线估计&#xff08;分析 -> 回归 -> 曲线估计&#xff09; 二元Logistic回归&#xff08;分析 -> 回归…

Centos7主机带宽限速

需求&#xff1a;最近有两个主机经常把带宽打满。咨询了阿里云无法对内网网卡做限制。这边想使用linux默认的TC工具。 限速之前测试带宽。这时带宽有 168.4MB/s。 ]# scp filebeat-8.8.2-x86_64.rpm 172.116.47.54:/root/100% 26MB 168.4MB/s 00:00 1. 限制出站&#xff0…

数据结构入门——08排序

1.排序 1.1什么是排序 排序是一种操作&#xff0c;通过比较记录中的关键字&#xff0c;将一组数据按照特定顺序&#xff08;递增或递减&#xff09;排列起来。排序在计算机科学中非常重要&#xff0c;因为它不仅有助于数据的快速检索&#xff0c;还能提高其他算法的性能。 1…

PostgreSQL-03-入门篇-过滤数据

文章目录 1. WHEREWHERE 子句概述WHERE 子句示例1) 使用 WHERE 子句和等于运算符 () 示例2) 使用 WHERE 子句和 AND 运算符示例3) 使用 WHERE 子句和 OR 运算符示例4) 使用 WHERE 子句和 IN 运算符示例5) 使用 WHERE 子句和 LIKE 运算符示例6) 将 WHERE 子句与 BETWEEN 运算符一…

自动化运维---ansible

ansible是一种由Python开发的自动化运维工具&#xff0c;集合了众多运维工具&#xff08;puppet、cfengine、chef、func、fabric&#xff09;的优点&#xff0c;实现了批量系统配置、批量程序部署、批量运行命令等功能。 特点: 部署简单 默认使用ssh进行管理&#xff0c;基于py…

【LLM大模型论文日更】| 大型语言模型用于模拟搜索用户行为

论文&#xff1a;https://arxiv.org/pdf/2403.09142代码&#xff1a;未开源机构&#xff1a;中国人民大学高瓴人工智能研究院领域&#xff1a;信息检索发表&#xff1a;SIGIR2024 短文 Abstract 由于成本效益和可再现性方面的优势&#xff0c;用户模拟已成为信息检索系统面向用…

Python酷库之旅-第三方库Pandas(084)

目录 一、用法精讲 351、pandas.Series.str.isdigit方法 351-1、语法 351-2、参数 351-3、功能 351-4、返回值 351-5、说明 351-6、用法 351-6-1、数据准备 351-6-2、代码示例 351-6-3、结果输出 352、pandas.Series.str.isspace方法 352-1、语法 352-2、参数 3…

【 亿邦动力网-注册安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞 …

钢铁百科:美标A633GrC材质分析、A633GrC正火状态、A633GrC材料性能

A633GrC钢板是一种美国ASTM标准的高强度低合金结构钢板&#xff0c;字母"A"代表钢&#xff08;Steel&#xff09;&#xff0c;数字"633"表示该材料的牌号&#xff0c;而"GrC"表示该材料为高强度低合金钢&#xff08;High Strength Low Alloy&…

wtv-next 宝塔更新教程

数据库升级办法 输入用户名密码&#xff0c;点执行 程序升级办法 文件后缀看清楚&#xff0c;是amd64、arm64。etc 目录下是配置文件&#xff0c;按照格式往下加就行。 回到刚才那个页面 先点停止&#xff0c;再点启动

【大模型部署及其应用 】RAG检索技术和生成模型的应用程序架构:RAG 使用 Meta AI 的 Llama 3

目录 RAG检索技术和生成模型的应用程序架构1. **基本概念**2. **工作原理**3. **RAG的优势**4. **常见应用场景**5. **RAG的挑战**6. **技术实现**参考RAG 使用 Meta AI 的 Llama 3亲自尝试运行主笔记本与文档应用聊天关键架构组件1. 自定义知识库2. 分块3. 嵌入模型4. 矢量数据…

GAMES104:08游戏引擎的动画技术基础-学习笔记

文章目录 一&#xff0c;动画技术简介动画技术的挑战 二&#xff0c;2D游戏动画技术2.1 精灵动画&#xff08;sprite animation&#xff09;2.2 Live2D 三&#xff0c;3D游戏动画技术3.1 基于层次的刚体动画3.2 顶点动画3.3 Morph Target Animation3.4 蒙皮动画3.4.1 2D蒙皮动画…

房产系统源码开发

一、开发需求&#xff1a; 信息录入与管理&#xff1a;系统需要支持各种数据的录入&#xff0c;这包括但不限于客户信息、房源信息、员工信息、合同信息和财务信息等。这些数据是房产系统的基础&#xff0c;对于后续的信息查询、分析和共享至关重要。信息查询与检索&#xff1…

Ports Number of field profile samples 参数设置

Ports Number of field profile samples 参数设置 正文正文 在进行 Port 仿真时,通常我们会对 port 端口中的光束模式进行设定,很多时候我们会遇到一个名为 Number of field profile samples 的参数,如下图所示: 如果去官方论坛查看解释,往往会被搞得云里雾里。这个参数…

什么是AR、VR、MR、XR?

时代背景 近年来随着计算机图形学、显示技术等的发展&#xff0c;视觉虚拟化技术得到了广泛的发展&#xff0c;并且越来越普及化&#xff0c;慢慢的也走入人们的视野。目前市场上视觉虚拟化技术的主流分为这几种 VR、AR、MR、XR。这几项技术并不是最近才出现的&#xff0c;VR的…

RabbitMQ 的工作原理

下面是rabbitmq 的工作原理图解 1、客户端连接到消息队列服务器&#xff0c;打开一个channel。 2、客户端声明一个exchange&#xff0c;并设置相关属性。 3、客户端声明一个queue&#xff0c;并设置相关属性。 4、客户端使用routing key&#xff0c; 在exchange和queue 之间…

FreeBSD 针对OpenSSH 高危漏洞发布紧急补丁

近日&#xff0c;FreeBSD 项目的维护者针对OpenSSH 高危漏洞发布了紧急补丁。该漏洞被追踪为 CVE-2024-7589&#xff0c;CVSS 得分为 7.4&#xff08;最高分为 10.0&#xff09;。通过利用该漏洞&#xff0c;黑客能够在权限提升的情况下远程执行任意代码。 根据上周发布的一份…

Hive3:常用的虚拟列(Virtual Columns)

一、作用 虚拟列是Hive内置的可以在查询语句中使用的特殊标记&#xff0c;可以查询数据本身的详细参数。 Hive目前可用3个虚拟列&#xff1a; INPUT__FILE__NAME&#xff1a;显示数据行所在的具体文件BLOCK__OFFSET__INSIDE__FILE&#xff1a;显示数据行所在文件的偏移量ROW…

HarmonyOS开发:跨应用数据共享详解

目录 前言跨应用数据共享的重要性HarmonyOS的数据共享能力相关的基本概念跨应用数据共享的数据管理具体实现跨应用数据共享延伸&#xff1a;数据共享的安全和隐私结语 前言 现在的移动操作系统中&#xff0c;应用之间的数据共享已成为提升用户体验和实现功能互补的重要手段&a…

机器学习——第十四章 概率图模型

目录 14.1 隐马尔可夫模型 14.2 马尔可夫随机场 14.3 条件随机场 14.4学习与推断 14.4.1 变量消去 14.4.2 信念传播 14.5 近似推断 14.5.1 MCMC采样 14.5.2 变分推断 14.6 话题模型 14.1 隐马尔可夫模型 隐马尔可夫模型&#xff08;Hidden Markov Model&#x…