数据库:mycat实现读写分离
迪丽瓦拉
2025-05-31 07:11:20
0

目录

一、mycat

1、mycat实现读写分离原理

2、mycat应用场景

3、mycat作用

4、mycat实现读写分离实战


一、mycat

1、mycat实现读写分离原理

①用户进行读操作则由mycat转给配置的从数据库。

②用户进行写操作则由mycat转给配置的主数据库。

③转发规则由mycat配置文件中定义,那台是读那台是写。

2、mycat应用场景

Mycat适用的场景很丰富,以下是几个典型的应用场景

单纯的读写分离,此时配置最为简单,支持读写分离,主从切换

分表分库,对于超过1000万的表进行分片,最大支持1000亿的单表分片

多租户应用,每个应用一个库,但应用程序只连接Mycat,从而不改造程序本身,实现多租户化报表系统,借助于Mycat的分表能力,处理大规模报表的统计

替代Hbase,分析大数据,作为海量数据实时查询的一种简单有效方案,比如100亿条频繁查询的记录需要在3秒内查询出来结果,除了基于主键的查询,还可能存在范围查询或其他属性查询,此时Mycat可能是最简单有效的选择

3、mycat作用

一个彻底开源的,面向企业应用开发的大数据库集群

支持事务、ACID、可以替代MySQL的加强版数据库

一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群

一个融合内存缓存技术、NoSQL技术、HDFS大数据的新型SQL Server

结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品

一个新颖的数据库中间件产品

4、mycat实现读写分离实战

①环境准备:

2台安装了相同版本mysql数据库的服务器

主服务器(pc1):192.168.30.11

从服务器(pc2):192.168.30.12

1台服务器备用安装mycat

mycat服务器(pc3):192.168.30.13

1台客户机用于测试读写分离

测试服务器(pc4):192.168.30.14

②首先关闭4台服务器的firewalld以及selinux,重置主从服务器的mysql密码为Admin@123

pc1、pc2执行:
systemctl  stop  firewalld.service 
setenforce 0
systemctl start mysqld
#开启数据库
grep password /var/log/mysqld.log
#在错误日志中找到mysql初始密码,如下图
mysql -uroot  -p'初始密码' 
#登录数据库
alter user root@'localhost'  identified by 'Admin@123';
quit;
#修改root默认密码并退出

③主节点: 

vim  /etc/my.cnf
[mysqld]下一行添加内容:
server_id=11
#serverid建议配置为ip地址最后8位
log-bin=mysql-bin
#开启二进制日志
binlog_format=MIXED
#二进制日志格式
log-slave-updates=true
#开启从服务器同步
systemctl restart mysqld
#重启数据库
mysql -uroot -p'Admin@123'
#登录数据库
show  master status;
#查看主从复制从那个二进制日志的那个初始节点开始,从服务器配置需要依赖此条查看结果
grant replication slave on *.* to 'myslave'@'192.168.30.%' identified by 'Admin@123';
#建立一个myslave用户,并且允许192.168.30.%这个网段的地址来登录(环境不同注意改为自己的网段),密码是Admin@123,一会儿要在slave上使用这个账号
flush privileges;
#刷新一下;
create  database  test;
use test;
create table  lhj(id int,name char(11));
insert  lhj()  values(1,'abc'),(2,'xyz');
quit
#创建test库进入test库创建lhj表并写入2条数据到lhj表中,退出数据库。

④从节点: 

vim /etc/my.cnf
[mysqld]下一行添加内容:
server_id=12
relay-log=relay-log-bin
#添加,开启中继日志,从主服务器上同步日志文件记录到本地
relay-log-index=slave-relay-bin.index
#添加,定义中继日志文件的位置和名称,一般和relay-log在同一目录
systemctl restart mysqld
#重启服务
mysql -uroot -p'Admin@123'
#登录数据库
change master to
master_host='192.168.30.11',
master_user='myslave',
master_password='Admin@123',
master_log_file='master-bin.000001',
master_log_pos=154;
#配置主服务器相关信息包括主机,远程辅助用户和密码以及开始日志及节点,可以使用help change master to 查看模板
start slave;
#开启slave
show slave status \G;
#查看从服务器状态信息
select * from test.lhj
#查看是否将test库中的lhj表内容同步过来

⑤mycat节点:

yum install java -y
#mycat基于java所以要安装java环境
java -version
#查看java版本,确认安装成功
cd /opt
wget http://dl.mycat.org.cn/1.6.7.6/20210303094759/Mycat-server-1.6.7.6-release-20210303094759-linux.tar.gz
#进入/opt目录从官网下载mycat包
mkdir /apps
tar zxvf Mycat-server-1.6.7.6-release-20210303094759-linux.tar.gz -C /apps/
#创建/apps目录并将mycat包解压到/apps中
echo 'PATH=/apps/mycat/bin:$PATH' > /etc/profile.d/mycat.sh
source /etc/profile.d/mycat.sh
#设置并刷新环境变量使得mycat可以补全
mycat start
#启动mycat,注意若服务器内存小于等于2Gmycat服务起不来
tail -f /apps/mycat/logs/wrapper.log
#启动成功日志末尾会出现successfully,mycat只能通过查看日志的方式判断是否启动成功
#修改 mycat 配置文件*/apps/mycat/conf/schema.xml*此文件关联mysql读写分离策略,读写分离、分库分表策略、分片节点都是在此文件中配置的
vim  /apps/mycat/conf/schema.xml
#进入文件将内容全部删除然后复制添加以下文件修改



