TDengine C# 语言连接器进阶指南

本指南面向已完成“能连通、能读写”的开发者,补齐高级用法与易踩坑点。

1. 连接参数进阶与调优

WebSocket 连接增强参数

WebSocket 连接除基础参数外,还支持:

  • connTimeout:连接超时(默认 1 分钟)
  • readTimeout:读取超时(默认 5 分钟)
  • writeTimeout:发送超时(默认 10 秒)
  • enableCompression:是否启用压缩
  • autoReconnect:是否自动重连
  • reconnectRetryCount/reconnectIntervalMs:重连次数与间隔
  • token:TDengine Cloud Token
  • useSSL:是否启用 SSL

示例连接字符串:

protocol=WebSocket;host=127.0.0.1;port=6041;useSSL=false;enableCompression=true;autoReconnect=true;reconnectIntervalMs=10;reconnectRetryCount=5

连接级别时区(3.1.8+)

  • 仅支持 .NET 6+,仅支持 IANA 时区格式(如America/New_York
  • timezone互斥
  • Windows 平台原生连接不支持

2. RequestId 与可观测性

部分 API 支持传入reqId,便于日志/链路追踪。

usingTDengine.Driver;usingTDengine.Driver.Client;varbuilder=newConnectionStringBuilder("host=localhost;port=6030;username=root;password=taosdata");using(varclient=DbDriver.Open(builder)){using(varrows=client.Query("SELECT ts, current FROM power.meters LIMIT 1",3)){while(rows.Read()){/*...*/}}}

无模式写入时可通过ReqId.GetReqId()生成请求 ID(见第 4 节)。

3. 批量写入:Stmt 绑定

高吞吐写入推荐使用Stmt批量绑定。示例来自官方stmtInsert

usingTDengine.Driver;usingTDengine.Driver.Client;varbuilder=newConnectionStringBuilder("host=127.0.0.1;port=6030;username=root;password=taosdata");using(varclient=DbDriver.Open(builder)){client.Exec("CREATE DATABASE IF NOT EXISTS power");client.Exec("USE power");client.Exec("CREATE STABLE IF NOT EXISTS meters (ts TIMESTAMP, current FLOAT, voltage INT, phase FLOAT) TAGS (groupId INT, location BINARY(24))");using(varstmt=client.StmtInit()){stringsql="INSERT INTO ? USING meters TAGS(?,?) VALUES (?,?,?,?)";stmt.Prepare(sql);stmt.SetTableName("d_bind_1");stmt.SetTags(newobject[]{1,"location_1"});stmt.BindRow(newobject[]{DateTime.Now,12.3f,220,0.32f});stmt.AddBatch();stmt.Exec();Console.WriteLine($"Inserted:{stmt.Affected()}");}}

完整示例见 stmtInsert/Program.cs。

4. 无模式写入(Schemaless)

支持 Influx Line Protocol / OpenTSDB Telnet / JSON。

usingTDengine.Driver;usingTDengine.Driver.Client;varlineDemo="meters,groupid=2,location=California.SanFrancisco current=10.3000002f64,voltage=219i32,phase=0.31f64 1626006833639";vartelnetDemo="metric_telnet 1707095283260 4 host=host0 interface=eth0";varjsonDemo="{\"metric\": \"metric_json\",\"timestamp\": 1626846400,\"value\": 10.3, \"tags\": {\"groupid\": 2, \"location\": \"California.SanFrancisco\", \"id\": \"d1001\"}}";varbuilder=newConnectionStringBuilder("protocol=WebSocket;host=127.0.0.1;port=6041;username=root;password=taosdata");using(varclient=DbDriver.Open(builder)){client.Exec("CREATE DATABASE IF NOT EXISTS power");client.Exec("USE power");client.SchemalessInsert(new[]{lineDemo},TDengineSchemalessProtocol.TSDB_SML_LINE_PROTOCOL,TDengineSchemalessPrecision.TSDB_SML_TIMESTAMP_MILLI_SECONDS,0,ReqId.GetReqId());client.SchemalessInsert(new[]{telnetDemo},TDengineSchemalessProtocol.TSDB_SML_TELNET_PROTOCOL,TDengineSchemalessPrecision.TSDB_SML_TIMESTAMP_MILLI_SECONDS,0,ReqId.GetReqId());client.SchemalessInsert(new[]{jsonDemo},TDengineSchemalessProtocol.TSDB_SML_JSON_PROTOCOL,TDengineSchemalessPrecision.TSDB_SML_TIMESTAMP_NOT_CONFIGURED,0,ReqId.GetReqId());}

完整示例见 wssml/Program.cs。

5. TMQ 订阅与消费

适用于流式消费场景。核心步骤:创建 consumer、订阅 topic、消费消息、提交 offset。

usingTDengine.TMQ;varcfg=newDictionary<string,string>(){{"td.connect.port","6030"},{"auto.offset.reset","latest"},{"msg.with.table.name","true"},{"enable.auto.commit","true"},{"auto.commit.interval.ms","1000"},{"group.id","group1"},{"client.id","client1"},{"td.connect.ip","127.0.0.1"},{"td.connect.user","root"},{"td.connect.pass","taosdata"},};IConsumer<Dictionary<string,object>>consumer=newConsumerBuilder<Dictionary<string,object>>(cfg).Build();consumer.Subscribe(newList<string>(){"topic_meters"});using(varcr=consumer.Consume(100)){if(cr!=null){foreach(varmessageincr.Message){Console.WriteLine($"{message.Value["ts"]},{message.Value["current"]}");}}}

完整示例见 subscribe/Program.cs。

6. 时间类型与参数绑定注意事项

  • DateTime.Kind == Unspecified不可用于绑定(会导致 UTC 转换错误)。
  • 3.1.8+ 支持DateTimeOffsetlong(与数据库时间精度一致)。
  • 如需统一跨平台时区,优先使用 IANA 时区(如Asia/Shanghai)。

7. 资源与性能最佳实践

  • 使用using管理连接、结果集与消费者,确保及时释放。
  • 大批量写入优先用Stmt或无模式写入;避免逐条Exec
  • WebSocket 大量数据可开启enableCompression,降低带宽。
  • 异常统一捕获TDengineError,打印CodeError

8. 参考与更多示例

  • 连接器参考文档:https://docs.taosdata.com/tdengine-reference/client-libraries/csharp/
  • 示例代码目录:https://github.com/taosdata/TDengine/tree/main/docs/examples/csharp

关于TDengine

TDengine 专为物联网IoT平台、工业大数据平台设计。其中,TDengine TSDB 是一款高性能、分布式的时序数据库(Time Series Database),同时它还带有内建的缓存、流式计算、数据订阅等系统功能;TDengine IDMP 是一款AI原生工业数据管理平台,它通过树状层次结构建立数据目录,对数据进行标准化、情景化,并通过 AI 提供实时分析、可视化、事件管理与报警等功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1179148.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Node.js和包管理工具

Node.js 和 npm 是现代 JavaScript 开发中两个密切相关但功能不同的工具。下面分别解释它们的定义以及它们之间的关系。 一、什么是 Node.js&#xff1f; Node.js 是一个基于 Chrome V8 JavaScript 引擎 构建的运行时环境&#xff08;Runtime Environment&#xff09;&#xff…

人工智能之数据分析 Pandas:第二章 Series - 实践

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

为什么大多数 LLM 在金融和医疗中会“系统性偏保守”

一个常见误解很多人认为&#xff1a;“模型在高风险场景中偏保守&#xff0c;是因为安全对齐或合规要求。”这只是表象。真正原因&#xff1a;执行态被风险信号劫持在缺乏执行态约束的系统中&#xff1a;风险词情绪词责任暗示会直接触发模型进入&#xff1a;防御 / 回避 / 模糊…

WSL2 Win11 Ubuntu22.04 D盘安装 参考的教程记录

主要参考这个教程下载:https://kwanwaipang.github.io/WSL/ 怎样移动到D盘:https://zhuanlan.zhihu.com/p/23313784318

企业内部模型上线前,必须补上的一项测试:执行态稳定性

一个现实问题很多企业在模型上线前&#xff0c;会测试&#xff1a;准确率延迟成本幻觉率但几乎不测试&#xff1a;执行态是否稳定为什么这是一个严重缺口因为事故往往不是&#xff1a;完全错误而是&#xff1a;执行态不一致上线前最小 Gate 清单&#xff08;简化版&#xff09;…

通用 LLM 执行态稳定性标准(Draft v1.0)Universal LLM Execution State Stability Standard · U-ESS v1.0 发布

好&#xff0c;这一步我会完全按 CSDN 的“工程师可读 不被当成情绪输出 不显得在挑事”的发布逻辑来做。 下面是 可直接发布到 CSDN 的成稿版本&#xff0c;不是草稿、不是概要&#xff0c;你复制即可发。通用 LLM 执行态稳定性标准&#xff08;Draft v1.0&#xff09;——高…

调色板示例颜色数据获取-基于 Flutter × OpenHarmony

文章目录调色板示例颜色数据获取-基于 Flutter OpenHarmony前言背景Flutter Harmony OpenHarmony 跨端开发介绍开发核心代码代码解析心得总结调色板示例颜色数据获取-基于 Flutter OpenHarmony 前言 在移动端开发中&#xff0c;颜色调色板是 UI 设计和视觉一致性的核心元素…

【多智能体控制】多智能体点对点转移的分布式模型预测控制【含Matlab源码 14976期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;Matlab武动乾坤博客之家&#x1f49e;…

UE 增强输入(2)

&#xff08;10&#xff09; &#xff08;11&#xff09; 谢谢

dify制作的工作流如何通过API调用

大家在基于dify开发Workflow和Agent,一般都是通过dify提供app功能直接提供使用,或者通过嵌入到其他页面中使用,但是还有一种情况,特别是针对各种数据处理的Workflow,需要通过程序调用,返回数据供其他app使用。该如何做呢?本文主要基于dify,将通过工作流发布的API,通过…

(5-2)UCLASS(..) 的参数

&#xff08;12&#xff09; &#xff08;13&#xff09; 谢谢

远程Ubantu Mysql安装 + 本地Windows Navicat连接

远程Ubantu Mysql安装 + 本地Windows Navicat连接安装过程 Mysql安装配置过程Mysql在ubantu安装直接使用apt命令安装sudo apt-get install mysql-server mysql-client -y启动mysql服务sudo systemctl start mysql使用r…

CCF T3

CCF T3 没什么太特殊的,注意到全局旋转操作复杂度太高,考虑打个懒标记进行局部旋转。(别忘了对翻转标记进行旋转,因为这么一个唐诗问题调了2h我也是神人了) #include<bits/stdc++.h> using namespace std; …

2026年国产时序数据库市场全景:从技术突破到行业落地

摘要&#xff1a; 进入2026年&#xff0c;在“数字中国”与工业物联网浪潮的强劲推动下&#xff0c;国产时序数据库市场持续繁荣&#xff0c;竞争格局日趋清晰。本文将对当前主流的国产时序数据库进行梳理盘点&#xff0c;并特别聚焦于金仓数据库&#xff08;Kingbase&#xff…

Ubuntu安装Lamp

Ubuntu安装Lamp本文将为您提供一个在Ubuntu服务器上搭建LAMP(Linux, Apache, MySQL, PHP)环境的完整指南。通过本文,您将学习如何安装和配置Apache、MySQL、PHP,并将您的PHP项目部署到服务器上。本文适用于Ubuntu …

(6-1)常见类的继承关系

&#xff08;12&#xff09; &#xff08;13&#xff09; 谢谢

【程序员必看+收藏】AI Agent:从聊天机器人到数字员工的智能革命指南

文章全面解析了AI Agent的核心概念、工作原理与开发实践。AI Agent是基于大语言模型的智能体&#xff0c;具备自主规划、记忆存储和工具调用能力&#xff0c;能独立完成复杂任务。文章详细介绍了Agent的三大核心能力&#xff08;规划、记忆、工具使用&#xff09;、ReAct工作模…

How to do A/B test?

1 Pre-Experiment & Preparition 1.1 Define Clear Objective & Metrics You must move beyond a vague "affects the final results." What part of the algorithm are you changing? (e.g., scor…

铁轨轨道安全障碍物检测数据集VOC+YOLO格式620张6类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件)图片数量(jpg文件个数)&#xff1a;620标注数量(xml文件个数)&#xff1a;620标注数量(txt文件个数)&#xff1a;620标注类别数&…

CodeArts Doer代码智能体

什么是CodeArts Doer代码智能体 CodeArts Doer代码智能体是一款集代码大模型、AI IDE、代码Agent为一体的智能编码产品。面向代码生成、研发知识问答、单元测试用例生成、代码解释、代码注释、代码调试、代码翻译、代码检查、代码优化等场景功能&#xff0c;为开发者提高研发效…