🌻🌻 目录
- 一、Mycat 介绍
- 1.1 是什么
- 1.2 干什么的
- 1.3 原理
- 二、安装启动
- 2.1 解压缩文件拷贝到linux下 /usr/local/
- 2.2 三个文件
- 2.3 启动前先修改schema.xml(配置)
- 2.4 再修改server.xml
- 2.5 验证数据库访问情况
- 2.6 启动程序
- 2.7 启动时可能出现报错
- 2.8 登录
- 2.8.1 数据窗口
- 2.8.2 后台管理窗口
- 三、读写分离
- 3.1 读写分离
- 3.2 schema.xml
文章大纲 👇👇
一、Mycat 介绍
1.1 是什么
数据库中间件
- 前身是阿里的cobar
1.2 干什么的
1、读写分离
2、数据分片
- 垂直拆分
- 水平拆分
- 垂直+水平拆分
3、多数据源整合
1.3 原理
“拦截”
- Mycat 的原理中最重要的一个动词是“拦截”,它拦截了用户发送过来的 SQL 语句,首先对 SQL 语句做了
一些特定的分析:如分片分析、路由分析、读写分离分析、缓存分析等,然后将此 SQL 发往后端的真实数据库,
并将返回的结果做适当的处理,最终再返回给用户
二、安装启动
2.1 解压缩文件拷贝到linux下 /usr/local/
官网下载:https://github.com/MyCATApache/Mycat-download
本地资源库获取
① 上传到服务器(
建议另开一台服务器,不要使用前面的主从服务器
)
② 进行解压缩
cd /usr/local/
tar -xvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
③ 如果不在 /usr/local 下面,则进行拷贝到下面
cp -r mycat /usr/local
2.2 三个文件
schema.xml
- 定义逻辑库,表、分片节点等内容
rule.xml
- 定义分片规则
server.xml
- 定义用户以及系统相关变量,如端口等.
2.3 启动前先修改schema.xml(配置)
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!--逻辑库 name名称, checkSQLschema sqlMaxLimit 末尾是否要加 limit xxx-->
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> </schema>
<!--逻辑库 name名称, dataHost 引用的哪个dataHost database:对应mysql的database-->
<dataNode name="dn1" dataHost="localhost1" database="db1" />
<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 -->
<writeHost host="hostM1" url="localhost:3306" user="root"
password="root">
</writeHost>
</dataHost>
</mycat:schema>
<schema>
<dataNode>
<dataHost>
① 在linux配置文件中显示行号
:set nu #显示行号
dd #删除当前行
26dd # 删除当前下面的26行
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!--逻辑库 name名称, checkSQLschema sqlMaxLimit 末尾是否要加 limit xxx-->
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> </schema>
<!--逻辑库 name名称, dataHost 引用的哪个dataHost database:对应mysql的database-->
<dataNode name="dn1" dataHost="host1" database="mydb202401" />
<dataHost name="host1" 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 -->
<writeHost host="hostM1" url="192.168.10.100:3306" user="root"
password="root">
<!-- can have multi read hosts -->
<readHost host="hostS1" url="192.168.10.102:3306" user="root"
password="root">
</readHost>
</writeHost>
</dataHost>
2.4 再修改server.xml
<user name="mycat">
<property name="password">654321</property>
<property name="schemas">TESTDB</property>
</user>
2.5 验证数据库访问情况
意思大概是:
启动我的mycat的时候,能访问到我配置的两个数据库
mysql -uroot -proot -h 192.168.10.100 -P 3306
mysql -uroot -proot -h 192.168.10.102 -P 3306
如本机远程访问报错,请建对应用户
grant all privileges on *.* to root@'缺少的host' identified by 'root';
2.6 启动程序
- 控制台启动 :去
mycat/bin
目录下mycat console
(建议控制台启动:控制台可以看到日志)- 后台启动 :去
mycat/bin
目录下mycat start
2.7 启动时可能出现报错
域名解析失败
- 1、用
vi
修改/etc/hosts
文件
在 127.0.0.1
后面增加你的机器名
- 2、修改后重新启动网络服务
2.8 登录
2.8.1 数据窗口
mysql -umycat -p123456 -h 192.168.10.102 -P8066
命令
show database;
use TESTDB;
show tables;
select * from mytbl;
2.8.2 后台管理窗口
mysql -umycat -p123456 -P9066 -h192.168.10.102
show @@help
三、读写分离
前提:已经搭建好了主从复制
3.1 读写分离
- 创建表或在前面已创建的表中插入如下记录(动态获取登录的主机名)
create table mytbl
( id int auto_increment ,
name varchar(20)
);
- 分别在两个库下插入:
insert into mytbl(name) values (@@hostname)
- 然后再
mycat
下执行select * from mytbl
3.2 schema.xml
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!--逻辑库 name名称, checkSQLschema sqlMaxLimit 末尾是否要加 limit xxx-->
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"> </schema>
<!--逻辑库 name名称, dataHost 引用的哪个dataHost database:对应mysql的database-->
<dataNode name="dn1" dataHost="host1" database="mydb202401" />
<dataHost name="host1" maxCon="1000" minCon="10" balance="2"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM1" url="192.168.10.100:3306" user="root"
password="root">
<!-- can have multi read hosts -->
<readHost host="hostS1" url="192.168.10.102:3306" user="root"
password="root">
</readHost>
</writeHost>
</dataHost>
</mycat:schema>
balance
- 负载均衡类型,目前的取值有4 种:
balance="0"
, 不开启读写分离机制,所有读操作都发送到当前可用的 writeHost 上。
balance="1"
,全部的readHost
与stand by writeHost
(意思是写主机没有挂掉,就一直有仅有一台写主机运作) 参与 select 语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且 M1 与 M2 互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡。
balance="2"
,所有读操作都随机的在 writeHost、readhost 上分发。
balance="3"
,所有读请求随机的分发到 readhost 执行,writerHost 不负担读压力
[root@linux-102 conf]# vi schema.xml
[root@linux-102 bin]# ./mycat restart
- 最后:当在mycat下面运行
select * from mytbl;
就会动态切换;