Mycat 配置文件server.xml

server.xml 几乎保存了所有 mycat 需要的系统配置信息。

1、system 标签:

  该标签内嵌套的所有 property 标签都与系统配置有关。

charset 属性:

  该属性用于字符集设置。

<system>
    <property name="charset">utf8</property>
</system>

defaultSqlParser 属性:

  该属性用来指定默认的解析器。目前的可用的取值有:druidparser 和 fdbparser。使用的时候可以选择其中的一种,目前一般都使用 druidparser。1.3 解析器默认为 fdbparser,1.4 默认为 druidparser,1.4 以后 fdbparser 作废。

processors 属性:

  该属性主要用于指定系统可用的线程数,默认值为机器 CPU 核心线程数。主要影响 processorBufferPool、 processorBufferLocalPercent、 processorExecutor 属性。NIOProcessor 的个数也是由这个属性定义的,所以调优的时候可以适当的调高这个属性。

processorBufferChunk 属性:

  该属性指定每次分配 Socket Direct Buffer 的大小,默认是 4096 个字节。这个属性也影响 buffer pool 的长度。如果一次性获取的数过大 buffer 不够用会经常出现警告,此时可以适当调大。

processorBufferPool 属性:

  该属性指定 bufferPool 计算比例值。由于每次执行 NIO 读、写操作都需要使用到 buffer,系统初始化的时候会建立一定长度的 buffer 池来加快读、写的效率,减少建立 buffer 的时间。Mycat 中有两个主要的 buffer 池:

  BufferPool:BufferPool 由 ThreadLocalPool 组合而成,每次从 BufferPool 中获取 buffer 都会优先获取ThreadLocalPool 中的 buffer,未命中之后才会去获取 BufferPool 中的 buffer。也就是说 ThreadLocalPool 是作为 BufferPool 的二级缓存,每个线程内部自己使用的。BufferPool 上的 buffer 则是每个 NIOProcessor 都共享的。

  这个属性的默认值为: 默认bufferChunkSize(4096) * processors属性 * 1000

   BufferPool 的总长度 = bufferPool / bufferChunk。

若 bufferPool 不是 bufferChunk 的整数倍,则总长度为前面计算得出的商 + 1

假设系统线程数为 4,其他都为属性的默认值,则:

bufferPool = 4096 * 4 * 1000

BufferPool 的总长度 : 4000 = 16384000 / 4096

processorBufferLocalPercent 属性:

  前面提到了 ThreadLocalPool。这个属性就是用来控制分配这个 pool 的大小用的,这个属性默认值为 100。

  线程缓存百分比 = bufferLocalPercent / processors 属性。

  例如,系统可以同时运行 4 个线程,使用默认值,则根据公式每个线程的百分比为 25。最后根据这个百分比来计算出具体的 ThreadLocalPool 的长度公式如下:

  ThreadLocalPool 的长度 = 线程缓存百分比 * BufferPool 长度 / 100

  假设 BufferPool 的长度为 4000,其他保持默认值。

  那么最后每个线程建立上的 ThreadLocalPool 的长度为: 1000 = 25 * 4000 / 100

processorExecutor 属性:

  这个属性主要用于指定 NIOProcessor 上共享的 businessExecutor 固定线程池大小。 mycat 在需要处理一些异步逻辑的时候会把任务提交到这个线程池中。新版本中这个连接池的使用频率不是很大了,可以设置一个较小的值。

sequnceHandlerType 属性:

  指定使用 Mycat 全局序列的类型。 0 为本地文件方式,1 为数据库方式,2 为时间戳序列方式,3 为分布式ZK ID 生成器,4 为 zk 递增 id 生成。

TCP 连接相关属性:

  • StandardSocketOptions.SO_RCVBUF
  • StandardSocketOptions.SO_SNDBUF
  • StandardSocketOptions.TCP_NODELAY

以上这三个属性,分别由:

  frontSocketSoRcvbuf 默认值: 1024 * 1024

  frontSocketSoSndbuf 默认值: 4 * 1024 * 1024

  frontSocketNoDelay 默认值: 1

  backSocketSoRcvbuf 默认值: 4 * 1024 * 1024

  backSocketSoSndbuf 默认值: 1024 * 1024

  backSocketNoDelay 默认值: 1