#定义数据节点名为dn1,物理数据库名为localhost1,物理数据库中数据库名为test,此库主服务器中必须存在select user()
#配置写主机名为host1,主机地址为192.168.30.11:3306,登录用户为root,密码为Admin@123
#配置写主机名为host2,主机地址为192.168.30.12:3306,登录用户为root,密码为Admin@123

⑤主节点授权mycat登录:

mysql -uroot -p'Admin@123'
#登录数据库
GRANT ALL ON *.* TO 'root'@'192.168.30.%' IDENTIFIED BY 'Admin@123';
#创建授权一个root远程登录用户网段为192.168.30段,密码为Admin@123
use mysql;
select user,host from user;
#查看是否创建成功

⑥mycat节点授权完成后重启mycat服务:

mycat restart 
tail -f /apps/mycat/logs/wrapper.log
#重启mycat服务并通过日志查看是否重启成功
netstat -antp |grep 3306
#mycat重启成功后可以通过过滤监听3306端口看到mycat有在监听主从俩个服务器的3306端口

⑦测试服务器测试读操作:

mysql -uroot -p123456 -h 192.168.30.13  -P8806
#客户机远程登录mycat,-h指定远程登录地址,-P指定登录端口,mycat默认有个root用户密码为123456
show  databases;
#可以看到有个TESTDB库访问此库即访问主服务器的test库
use TESTDB;
select * from lhj;
#可以看到和主库中lhj表一样的数据
select @@server_id;
#使用select查询语句看提供服务的id即可看到是12提供的服务即从服务器提供的读服务

⑧主从服务器开启通用日志并实时查看,在客户端的表中新增内容可以看到只有主有日志变化显示

主从都执行:
mysql -uroot -pAdin@123
#登录数据库
set global general_log=1;
#打开通用日志,通用日志若为yum安装则会在/var/lib/mysql/本机主机名.log文件
quit;
#退出数据库
主服务即主机名为pc1:
tail -f/var/lib/mysql/pc1.log
#实时查看通用日志
从服务即主机名为pc2:
tail -f/var/lib/mysql/pc2.log
#实时查看通用日志
客户端测试:
mysql -uroot -p123456 -h192.168.30.13 -P8066
#登录mycat
use  TESTDB;
insert lhj() values('3','test');
#进入TESTDB库并在lhj表中加入数据查看主从实时日志只有主日志显示变化则读写分离实现,日志截图如下

 

相关内容

热门资讯

linux入门---制作进度条 了解缓冲区 我们首先来看看下面的操作: 我们首先创建了一个文件并在这个文件里面添加了...
C++ 机房预约系统(六):学... 8、 学生模块 8.1 学生子菜单、登录和注销 实现步骤: 在Student.cpp的...
A.机器学习入门算法(三):基... 机器学习算法(三):K近邻(k-nearest neigh...
数字温湿度传感器DHT11模块... 模块实例https://blog.csdn.net/qq_38393591/article/deta...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
Redis 所有支持的数据结构... Redis 是一种开源的基于键值对存储的 NoSQL 数据库,支持多种数据结构。以下是...
win下pytorch安装—c... 安装目录一、cuda安装1.1、cuda版本选择1.2、下载安装二、cudnn安装三、pytorch...
MySQL基础-多表查询 文章目录MySQL基础-多表查询一、案例及引入1、基础概念2、笛卡尔积的理解二、多表查询的分类1、等...
keil调试专题篇 调试的前提是需要连接调试器比如STLINK。 然后点击菜单或者快捷图标均可进入调试模式。 如果前面...
MATLAB | 全网最详细网... 一篇超超超长,超超超全面网络图绘制教程,本篇基本能讲清楚所有绘制要点&#...
IHome主页 - 让你的浏览... 随着互联网的发展,人们越来越离不开浏览器了。每天上班、学习、娱乐,浏览器...
TCP 协议 一、TCP 协议概念 TCP即传输控制协议(Transmission Control ...
营业执照的经营范围有哪些 营业执照的经营范围有哪些 经营范围是指企业可以从事的生产经营与服务项目,是进行公司注册...
C++ 可变体(variant... 一、可变体(variant) 基础用法 Union的问题: 无法知道当前使用的类型是什...
血压计语音芯片,电子医疗设备声... 语音电子血压计是带有语音提示功能的电子血压计,测量前至测量结果全程语音播报࿰...
MySQL OCP888题解0... 文章目录1、原题1.1、英文原题1.2、答案2、题目解析2.1、题干解析2.2、选项解析3、知识点3...
【2023-Pytorch-检... (肆十二想说的一些话)Yolo这个系列我们已经更新了大概一年的时间,现在基本的流程也走走通了,包含数...
实战项目:保险行业用户分类 这里写目录标题1、项目介绍1.1 行业背景1.2 数据介绍2、代码实现导入数据探索数据处理列标签名异...
记录--我在前端干工地(thr... 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前段时间接触了Th...
43 openEuler搭建A... 文章目录43 openEuler搭建Apache服务器-配置文件说明和管理模块43.1 配置文件说明...