通过jdbcurl方式传入
属性 | 数据类型 | 默认值 | 备注 |
---|---|---|---|
deepPaginationThreshold | int | 1000000000 | 用来设置深度分页优化的临界值,超过此参数大小会开启深度分页优化(转为流式查询) |
role | String | rw | 用来配置读写分离,默认role=rw role=rr 优先读replica,replica不可用时读rdonly role=ro 读rdonly,rdonly不可用时报错。需要注意的是,rdonly节点一般用于抽数和备份,OOM风险高于其他节点 role=rrm 优先读replica,replica不可用时读rdonly,rdonly不可用时读取master |
vtPlanCacheCapacity | int | 300 | 该参数用来设置执行计划缓存cache大小,最大值10240 |
queryConsolidator | boolean | false | 用来开启Consolidator,仅在role=rr场景生效;相同的sql语句只执行一次,其余线程等待第一次查询返回结果后返回 |
queryParallelNum | int | 1 | 在分表场景下,执行事务外的SQL语句时每个分片上可开启的最大并发数 |
属性 | 数据类型 | 默认值 | 备注 |
---|---|---|---|
user | String | 连接的用户 | |
password | String | 连接时使用的密码 | |
characterEncoding | String | utf8 | 是指定所处理字符的解码和编码的格式,或者说是标准。若项目的字符集和MySQL数据库字符集设置为同一字符集则url可以不加此参数 |
serverTimezone | String | 设置时区 | |
socketTimeout | int | 10000 | 单位ms,查询超时时间 |
allowMultiQueries | boolean | true | 在一条语句中,允许使用“;”来分隔多条查询。不可更改,VtDriver强制设置为true |
maxAllowedPacket | byte | 65535(64k) | 设置server接受的数据包的大小 |
zeroDateTimeBehavior | String | exception | JAVA连接MySQL数据库,在操作值为0的timestamp类型时不能正确的处理,而是默认抛出一个异常。 参数: exception:默认值 convertToNull:将日期转换成NULL值 round:替换成最近的日期 |
sendFractionalSeconds | boolean | true | 指定发送TIMESTAMPSCHEMA的小数秒部分。若该属性为false,则TIMESTAMP的纳秒部分在发送给服务器之前会被截断。该属性适用于预处理语句,可调用的语句,或可更新的结果集 |
treatUtilDateAsTimestamp | boolean | true | 为了PreparedStatement.setObject(),驱动程序是否将java.util.Date视为TIMESTAMP |
useStreamLengthsInPrepStmts | boolean | true | 是否使用PreparedStatement/ResultSet.setXXXStream()方法调用中的流长度参数?true/false,默认为“true”。 |
autoClosePStmtStreams | boolean | false | 驱动程序是否自动调用.close()在流/读取器作为参数传递通过set *()方法? |
autoReconnect | boolean | false | CATALOG 驱动程序是否应尝试再次建立失效的链接或死连接? |
connectTimeout | long | 0 | 套接字连接的超时(单位为毫秒),0表示无超时 |
useSSL | boolean | false | 在与服务器通信时使用SSL |
useAffectedRows | boolean | false | 当连接到服务器时不要设置“client_found_rows”标签 (这个是不符合JDBC标准的,它会破坏大部分依赖“found”VS DML语句下的”affected”应用程序)。但是会导致“insert”里面的“Correct”更新数据。服务器会返回“ON Duplicate Key update”的状态 |
rewriteBatchedStatements | boolean | false | 针对Statement.executeBatch(), 是否使用MultiQuery方式执行。在VtDriver分表场景,由于分表底层已开启MultiQuery,不能开启这个参数 |
属性 | 数据类型 | 默认值 | 备注 |
---|---|---|---|
vtMinimumIdle | int | 5 | 最小连接数(初始连接数) |
vtMaximumPoolSize | int | 10 | 最大连接数 |
vtConnectionInitSql | String | select 1 | 此属性设置一个SQL语句,该语句将在每次创建新连接之后执行,然后再将其添加到池中。如果此SQL无效或引发异常,则将其视为连接失败,并将遵循标准重试逻辑。 |
vtConnectionTimeout | long | 1000 | 此属性控制客户端等待池中连接的最大毫秒数。如果在没有连接可用的情况下超过此时间,则将抛出SQLException。最低可接受的连接超时为250毫秒。 |
vtIdleTimeout | long | 600000(10分钟) | 此属性控制允许连接在池中处于空闲状态的最长时间。(此设置仅在大于vtMinimumIdle小于vtMaximumPoolSize时才适用。一旦池到达连接, 空闲连接将不会退出minimumIdle。连接是否空闲退出的最大变化为+30秒,平均变化为+15秒。在此超时之前,连接永远不会被空闲)值为0表示永远不会从池中删除空闲连接。允许的最小值为10000毫秒(10秒)。 |
vtMaxLifetime | long | 10800000(3小时) | 此属性控制池中连接的最长生命周期。使用中的连接永远不会退役。 强烈建议您设置此值,它应比任何数据库或基础结构强加的连接时间限制短几秒。 值0表示没有最大寿命(无限寿命)。 如果设置成0会出现问题:长时间没对库进行操作(超过8小时)连接会依然在池内, 超过8小时数据库会断开与客户端的链接,在时用此链接必定报错 如果不等于0且小于30秒则会被重置回30分钟。 |
vtValidationTimeout | long | 1000 | 此属性控制连接测试活动的最长时间。该值必须小于connectionTimeout。最低可接受的验证超时为250毫秒。当设置的vtValidationTimeout大于vtConnectionTimeout时,vtValidationTimeout将被设置为vtConnectionTimeout的1/2 |
注:vtMinimumIdle
和vtMaximumPoolSize
两个参数同时未指定且分片数大于等于8时, 默认值有所不同:
- 分片数>=8且<16时,
vtMinimumIdle
/vtMaximumPoolSize
= 4 / 8。 - 分片数>=16且<32时,
vtMinimumIdle
/vtMaximumPoolSize
= 3 / 6。 - 分片数>=32且<64时,
vtMinimumIdle
/vtMaximumPoolSize
= 2 / 5。 - 分片数>=64时,
vtMinimumIdle
/vtMaximumPoolSize
= 2 / 4。
通过-DVtDriver.api.port=9999方式传入
属性 | 数据类型 | 默认值 | 备注 |
---|---|---|---|
vtdriver.api.port | int | 15002 | 指定开启的http端口 |
vtdriver.monitor.port | int | 15001 | 指定开启的http端口(prometheus) |
vtdriver.secondsBehindMaster | int | 7200 | 指定HealthCheck中判定tablet为可用的最大主从延迟,默认值为7200s |
vtdriver.queryCoreSize | int | jdk1.8.0_131以前的版本默认值为8,之后的版本的默认值根据应用容器的cpu核数来设定,核数小于8取8,核数大于32取32,核数在8-32之间取应用cpu核数 | 执行SQL线程池核心线程数 |
vtdriver.queryMaximumSize | int | 100 | 执行SQL线程池最大线程数 |
vtdriver.queryQueueSize | int | 1000 | 执行SQL线程池任务队列长度 |
vtdriver.queryRejectedTimeout | long | 3000 | 执行SQL线程池拒绝任务丢弃超时(毫秒) |
vtdriver.healthCheckCoreSize | int | 10 | healthCheck线程池核心线程数 |
vtdriver.healthCheckMaximumSize | int | 100 | healthCheck线程池最大线程数 |
vtdriver.healthCheckQueueSize | int | 10000 | healthCheck线程池任务队列长度 |
vtdriver.healthCheckRejectedTimeout | long | 3000 | healthCheck线程池拒绝任务丢弃超时(毫秒) |
vtdriver.topoExecuteTimeout | long | 10000 | 访问拓扑元数据的执行超时时间(毫秒) |
vtdriver.topoConnectTimeout | long | 5000 | 访问拓扑元数据连接超时时间(毫秒) |