各自设置前后端 TCP 连接参数。 Mycat 在每次建立前、后端连接的时候都会使用这些参数初始化连接。可以按系统要求适当的调整这些 buffer 的大小。

其他涉及属性:

1.1、心跳属性

mycat 中有几个周期性的任务来异步的处理一些我需要的工作。这些属性就在系统调优的过程中也是比不可少的。

processorCheckPeriod :

  清理 NIOProcessor 上前后端空闲、超时和关闭连接的间隔时间。默认是 1 秒,单位毫秒。

dataNodeIdleCheckPeriod :

  对后端连接进行空闲、超时检查的时间间隔,默认是 300 秒,单位毫秒。

dataNodeHeartbeatPeriod :

  对后端所有读、写库发起心跳的间隔时间,默认是 10 秒,单位毫秒。

1.2、服务相关属性

这里介绍一个与服务相关的属性,主要会影响外部系统对 myact 的感知。

bindIp :

  mycat 服务监听的 IP 地址,默认值为 0.0.0.0。

serverPort :

  定义 mycat 的使用端口,默认值为 8066。

managerPort :

  定义 mycat 的管理端口,默认值为 9066。

1.3、Mysql 连接相关属性

初始化 mysql 前后端连接所涉及到的一些属性:

packetHeaderSize :

  指定 Mysql 协议中的报文头长度。默认 4。

maxPacketSize :

  指定 Mysql 协议可以携带的数据最大长度。默认 16M。

idleTimeout :

  指定连接的空闲超时时间。某连接在发起空闲检查下,发现距离上次使用超过了空闲时间,那么这个连接会被回收,就是被直接的关闭掉。默认 30 分钟,单位毫秒。

charset :

  连接的初始化字符集。默认为 utf8。

txIsolation :

  前端连接的初始化事务隔离级别,只在初始化的时候使用,后续会根据客户端传递过来的属性对后端数据库连接进行同步。默认为 REPEATED_READ,设置值为数字默认 3。

  •   READ_UNCOMMITTED = 1;
  •   READ_COMMITTED = 2;
  •   REPEATED_READ = 3;
  •   SERIALIZABLE = 4;

sqlExecuteTimeout :

  SQL 执行超时的时间,Mycat 会检查连接上最后一次执行 SQL 的时间,若超过这个时间则会直接关闭这连接。默认时间为 300 秒,单位秒。

2、user 标签

<user name="test">
    <property name="password">123456</property>
    <property name="schemas">TESTDB</property>
    <property name="readOnly">true</property>
    <property name="benchmark">111111</property>
    <proerty name="usingDecrypt">1</property>
    <privileges check="false">
        <schema name="TESTDB" dml="0010" showTables="custome/mysql">
            <table name="tb_user" dml="0110"></table>
            <table name="tb_dynamic dml="1111"></table>
        </schema>
    </privileges>
</user>  

该标签主要用于定义登录 mycat 的用户和权限。示例定义了一个用户,用户名为 test、密码为123456,可访问的 schema 也只有 TESTDB 一个。

property属性 :

  声明具体的属性值,例如修改schemas内的文本来控制用户可访问的 schema,同时访问多个 schema 的话使用,隔开,例如:

<property name="schemas">TESTDB,db1,db2<property>

Benchmark 属性:

  用于mycat连接服务降级处理:benchmark基准,当前端的整体connection数达到基准值时,对来自该账户的请求开始拒绝连接,0或不设表示不限制。

usingDecrypt 属性:

  是否对密码加密。默认0表示不开启,1表示开启密码加密,同时使用加密程序对密码加密。

privileges 属性:

  对用户的 schema 及下级的 table 进行精细化的 DML 权限控制。

  check 属性是用于标识是否开启 DML 权限检查, 默认 false 标识不检查。由于 Mycat 一个用户的 schemas 属性可配置多个 schema ,所以 privileges 的下级节点 schema 节点同样可配置多个,对多库多表进行细粒度的 DML 权限控制。

  Schema/Table 上的 dml 属性:

原文地址:https://www.cnblogs.com/kingsonfu/p/10627285.html

时间: 2024-08-30 12:10:38

Mycat 配置文件server.xml的相关文章

Tomcat主配置文件Server.xml详解

