1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > docker安装mycat_分布式数据库中间件 MyCat 搞起来!

docker安装mycat_分布式数据库中间件 MyCat 搞起来!

时间:2023-04-26 23:04:08

相关推荐

docker安装mycat_分布式数据库中间件 MyCat 搞起来!

关于 MyCat 的铺垫文章已经写了三篇了:

MySQL 只能做小项目?松哥要说几句公道话!

北冥有 Data,其名为鲲,鲲之大,一个 MySQL 放不下!

What?Tomcat 竟然也算中间件?

今天终于可以迎接我们的大 Boss 出场了!

MyCat 简介

前面文章我们提到,如果数据量比较大的话,我们需要对数据进行分库分表,分完之后,原本存在一个数据库中的数据,现在就存在多个数据库中了,就像下面这样:

那么此时 MyCat 所扮演的角色就是分布式数据库中间件!

MyCat 是一个开源的分布式数据库中间件,它实现了 MySQL 协议,在开发者眼里,他就是一个数据库代理,我们甚至可以使用 MySQL 的客户端工具以及命令行来访问 MyCat 。

MyCat 现在已经不仅仅只支持 MySQL 了,同时也支持 MSSQL、Oracle、DB2、以及 PostgreSQL等主流数据库。甚至像 MongoDB 这种 NoSQL 也支持。

快速入门

搭建读写分离

要搞 MyCat ,一般要先搭建好 MySQL 的读写分离,MySQL 的读写分离可以参考松哥之前的这篇文章:

提高性能,MySQL 读写分离环境搭建(二)

MyCat 安装

环境:

CentOS7

JDK1.8

MyCat 使用 Java 开发,因此,运行 MyCat ,一定要具备 Java 环境,配置 Java 运行环境这个比较容易,网上资料也很多,我就不详细介绍了。

Java 环境安装好之后,首先下载 MyCat:

wget http://dl.mycat.io/1.6.7.1/Mycat-server-1.6.7.1-release-0213150257-linux.tar.gz

下载完成后,对下载文件进行解压。

tar -zxvf Mycat-server-1.6.7.1-release-0213150257-linux.tar.gz

解压成功后,会出现一个mycat目录,进入到mycat/conf目录,对mycat进行配置:

首先来配置schema.xml文件:

首先在schema中指定逻辑库的名字,逻辑库是指MyCat中的库,这个库不存储数据,数据存储在MySQL中的物理库中。

逻辑库中配置逻辑表,配置逻辑表时,需要指定dataNode节点,dataNode就是指数据库存储的位置

配置dataNodedataNode指定dataHost和物理库的名字。

dataHost则配置MySQL的主机和从机的位置,登录密码等。主机和从机都可以配置多个。

配置完 schema.xml 后 ,接下来配置 server.xml。

server.xml 中主要配置 MyCat 的登录用户名和密码,以及需要操作的逻辑库。

配置完成后,接下来就可以启动 MyCat 了 。

执行 MyCat 解压目录下的 bin 目录下的 mycat 命令,可以启动 MyCat

./bin/mycat start

如果启动后,提示无法创建mycat.pid文件,就自己手动创建一个mycat.pid文件。启动成功之后,就可以在本地连接MyCat了,连接方式和MySQL一样,唯一的区别在于端口号不同。

在连接MyCat之前,先在MySQL物理库中创建db1db2以及db3三个数据库。

使用SQLyog连接:

也可以在cmd命令行登录MyCat

登录成功后 ,在MyCat的窗口中,执行如下命令,创建表:

create table t_user (id integer primary key,username varchar(255))

执行成功后,我们会发现物理库中出现了相应的表。接下来,手动往各个物理库的物理表中存储一条数据,然后在 MyCat 窗口中查询:

这样就可以查询到 三个库中的三个表中的数据。

问题分析

整个过程不难,但是有的小伙伴在第一次配置的过程中还是容易出错,因此我这里还是来说两句,出错了要如何定位。

一般来说,配置 MyCat 出错,问题可能发生在两个阶段。第一个阶段就是客户端连接 MyCat 出错,第二个阶段就是 MyCat 连接 MySQL 出错。

无论你是使用 SQLyog 还是 Navicat ,我们在连接数据库的过程中,都可以先测试连接,很多人卡在这一步。

如果在测试连接的时候就连接不通,说明是 MyCat 的问题,这个时候检查步骤如下:

首先当然是查看日志信息,看能不能找出端倪

通过 jps 命令查看 mycat 是否成功启动

检查 server.xml 中配置是否正确,用户名密码是否输入正确

这是第一种可能的问题,第二种问题就是测试连接没问题,但是测试完后,却连接不上。反映到 Navicat 上,就是测试连接没问题,测完之后,点击连接名要打开连接时,Navicat 就崩了,出现这个问题一般是 MyCat 在连接 MySQL 出问题了,这个时候就要去检查 schema.xml 文件中关于 MySQL 主机和从机的配置是否正确,数据库地址是否正确,用户名密码是否正确。

结语

好了,本文主要简单介绍了下 MyCat 的安装问题,下篇文章我们来看 MyCat 中的分片规则问题。

参考资料:

MyCat 官方文档

如果小伙伴觉得松哥自己写的技术文章还过得去的话,欢迎积极转发,松哥每隔 15 天会根据微信后台数据,选一个分享转发最多的一位小伙伴+精选评论最多的小伙伴,各送一本松哥自己的签名书或者 Java 领域的经典书籍,欢迎大家积极参与,下一次开奖时间在下周。

●松哥整理了 15 道 Spring Boot 高频面试题,看完当面霸!

●想让自己的项目6666,可是 Chrome 不答应!

●干货|最新版 Spring Boot2.1.5 教程+案例合集

●极简 Spring Boot 整合 Thymeleaf 页面模板

●另一种缓存,Spring Boot 整合 Ehcache

●Spring Boot 整合 Shiro ,两种方式全总结!

●Docker 入门及安装[Docker 系列-1]

●Nginx 极简入门教程!

●Spring Boot 一个依赖搞定 session 共享,没有比这更简单的方案了!

●Spring Boot 操作 Redis,三种方案全解析!

你点的每个在看,我都认真当成了喜欢

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。