当前位置:网站首页>MyCat2 introduction and installation and basic use
MyCat2 introduction and installation and basic use
2022-08-02 12:08:00 【丨Jack_Chen丨】
MyCat2的介绍与安装以及基本使用
MyCat2
MyCat概述
Mycat是数据库中间件,连接java应用程序和数据库.
Java程序与数据库紧密关联耦合严重,高访问量高并发对数据库的压力巨大,因此可以引入数据库中间件MyCat解决.
Mycat2的官网:http://www.mycat.org.cn/
Mycat2学习指南:https://www.yuque.com/books/share/6606b3b6-3365-4187-94c4-e51116894695
GitHub地址:https://github.com/MyCATApache/Mycat-Server
特性
核心功能
1.读写分离
Java操作MyCat,Mycat作为数据源访问,根据Java读、写请求分发到主从Mysql上,从而实现了读写分离.
2.数据分片
对数据库垂直拆分(分库)、对表水平拆分(分表)、对数据库垂直与表水平拆分(分库分表)
3.多数据源整合
Java操作MyCat,Mycat作为数据源访问,根据不同业务进行数据源划分,MyCat访问不同的数据源(MySql、MongoDB),从而实现多数据源整合.
原理
Mycat的原理中最重要的一个动词是“拦截”,它拦截用户发送的 SQL 语句,首先对 SQL语句做一些特定的分析:如分片分析、路由分析、读写分离分析、缓存分析等,然后将此 SQL 发往真实数据库,并将返回的结果做适当的处理,最终再返回给用户.
Mycat2相关概念
核心概念
具体参考:MyCat2官网文档
1.分库分表
According to certain rules, the tables in the database are split into multiple database instances,物理库,物理表访问路径的分表
分库:Usually divided by function template,如:分为用户库、订单库等
分表:When a piece of data is expressedMySQLsingle table bottleneck,Divide table data into multiple tables in multiple databases
2.逻辑库
The database in the database agent,It can contain multiple logical tables
MycatLibraries defined in ,在逻辑上存在,physicallyMySQL里并不存在
A logical library may be more than oneMySQL数据库共同组成
3.逻辑表
A table in the database agent,It can map tables in the database to which the proxy is connected(物理表)
Mycat里定义的表,在逻辑上存在,The real can be mappedMySQL数据库的表,可以一对一,也可以一对多.
4.物理库
Libraries in the database to which the database agent is connected,比如mysql上的information_schema
MySQL真实的数据库
5.物理表
A table in the database to which the database agent is connected,比如mysql上的information_schema.TABLES
MySQL A real data table in a real database
6.分库分表中间件
The middleware that realizes the function of sub-database and sub-table,It is functionally equivalent to a computing node in a sub-database and sub-phenotype database
7.Sub-library sub-phenotype database
A database constructed with sub-database and sub-table technology,There are generally compute nodes on the components,存储节点.Its storage node is generally an independently deployable database product,比如mysql
8.拆分键
即分片键,描述拆分逻辑表的数据规则的字段.
如:The order form can be per attributable user id 拆分,用户 id 就是拆分键
9.分区
Generally refers to the data partition,计算节点上,A horizontally sharded table splits the smallest area of data
10.分区键
when using equivalence queries,A split key that maps directly to a partition
11.系统表,元数据表
一般指mysql中的information_schema,performance_schema,mysqlTables under the three libraries
12.物理分表
Physical sub-tables refer to data that has been split,在数据库上面的物理表,是分片表的一个分区
多个物理分表里的数据汇总就是逻辑表的全部数据
13.物理分库
一般指包含多个物理分表的库
参与数据分片的实际数据库
14.单库分表
The same database table is split into multiple physical sub-tables under the same database
15.分库
一般指通过多个数据库拆分分片表,每个数据库一个物理分表,The physical sub-base has the same name
The physical sub-tables of each database constitute a complete physical table
16.分片表,水平分片表
The data is divided into multiple partitioned tables according to certain rules,在分库分表语境下,It is a type of logical table
17.单表
没有分片,没有数据冗余的表
没有拆分数据,There is also no copying of data to tables in other libraries
18.全局表,广播表
每个数据库实例都冗余全量数据的逻辑表
它通过表数据冗余,使分片表的分区与该表的数据在同一个数据库实例里,达到joinOperations can be performed directly within the database instance
Its data consistency is generally distributed through database agentsSQL实现.也有基于集群日志的实现
如: Dictionary table defined in the system,The full dictionary data is required for each sharded table
19.集群
多个数据节点组成的逻辑节点.在mycat2里,它是把对多个数据源地址视为一个数据源地址(名称),并提供自动故障恢复,转移,即实现高可用,负载均衡的组件
20.数据源
连接后端数据库的组件,它是数据库代理中连接后端数据库的客户端
Mycat Connect through a data source MySQL 数据库
21.schema(库)
在mycat2Configuration table logic in ,Configuration of views, etc
22.物理视图
Views in the backend database
23.逻辑视图
在mycat2The logical view in is the function of treating a query statement as a logical table
24.前端会话
一般指Mycat服务器中,The session points to the connectionmycat的客户端
25.backend session
一般指Mycat服务器中,The session points to the client connecting to the database
26.后端数据库
in the database agent,The database to which the database agent is connected
27.透传SQL
in the database agent,Refers to received from the clientSQL,It has not been altered,Send directly to the backend database in the proxy
28.Transparently transmit the result set
in the database agent,Refers to the result set returned from the backend database,Not changed,转换,Write to the frontend session
29.ER表
Narrowly refers to the child table in the parent-child table,它的分片键指向父表的分片键,Moreover, the sharding algorithm of the two tables is the same, which generally refers to a group of tables with the same data distribution.
如:The order details table is the order table ER表
30.原型库(prototype)
A prototype library is a real database that stores data,配置数据源时必须指定原型库
配置
详情参考:MyCat2官方文档
MyCat配置结构
mycat配置文件夹
+ clusters
- prototype.cluster.json //无集群的时候自动创建
- c0.cluster.json
- c1.cluster.json
+ datasources
- prototypeDs.datasource.json //无数据源的时候自动创建
- dr0.datasource.json
- dw0.datasource.json
+ schemas
- db1.schema.json
- mysql.schema.json
+ sequences
- db1_schema.sequence.json
-server.json //服务器配置
-state.json //mycat运行状态,包含集群选举的主节点信息,配置时间戳
1.服务配置
目录:mycat/conf/server.json
,Usually the default configuration is sufficient
作用:MyCat2服务相关配置
如: server.json
{
"loadBalance":{
"defaultLoadBalance":"BalanceRandom",
"loadBalances":[]
},
"mode":"local",
"properties":{
},
"server":{
"bufferPool":{
},
"idleTimer":{
"initialDelay":3,
"period":60000,
"timeUnit":"SECONDS"
},
"ip":"0.0.0.0",
"mycatId":1,
"port":8066,
"reactorNumber":8,
"tempDirectory":null,
"timeWorkerPool":{
"corePoolSize":0,
"keepAliveTime":1,
"maxPendingLimit":65535,
"maxPoolSize":2,
"taskTimeout":5,
"timeUnit":"MINUTES"
},
"workerPool":{
"corePoolSize":1,
"keepAliveTime":1,
"maxPendingLimit":65535,
"maxPoolSize":1024,
"taskTimeout":5,
"timeUnit":"MINUTES"
}
}
}
2.用户配置
目录:mycat/conf/users/
配置规则:用户名.user.json
作用:配置用户相关信息
如:root.user.json
{
"dialect":"mysql",# 使用语言,默认mysql
"ip":null,# 客户端访问ip,When filled in, it will be sent to the clientip进行限制
"password":"123456", # 密码
"transactionType":"proxy", # 事务类型,默认proxy
"username":"root" # Username to connect to the middleware library
}
transactionType:事务类型
proxy:本地事务,在涉及大于1个数据库的事务,commit阶段失败会导致不一致,但是兼容性最好
xa:分布式事务,需要确认存储节点集群类型是否支持XA
Statement implementation switches transaction types
set transaction_policy = 'xa'
set transaction_policy = 'proxy'
The statement queries the transaction type
SELECT @@transaction_policy
isolation:Sets the initial transaction isolation level
READ_UNCOMMITTED:1
READ_COMMITTED:2
REPEATED_READ:3,默认
SERIALIZABLE:4
3.数据源配置
目录: mycat/conf/datasources
配置规则:数据源名字.datasource.json
作用:配置Mycat连接的数据源信息
如:prototypeDs.datasource.json
{
"dbType":"mysql",# 数据库类型
"idleTimeout":60000, # 空闲连接超时时间
"initSqls":[], # 初始化sql
"initSqlsGetConnection":true, # 对于jdbc每次获取连接是否都执行 initSqls
"instanceType":"READ_WRITE", # 配置实例只读还是读写,可选值:READ_WRITE,READ,WRITE
"maxCon":1000, # 连接配置
"maxConnectTimeout":3000, # 连接配置
"maxRetryCount":5, # 连接配置
"minCon":1, # 连接配置
"name":"prototypeDs",
"password":"123456", # 密码
"type":"JDBC", # 数据源类型,默认 JDBC
"url":"jdbc:mysql://IP:3306/mysql?useUnicode=true&serverTimezone=Asia/Shanghai&characterEncoding=UTF-8", # 访问数据库地址
"user":"mycat", # 用户名
"weight":0 # 负载均衡权重
}
4.集群配置
目录:mycat/conf/clusters
配置规则:集群名字.cluster.json
作用 :配置集群信息
如:prototype.cluster.json
{
"clusterType":"MASTER_SLAVE", # 集群类型
# 可选值:SINGLE_NODE:单一节点
# MASTER_SLAVE:普通主从
# GARELA_CLUSTER:garela cluster/PXC 集群
# MHA:MHA集群
# MGR:MGR集群
"heartbeat":{
"heartbeatTimeout":1000,
"maxRetry":3,
"minSwitchTimeInterval":300,
"slaveThreshold":0
},
# 配置主节点
"masters":[
"prototypeDs"
],
"maxCon":200,
"name":"prototype",
"readBalanceType":"BALANCE_ALL", # 负载均衡策略
# 可选值:
# BALANCE_ALL(默认值):获取集群中所有数据源、
# BALANCE_ALL_READ:获取集群中允许读的数据源
# BALANCE_READ_WRITE:获取集群中允许读写的数据源,但允许读的数据源优先
# BALANCE_NONE:获取集群中允许写数据源,即主节点中选择
"switchType":"SWITCH" # 切换类型
# 可选值:
# NOT_SWITCH:不进行主从切换
# SWITCH:进行主从切换
}
5.Logic library table configuration
目录:mycat/conf/schemas
配置规则:库名.schema.json
作用:配置逻辑库表,实现分库分表
如:mysql.schema.json
{
"customTables":{
},
"globalTables":{
},
"normalTables":{
"spm_baseline":{
<!-- 建表SQL -->
"createTableSQL":"CREATE TABLE mysql.spm_baseline (\n\t`id` bigint(22) NOT NULL AUTO_INCREMENT,\n\t`sql` longtext,\n\t`fix_plan_id` bigint(22) DEFAULT NULL,\n\tKEY `id` (`id`)\n) ENGINE = InnoDB CHARSET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci",
"locality":{
"schemaName":"mysql", // 逻辑库名
"tableName":"spm_baseline", // 物理表
"targetName":"prototype" // 目的数据源或集群
}
}
},
"schemaName":"mysql",
"shardingTables":{
},
"targetName":"prototype"
}
MyCat2的基本使用
安装MyCat
下载地址:http://dl.mycat.org.cn/
wget http://dl.mycat.org.cn/2.0/install-template/mycat2-install-template-1.21.zip
下载Jar包:
wget http://dl.mycat.org.cn/2.0/1.21-release/mycat2-1.21-release-jar-with-dependencies.jar
解压mycat
unzip mycat2-install-template-1.21.zip
将mycat2-1.21-release-jar-with-dependencies.jar
放进解压的mycat\lib
文件夹下
mv mycat2-1.21-release-jar-with-dependencies.jar mycat/lib/
创建用户
创建用户,用于MyCat连接MySQL数据库
# 创建mycat用户
CREATE USER 'mycat'@'%' IDENTIFIED BY '123456';
# 授权
GRANT ALL PRIVILEGES ON *.* TO 'mycat'@'%' ;
# 刷新权限
flush privileges;
配置prototype数据源:vim mycat/conf/datasources/prototypeDs.datasource.json
修改对应的mysql数据库配置,修改user、password、url
等参数,So you can connectMyCat操作MySQL了.
{
"dbType":"mysql",
"idleTimeout":60000,
"initSqls":[],
"initSqlsGetConnection":true,
"instanceType":"READ_WRITE",
"maxCon":1000,
"maxConnectTimeout":3000,
"maxRetryCount":5,
"minCon":1,
"name":"prototypeDs",
"password":"123456",
"type":"JDBC",
"url":"jdbc:mysql://IP:3306/mysql?useUnicode=true&serverTimezone=Asia/Shanghai&characterEncoding=UTF-8",
"user":"mycat",
"weight":0
}
启动MyCat
Linux环境下
cd mycat/bin
./mycat start
./mycat status
./mycat start 启动
./mycat stop 停止
./mycat console 前台运行
./mycat restart 重启服务
./mycat pause 暂停
./mycat status 查看启动状态
Windos环境下
cd mycat/bin
#PowerShell
./mycat install
./mycat start
./mycat status
#CMD
mycat install
mycat start
mycat status
在Linux环境下使用,报错:
-bash: ./mycat: 权限不够
修改mycat
、 wrapper-linux-x86-64
、wrapper-linux-x86-32
and other file permissions,Otherwise when running the startup command,An error will be reported due to insufficient permissions
chmod 777 mycat wrapper-linux-x86-64 wrapper-linux-x86-32
重启MyCat
[root@administrator bin]# mycat start
Starting mycat2...
测试验证
MyCat安装、配置完毕后,就可以让应用程序、客户端连接MyCat,通过Mycat操作MySQL,从而实现程序与数据库的解耦.
1.9066
是MyCat管理窗口的端口,主要用于管理维护Mycat
mysql -umycat -p123456 -P 9066 -h IP
2.8066
是MyCat数据查询的端口,主要用于通过Mycat查询数据
mysql -umycat -p123456 -P 8066 -h IP
mysql> CREATE DATABASE mydb;
Query OK, 0 rows affected (0.55 sec)
mysql> use mydb;
Database changed
mysql> CREATE TABLE mytb(id INT,name VARCHAR(20));
Query OK, 0 rows affected (0.41 sec)
mysql> INSERT INTO mytb VALUES(1,'mycat');
Query OK, 1 row affected (0.07 sec)
mysql> select * from mytb;
+------+-------+
| id | name |
+------+-------+
| 1 | mycat |
+------+-------+
1 row in set (0.02 sec)
Main library login:mysql -uroot -h localhost -P3306 -p
mysql> use mydb;
Database changed
mysql> select * from mytb;
+------+-------+
| id | name |
+------+-------+
| 1 | mycat |
+------+-------+
1 row in set (0.01 sec)
Mycat2的安全设置
MycatThe security configuration is mainly usedmycat/conf/users
目录下的用户名.user.json
文件进行配置
如:root.user.json
{
"dialect":"mysql",# 使用语言,默认mysql
"ip":null,# 客户端访问ip,When filled in, it will be sent to the clientip进行限制
"password":"123456", # 密码
"transactionType":"proxy", # 事务类型,默认proxy
"username":"root" # Username to connect to the middleware library
}
Mycat2 UI监控工具
Mycat2 UI
是官方推出的Mycat2监控工具.使用需安装JDK8的环境,双击jar包运行.
下载列表:http://dl.mycat.org.cn/2.0/ui/
下载地址:http://dl.mycat.org.cn/2.0/ui/assistant-1.22-release-jar-with-dependencies-2022-5-26.jar
下载后双击assistant-1.22-release-jar-with-dependencies-2022-5-26.jar
启动,然后输入MyCat2related information can be connected.
You can configure it directly in the management interface、查询
添加监控
边栏推荐
猜你喜欢
随机推荐
Thymeleaf
手撸架构,MongDB 面试50问
JSP中如何正确的填写include指令中的file路径呢?
The use of QListView
AQS-AbstractQueuedSynchronizer
QAbstractScrollArea、QScrollArea
Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单。
Free Chinese-English Translation Software - Automatic Batch Chinese-English Translation Software Recommended Daquan
商业流程服务BPass你真的了解吗?
数据湖(一):数据湖概念
excel 批量翻译-excel 批量函数公司翻译大全免费
【kali-信息收集】(1.8)ARP侦查工具_Netdiscover
After Effects 教程,如何在 After Effects 中对蒙版进行动画绘制?
看我如何用多线程,帮助运营小姐姐解决数据校对系统变慢!
Likou 35 - search for insertion position - binary search
面积曲线AUC(area under curve)
打破千篇一律,DIY属于自己独一无二的商城
Jest 测试框架 beforeEach 的设计原理解析
从幻核疑似裁撤看如何保证NFT的安全
MD5详解(校验文件完整性)