Tomcat主配置文件Server.xml详解 1.软件版本 [[email protected] META-INF]# java -version java version "1.8.0_60" Java(TM) SE Runtime Environment (build 1.8.0_60-b27) Java HotSpot(TM) 64-Bit Server VM (build 25.60-b23, mixed mode) 2.server.xml组件类别 顶级组件:位于整个配置的

omcat配置文件server.xml详解

首先,看一下tomcat的目录结构: bin            存放启动和关闭tomcat脚本 conf          包含不同的配置文件,server.xml(Tomcat的主要配置文件)和web.xml work          存放jsp编译后产生的class文件 webapp     存放应用程序示例,以后你要部署的应用程序也要放到此目录 logs           存放日志文件 lib/japser/common    这三个目录主要存放tomcat所需的jar文件 ---

tomcat之配置文件server.xml综合分析

最近有两件完全背道而驰的事情同时发生,第一件事情是以SEO业务为主要业务的业者逐渐减少,许多原本是SEO的业者都纷纷转向其他业务,SEO业务反而变成副业.第二件事情是中小企业的SEO需求增加了,并且大多以钱少人累为主.当然这个观察只是片面的资料,不能说是全面SEO的现况,但是至少反应出了一些问题... SEO的业者之所以会纷纷转向其他业务,当然是因为没有足够的客户来支撑,但是奇怪的是近期所接触的中小企业反而是增高了SEO的需求,为何这些需求没能变成SEO业者的客户呢? 因为这些中小企业可能都已经

Tomcat的配置文件 -- server.xml(一)

一.tomcat配置文件server.xml包含的元素分类 1.顶层类元素:<server> <service> 位于整个配置文件的顶层 2.连接器类元素:<connector> 客户和容器类元素的通讯接口 3.容器类元素:<engine> <host> <context> 处理客户请求并且生成响应结果 4.嵌套类元素:<logger> <value> <realm> 可加入到容器中的元素 配置文件

(2) tomcat配置文件server.xml详解

1. 入门示例:虚拟主机提供web服务 该示例通过设置虚拟主机来提供web服务,因为是入门示例,所以设置极其简单,只需修改$CATALINA_HOME/conf/server.xml文件为如下内容即可,本文的tomcat安装在/application/tomcat下,因此$CATALINA_HOME=/application/tomcat. 其中大部分都采用了默认设置,只是在engine容器中添加了两个Host容器. <?xml version="1.0" encoding=&q

tomcat 配置文件server.xml标签介绍

tomcat的配置文件在其安装后生成的conf目录下,其中主配置文件便是conf下的server.xml文件. server.xml文件由server->service->engine->host->context结构组成. server标签: tomcat实例顶层元素,代表整个容器.server标签里面指定了监听shutdown命令的端口.默认为8005 <Server port="8005" shutdown="SHUTDOWN"&

Tomcat的配置文件Server.xml解析

配置元素说明: 元素名 属性 解释 server port 指定一个端口,这个端口负责监听关闭tomcat 的请求 shutdown 指定向端口发送的命令字符串 service name 指定service 的名字 Connector ( 表示客户端和service之间的连接) port 指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求 minProcessors 服务器启动时创建的处理请求的线程数 maxProcessors 最大可以创建的处理请求的线程数 enableLookup

tomcat 的配置文件 server.xml 详解

server.xml位于$TOMCAT_HOME/conf目录下,作为整个tomcat 服务器最核心的配置文件,server.xml的每一个元素都对应了tomcat中的一个组件,通过对xml中元素的配置,实现对tomcat中的各个组件和端口的配置.通常初学者可以直接使用默认配置即可,但当你本机由于各种原因(如分布式.多IDE等)需要配置多个tomcat时,就需要对server.xml的配置有一定了解. 1. server.xml配置实例 下面是实际开发环境中的tomcat7,端口保持默认,增加了

详解Tomcat 配置文件server.xml

前言 Tomcat隶属于Apache基金会,是开源的轻量级Web应用服务器,使用非常广泛.server.xml是Tomcat中最重要的配置文件,server.xml的每一个元素都对应了Tomcat中的一个组件:通过对xml文件中元素的配置,可以实现对Tomcat中各个组件的控制.因此,学习server.xml文件的配置,对于了解和使用Tomcat至关重要. 本文将通过实例,介绍server.xml中各个组件的配置,并详细说明Tomcat各个核心组件的作用以及各个组件之间的相互关系. 说明:由于s