0%

Mycat配置读写分离

配置schema.xml配置文件,schema.xml管理着mycat的逻辑库、表、分片规则、DataNode以及DataSource

  • schema标签用于定义mycat实例中的逻辑库
  • table标签定义mycat中的逻辑表
  • dataNode标签定义mycat中的数据节点
  • dataHost标签定义具体的数据库实例、读写分离配置和心跳检测
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

<!-- 逻辑库 可以配置多个逻辑库 -->
<schema name="TESTDB" checkSQLschema="true" sqlMaxLimit="100" dataNode="dn1">

</schema>

<!-- 数据节点,真实的数据库 -->
<dataNode name="dn1" dataHost="host1" database="mybatis" />

<!-- 数据主机配置
balance是用来配置读写分离的
0:不开启读写分离,所有的读请求都发送到当前可用的writeHost写主机上
1:全部的readHost与writeHost(备主写)参与select语句的负载均衡,双主双从,且双主互为主备
2:所有的读操作随机在writeHost和readHost上分发
3:所有的读请求随机分发到readHost,writeHost不负担读压力

writeType 多主配置使用
0:所有写操作都发送到第一个writeHost,第一个挂了切换到第二个writeHost
1:所有写操作都随机发送到配置的writeHost,1.5后废弃不推荐使用

switchType 写主机切换方式
1:默认值,自动切换
-1:不自动切换
2:基于Mysql主从同步的状态决定是否切换
-->
<dataHost name="host1" maxCon="1000" minCon="10" balance="3"
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="123456">
</writeHost>

<!-- 读主机 -->
<readHost host="hostS1" url="localhost:3307" user="root"
password="123456"></readHost>
</dataHost>
</mycat:schema>

springboot注解

springboot中取消了大部分的xml配置,以及进行了很多的默认配置,取而代之的就是注解,所以在一个springboot项目中需要大量的使用注解

@SpringBootApplication注解

这个注解如果没见过,那么可能是没用过springboot的朋友,这个注解是用来标注springboot项目的,是一个组合注解,由三个注解组成

1
2
3
@SpringBootConfiguration // 这个注解就是个套了层壳子的@Configuration
@EnableAutoConfiguration// 开启自动配置的注解,使用该注解之后,springboot就会根据当前类路径下的包或者类来配置springbean,扫描各个xxxAutoConfiguration类
@ComponentScan // 组件扫描,这个在spring中就已经有了
阅读全文 »

tomcat配置项目位置

默认

tomcat会自动映射webapps目录下的所有web应用

为什么是webapps目录呢?是因为默认在server.xml中配置的Host配置的appBase为webapps

自定义

当然不想将应用放到webapps下也可以,那就需要自己配置Context了,

tomcat在加载一个web应用时,会一次按照以下五种方式查找web应用中的元素,优先级一次降低,直到找到为止

  • 到Tomcat安装目录/conf/Context.xml文件中查找元素。

  • 到Tomcat安装目录/conf/[enginename]/[hostname]/context.xml.default文件中查找元素。

  • 到Tomcat安装目录/conf/[enginename]/[hostname]/[contextpath].xml文件中查找元素

  • 到Web应用的META-INF/context.xml文件中查找元素

  • 到Tomcat安装目录/conf/server.xml文件中查找元素。只适用于单个Web应用

1
2
3
4
5
6
<!-- path为web应用的根路径  
docBase为项目路径(编译之后的项目)
reloadable若为true,表示tomcat服务器在运行状态下会监视在WEB-INF/classes和WEB-INF/lib目录下的class文件的变动,以及监视web应用的WEB-INF/web.xml的改动,如果发现改动会自动更新加载web应用
className 指定实现Context组件的java类名,默认为org.apache.catalina.core.StandardContext,一般不需要设置,使用默认即可
-->
<Context path="" docBase="" reloadable="true">

Mycat配置文件

Mycat简介中有提到Mycat有三个重要的配置文件schema.xmlserver.xmlrule.xml ,还有一些其他的依赖配置文件,接下来就分别介绍一下

server.xml配置文件

定义Mycat用户以及系统相关变量,如用户名、密码、端口等

两个重要的标签为user标签和system标签

user标签

主要用于定义登录Mycat的用户和权限

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<!-- 用户 name表示用户名-->
<user name="mycat" defaultAccount="true">

<property name="password">123456</property>
<!-- 该用户可以访问的schema -->
<property name="schemas">TESTDB,db1,db2</property>
<property name="defaultSchema">TESTDB</property>
<!-- 是否只读 -->
<property name="readOnly">true</property>
<!-- benchmark用于现在整体连接数量,如果为0或不设置则表示不限制 -->
<property name="benchmark">1000</property>
<!-- 是否使用密码加密功能,默认为0
加密命令为java -cp Mycat-server-1.6.7.4-release.jar org.opencloudb.util.DecryptUtil 0:user:password
-->
<property name="usingDecrypt">1000</property>
<!--No MyCAT Database selected 错误前会尝试使用该schema作为schema,不设置则为null,报错 -->

<!-- 表级 DML 权限设置 -->
<!--
<privileges check="false">
<schema name="TESTDB" dml="0110" >
<table name="tb01" dml="0000"></table>
<table name="tb02" dml="1111"></table>
</schema>
</privileges>
-->
</user>
阅读全文 »

Mycat简介

Mycat是一款数据库中间件,一端连数据库,一端连java应用,可以支持MySQL、SQL Server、Oracle、DB2、PostgreSQL等主流数据,用于解决以下问题

  • java与数据库紧耦合
  • 高访问量、高并发对数据库压力
  • 读写请求数据不一致

可以用来做 读写分离数据分片多数据源整合

Mycat的原理就是拦截用户发送的SQL语句,对SQL语句做特定的分析:如分片分析、路由分析、读写分离分析、缓存分析等,然后将此SQL语句发送到真实数据库,并将返回的结果做适当的处理,最终再返回给用户

属于中间件代理,偏运维

阅读全文 »