MyCAT读写分离

2023-12-13 21:49:54

????????Mycat 是一个开源的数据库系统,但是由于真正的数据库需要存储引擎,而 Mycat 并没有存 储引擎,所以并不是完全意义的数据库系统。 那么 Mycat 是什么?Mycat 是数据库中间件,就是介于数据库与应用之间,进行数据处理与交互的中间服务。

MyCAT 是使用 JAVA 语言进行编写开发,使用前需要先安装 JAVA 运行环境(JRE),由于 MyCAT 中使用了 JDK7 中的一些特性,所以要求必须在 JDK7 以上的版本上运行。

部署环境

1下载JDK并安装

# 解压
[root@mycat ~]# tar -xf jdk-8u181-linux-x64.tar.gz -C /usr/local/

# 配置环境变量
[root@mycat ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/local/java
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

# 使环境变量生效
[root@mycat ~]# source /etc/profile.d/java.sh
部署Mycat

下载并解压安装包?

# 下载
[root@mycat ~]# wget http://dl.mycat.org.cn/1.6.5/Mycat-server-1.6.5-release-20180122220033-linux.tar.gz

# 解压
[root@mycat ~]# tar xf Mycat-server-1.6.5-release-20180122220033-linux.tar.gz -C /usr/local/
配置Mycat

认识配置文件

MyCAT 目前主要通过配置文件的方式来定义逻辑库和相关配置:

/usr/local/mycat/conf/server.xml 定义用户以及系统相关变量,如端口等。其中用户信息是前端应用程序连接 mycat 的用户信息。

/usr/local/mycat/conf/schema.xml 定义逻辑库,表、分片节点等内容

配置 server.xml

以下为代码片段

下面的用户和密码是应用程序连接到 MyCat 使用的,可以自定义配置

而其中的schemas 配置项所对应的值是逻辑数据库的名字,也可以自定义,但是这个名字需要和后面 schema.xml 文件中配置的一致。

[root@mycat ~]# vim /usr/local/mycat/conf/server.xml 
<!--下面的用户和密码是应用程序连接到 MyCat 使用的.schemas 配置项所对应的值是逻辑数据库的名字,这个名字需要和后面 schema.xml 文件中配置的一致。-->

       <user name="youngfit" defaultAccount="true">
                <property name="password">123456</property>
                <property name="schemas">testdb</property>
                
                <!-- 表级 DML 权限设置 -->
                <!--            
                <privileges check="false">
                        <schema name="TESTDB" dml="0110" >
                                <table name="tb01" dml="0000"></table>
                                <table name="tb02" dml="1111"></table>
                        </schema>
                </privileges>           
                 -->
        </user>
<!--下面是另一个用户,并且设置的访问 TESTED 逻辑数据库的权限是 只读
        <!--user name="mycatuser">
                <property name="password">123456</property>
                <property name="schemas">testdb</property>
                <property name="readOnly">true</property>
        </user-->
-->
</mycat:server>

上面的配置中,假如配置了用户访问的逻辑库,那么必须在 schema.xml 文件中也配置这个逻辑库,否则报错,启动 mycat 失败。

配置schema.xml

以下是配置文件中的每个部分的配置块儿

逻辑库和分表设置

<schema name="testdb" ? ? ? ? ? // 逻辑库名称,与server.xml的一致
? ? ? ? checkSQLschema="false" ? ?// 不检查sql
? ? ? ? sqlMaxLimit="100" ? ? ? ? // 最大连接数
? ? ? ? dataNode="dn1"> ? ? ? ?// ?数据节点名称
<!--这里定义的是分表的信息--> ? ? ? ?
</schema>
?

数据节点

<dataNode name="dn1" ? ? ? ? ? ? // 此数据节点的名称
? ? ? ? ? dataHost="localhost1" ? ? // 主机组
? ? ? ? ? database="testdb" /> ?// 真实的数据库名称

主机组

<dataHost name="localhost1" ? ? ? ? ? ? ? ? ? ? ? // 主机组
? ? ? ? ? maxCon="1000" minCon="10" ? ? ? ? ? ? ? // 连接
? ? ? ? ? balance="0" ? ? ? ? ? ? ? ? ? ? ? ? ? ? // 负载均衡
? ? ? ? ? writeType="0" ? ? ? ? ? ? ? ? ? ? ? ? ? // 写模式配置
? ? ? ? ? dbType="mysql" dbDriver="native" ? ? ? ?// 数据库配置
? ? ? ? ? switchType="1" ?slaveThreshold="100">
<!--这里可以配置关于这个主机组的成员信息,和针对这些主机的健康检查语句-->
</dataHost>

?balance 属性与writeType 属性

?balance 属性
负载均衡类型,目前的取值有 3 种:
1. balance="0", 不开启读写分离机制,所有读操作都发送到当前可用的 writeHost 上。
2. balance="1", 全部的 readHost 与 stand by writeHost 参与 select 语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且 M1 与 M2?
? ? 互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡。
4. balance="2", 所有读操作都随机的在 writeHost、readhost 上分发。
5. balance="3", 所有读请求随机的分发到 writerHost 对应的 readhost 执行,writerHost 不负担读压力,注意 balance=3 只在 1.4 及其以后版本有,1.3 没有。

writeType 属性
负载均衡类型
1. writeType="0", 所有写操作发送到配置的第一个 writeHost,第一个挂了切到还生存的第二个writeHost,重新启动后已切换后的为准.
2. writeType="1",所有写操作都随机的发送到配置的 writeHost,1.5 以后废弃不推荐。

健康检查

<heartbeat>select user()</heartbeat>?? ??

读写配置

<writeHost host="hostM1" url="192.168.62.153:3306" user="root" password="Syf_123456">
? ? ? ? ? ? ? ? ? ? ? ? <!-- can have multi read hosts -->
<readHost host="hostS2" url="192.168.62.152:3306" user="root" password="Syf_123456" />
</writeHost>

以下是组合为完整的配置文件,适用于一主一从的架构

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

  <schema name="testdb" 
        checkSQLschema="false" 
        sqlMaxLimit="100" 
        dataNode="dn1"> 
   <!--这里定义的是分库分表的信息-->     
   </schema>
   

  <dataNode name="dn1" 
          dataHost="localhost1" database="testdb" />
        
        
  <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="192.168.62.153:3306" 
              user="root"  password="Syf_123456">
      <!-- can have multi read hosts -->
      <readHost host="hostS2" url="192.168.62.152:3306" 
                user="root" password="Syf_123456" />
     </writeHost>
   </dataHost>
</mycat:schema>
?启动 mycat
[root@mycat ~]# /usr/local/mycat/bin/mycat  start

支持一下参数
start | restart |stop | status
在真实的 master 数据库上给用户授权
mysql> grant all on testdb.* to root@'%' identified by 'Syf_123456';
mysql> flush privileges;
测试

在 mycat 的机器上测试用户权限有效性

测试是否能正常登录上 主服务器

mysql -uroot -p'Syf_123456' -h192.168.62.153

继续测试是否能登录上从服务器

mysql -uroot -p'Syf_123456' -h192.168.62.152?

通过客户端进行测试是否能登录到 mycat 上

192.168.62.151 是 mycat 的主机地址

注意端口号是 8066

[root@mysqlclient ~]# mysql -uroot -pSyf_123456 -h192.168.62.151 -P 8066

MySQL [(none)]> show databases;
+----------+
| DATABASE |
+----------+
| testdb |
+----------+
1 row in set (0.00 sec)

继续测试读写分离策略

使用 mysql 客户端工具使用 mycat 的账户和密码登录 mycat , 之后执行 select 语句。

之后查询 mycat 主机上 mycat 安装目录下的 logs/mycat.log 日志。

在日志重搜索查询的语句或者查询 从库的 ip 地址,应该能搜索到。

文章来源:https://blog.csdn.net/Mwb_lhm/article/details/134825695
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。