分布式数据库中间件 MyCat 搞起来!
source link: https://www.tuicool.com/articles/ZvMzAfJ
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
关于 MyCat 的铺垫文章已经写了三篇了:
今天终于可以迎接我们的大 Boss 出场了!
MyCat 简介
前面文章我们提到,如果数据量比较大的话,我们需要对数据进行分库分表,分完之后,原本存在一个数据库中的数据,现在就存在多个数据库中了,就像下面这样:
那么此时 MyCat 所扮演的角色就是分布式数据库中间件!
MyCat 是一个开源的分布式数据库中间件,它实现了 MySQL 协议,在开发者眼里,他就是一个数据库代理,我们甚至可以使用 MySQL 的客户端工具以及命令行来访问 MyCat 。
MyCat 现在已经不仅仅只支持 MySQL 了,同时也支持 MSSQL、Oracle、DB2、以及 PostgreSQL等主流数据库。甚至像 MongoDB 这种 NoSQL 也支持。
快速入门
搭建读写分离
要搞 MyCat ,一般要先搭建好 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-20190213150257-linux.tar.gz
下载完成后,对下载文件进行解压。
tar -zxvf Mycat-server-1.6.7.1-release-20190213150257-linux.tar.gz
解压成功后,会出现一个 mycat
目录,进入到 mycat/conf
目录,对 mycat
进行配置:
首先来配置 schema.xml
文件:
- 首先在
schema
中指定逻辑库的名字,逻辑库是指MyCat
中的库,这个库不存储数据,数据存储在MySQL
中的物理库中。 - 逻辑库中配置逻辑表,配置逻辑表时,需要指定
dataNode
节点,dataNode
就是指数据库存储的位置 - 配置
dataNode
,dataNode
指定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
物理库中创建 db1
、 db2
以及 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 中的分片规则问题。
参考资料:
喜欢这篇文章吗?扫码关注公众号 【江南一点雨】 , 【江南一点雨】 专注于 SPRING BOOT+微服务以及前后端分离技术,每天推送原创技术干货,关注后回复 JAVA,领取松哥为你精心准备的 JAVA 干货!
Recommend
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK