客户端驱动参考手册
TDengine 客户端驱动提供了应用编程所需要的全部 API,并且在整个集群的分布式计算中扮演着重要角色。客户端驱动的行为除了 API 及其具体参数以外,也可以通过配置文件的形式进行全局控制,本节列举 TDengine 客户端可以使用的配置参数。
配置参数
连接相关
firstEp
- 说明:启动时,主动连接的集群中首个 dnode 的 endpoint
- 默认值:hostname:6030,若无法获取该服务器的 hostname,则赋值为 localhost
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
secondEp
- 说明:启动时,如果 firstEp 连接不上,尝试连接集群中第二个 dnode 的 endpoint
- 默认值:无
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
serverPort
- 说明:taosd 监听的端口
- 默认值:6030
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
compressMsgSize
- 说明:是否对 RPC 消息进行压缩
- 类型:整数;-1:所有消息都不压缩;0:所有消息都压缩;N (N>0):只有大于 N 个字节的消息才压缩
- 单位:bytes
- 默认值:-1
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
shellActivityTimer
- 说明:客户端向 mnode 发送心跳的时长
- 类型:整数
- 单位:秒
- 默认值:3
- 最小值:1
- 最大值:120
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
numOfRpcSessions
- 说明:RPC 支持的最大连接数
- 类型:整数
- 默认值:30000
- 最小值:100
- 最大值:100000
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
numOfRpcThreads
- 说明:RPC 收发数据线程数目
- 类型:整数
- 默认值:CPU 核数的一半
- 最小值:1
- 最大值:50
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
numOfTaskQueueThreads
- 说明:客户端处理 RPC消息的线程数
- 类型:整数
- 默认值:CPU 核数的一半
- 最小值:4
- 最大值:16
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
timeToGetAvailableConn
- 说明:获得可用连接的最长等待时间
- 类型:整数
- 单位:毫秒
- 默认值:500000
- 最小值:10
- 最大值:50000000
- 动态修改:不支持
- 支持版本:3.3.4.*之后取消
useAdapter
- 说明:是否使用 taosadapter,影响 CSV 文件导入
内部参数
- 动态修改:支持通过 SQL 修改,立 即生效
- 支持版本:从 v3.0.0.0 版本开始引入
shareConnLimit
- 说明:一个链接可以共享的查询数目
内部参数
- 最小值:1
- 最大值:256
- 默认值:10
- 动态修改:不支持
- 支持版本:从 v3.3.4.0 版本开始引入
readTimeout
- 说明:最小超时时间
内部参数
- 单位:秒
- 最小值:64
- 最大值:604800
- 默认值:900
- 动态修改:不支持
- 支持版本:从 v3.3.4.0 版本开始引入
查询相关
countAlwaysReturnValue
- 说明:count/hyperloglog 函数在输入数据为空或者 NULL 的情况下是否返回值;该参数设置为 1 时,如果查询中含有 INTERVAL 子句或者该查询使用了 TSMA 时,且相应的组或窗口内数据为空或者 NULL,对应的组或窗口将不返回查询结果;注意此参数客户端和服务端值应保持一致
- 类型:整数;0:返回空行,1:返回
- 最小值:0
- 最大值:1
- 默认值:1
- 动态修改:支持通过 SQL 修改 ,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
keepColumnName
- 说明:Last、First、LastRow 函数查询且未指定别名时,自动设置别名为列名(不含函数名),因此 order by 子句如果引用了该列名将自动引用该列对应的函数
- 类型:整数;1:表示自动设置别名为列名(不包含函数名),0:表示不自动设置别名
- 最小值:0
- 最大值:1
- 默认值:0
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
multiResultFunctionStarReturnTags
- 说明:查询超级表时,last(*)/last_row(*)/first(*) 是否返回标签列;查询普通表、子表时,不受该参数影响;
- 类型:整数;0:不返回标签列,1:返回标签列;该参数设置为 0 时,last(*)/last_row(*)/first(*) 只返回超级表的普通列;为 1 时,返回超级表的普通列和标签列
- 最小值:0
- 最大值:1
- 默认值:0
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.3.3.0 版本开始引入
metaCacheMaxSize
- 说明:指定单个客户端元数据缓存大小的最大值
- 类型:整 数;0:不返回标签列,1:返回标签列;该参数设置为 0 时,last(*)/last_row(*)/first(*) 只返回超级表的普通列;为 1 时,返回超级表的普通列和标签列
- 单位:MB
- 最小值:-1
- 最大值:2147483647
- 默认值:-1 表示无限制
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
maxTsmaCalcDelay
- 说明:查询时客户端可允许的 tsma 计算延迟,若 tsma 的计算延迟大于配置值,则该 TSMA 将不会被使用
- 类型:整数
- 单位:秒
- 最小值:600
- 最大值:86400
- 默认值:600
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
tsmaDataDeleteMark
- 说明:TSMA 计算的历史数据中间结果保存时间
- 类型:整数
- 单位:毫秒
- 最小值:3600000
- 最大值:9223372036854775807
- 默认值:86400000
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryPolicy
- 说明:查询语句的执行策略
- 类型:整数;1:只使用 vnode,不使用 qnode;2:没有扫描算子的子任务在 qnode 执行,带扫描算子的子任务在 vnode 执行;3:vnode 只运行扫描算子,其余算子均在 qnode 执行;
- 单位:秒
- 默认值:1
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryTableNotExistAsEmpty
- 说明:查询表不存在时是否返回空结果集
- 类型:布尔;false:返回错误;true:返回空结果集
- 默认值:false
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
querySmaOptimize
- 说明:querSmaOptimize,永远从原始数据进行查询
- 类型:整数 ;1:表示使用 sma index,对符合的语句,直接从预计算的结果进行查询
- 默认值:false
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryPlannerTrace
- 说明:查询计划是否输出详细日志
内部参数
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryNodeChunkSize
- 说明:查询计划的块大小
内部参数
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryUseNodeAllocator
- 说明:查询计划的分配方法
内部参数
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
queryMaxConcurrentTables
- 说明:查询计划的并发数目
内部参数
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
enableQueryHb
- 说明:是否发送查询心跳消息
内部参数
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
minSlidingTime
- 说明:sliding 的最小允许值
内部参数
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
minIntervalTime
- 说明:interval 的最小允许值
内部参数
- 动态修改:不支持
- 支持版本:从 v3.0.0.0 版本开始引入
写入相关
smlChildTableName
- 说明:schemaless 自定义的子表名的 key
- 默认值:无
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
smlAutoChildTableNameDelimiter
- 说明:schemaless tag 之间的连接符,连起来作为子表名
- 默认值:无
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
smlTagName
- 说明:schemaless tag 为空时默认的 tag 名字
- 默认值:"_tag_null"
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
smlTsDefaultName
- 说明:schemaless 自动建表的时间列名字通过该配置设置
- 默认值:"_ts"
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
smlDot2Underline
- 说明:schemaless 把超级表名中的 dot 转成下划线
- 默认值:true
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
maxInsertBatchRows
- 说明:一批写入的最大条数
- 默认值:1000000
- 最小值:1
- 最大值:2147483647
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.0.0.0 版本开始引入
区域相关
timezone
- 说明:时区
- 默认值:从系统中动态获取当前的时区设置
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
locale
- 说明:系统区位信息及编码格式
- 默认值:从系统中获取
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
charset
- 说明:字符集编码
- 默认值:从系统中获取
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
存储相关
tempDir
- 说明:指定所有运行过程中的临时文件生成的目录
- 默认值:Linux 平台默认值为 /tmp
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
minimalTmpDirGB
- 说明:tempDir 所指定的临时文件目录所需要保留的最小空间
- 类型:浮点数
- 单位:GB
- 默认值:1
- 最小值:0.001f
- 最大值:10000000
- 动态修改:不支持
- 支持版本:从 v3.1.0.0 版本开始引入
日志相关
logDir
- 说明:日志文件目录,运行日志将写入该目录
- 类型:字符串
- 默认值:/var/log/taos
- 动态修改:不支持
- 支持版本:从 v3.1.0.0 版本开始引入
minimalLogDirGB
- 说明:日志文件夹所在磁盘可用空间大小小于该值时,停止写日志
- 类型:浮点数
- 单位:GB
- 默认值:1
- 最小值:0.001f
- 最大值:10000000
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
numOfLogLines
- 说明:单个日志文件允许的最大行数
- 类型:整数
- 默认值:10,000,000
- 最小值:1000
- 最大值:2000000000
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
asyncLog
- 说明:日志写入模式
- 类型:整数;0:同步,1:异步
- 默认值:1
- 最小值:0
- 最大值:1
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
logKeepDays
- 说明:日志文件的最长保存时间,小于等于0意味着只有两个日志文件相互切换保存日志,超过两个文件保存数量的日志会被删除;当设置为大于 0 的值时,当日志文件大小达到设置的上限时会被重命名为 taosdlog.yyy,其中 yyy 为日志文件最后修改的时间戳,并滚动产生新的日志文件
- 类型:整数;0
- 单位:天
- 默认值:0
- 最小值:-365000
- 最大值:365000
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
debugFlag
- 说明:运行日志开关,该参数的设置会影响所有模块的开关,后设置的参数起效
- 类型:整数
- 取值范围:131(输出错误和警告日志),135(输出错误、警告和调试日志),143(输出错误、警告、调试和跟踪日志)
- 默认值:131 或 135 (取决于不同模块)
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
tmrDebugFlag
- 说明:定时器模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通 过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
uDebugFlag
- 说明:共用功能模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
rpcDebugFlag
- 说明:rpc 模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
jniDebugFlag
- 说明:jni 模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
qDebugFlag
- 说明:query 模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
cDebugFlag
- 说明:客户端模块的日志开关
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
simDebugFlag
- 说明:测试工具的日志开关
内部参数
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
tqClientDebugFlag
- 说明:测试工具的日志开关
内部参数
- 类型:整数
- 取值范围:同上
- 默认值:131
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
调试相关
crashReporting
- 说明:是否上传 crash 到 telemetry
- 类型:整数;0:不上传,1:上传;
- 默认值:1
- 最小值:0
- 最大值:1
- 动态修改: 支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
enableCoreFile
- 说明:crash 时是否生成 core 文件
- 类型:整数;0:不生成,1:生成;
- 默认值:1
- 最小值:0
- 最大值:1
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.1.0.0 版本开始引入
assert
- 说明:断言控制开关
- 类型:整数;0:关闭,1:开启
- 默认值:0
- 最小值:0
- 最大值:1
- 动态修改:不支持
- 支持版本:从 v3.1.0.0 版本开始引入
configDir
- 说明:配置文件所在目录
- 类型:字符串
- 动态修改:不支持
- 支持版本:从 v3.1.0.0 版本开始引入
scriptDir
- 说明:测试工具的脚本目录
内部参数
- 类型:字符串
- 动态修改:不支持
- 支持版本:从 v3.3.3.0 版本开始引入
randErrorChance
- 说明:用于随机失败测试
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.3.0 版本开始引入
randErrorDivisor
- 说明:用于随机失败测试
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.3.0 版本开始引入
randErrorScope
- 说明:用于随机失败测试
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.3.0 版本开始引入
safetyCheckLevel
- 说明:用于随机失败测试
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.3.0 版本开始引入
simdEnable
- 说明:用于测试 SIMD 加速
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.4.3 版本开始引入
AVX512Enable
- 说明:用于测试 AVX512 加速
内部参数
- 动态修改:不支持
- 支持版本:从 v3.3.4.3 版本开始引入
bypassFlag
- 说明:用于短路测试
内部参数
- 类型:整数;
- 取值范围:0:正常写入,1:写入消息在 taos 客户端发送 RPC 消息前返回,2:写入消息在 taosd 服务端收到 RPC 消息后返回,4:写入消息在 taosd 服务端写入内存缓存前返回,8:写入消息在 taosd 服务端数据落盘前返回
- 默认值:0
- 动态修改:支持通过 SQL 修改,立即生效
- 支持版本:从 v3.3.4.5 版本开始引入
SHELL 相关
enableScience
- 说明:是否开启科学计数法显示浮点数
- 类型:整数;0:不开始,1:开启;
- 默认值:1
- 最小值:0
- 最大值:1
- 动态修改:不支持
- 支持版本:从 v3.1.0.0 版本开始引入
API
请参考连接器