docs.md 12.2 KB
Newer Older
1
# TDengine 文档
2

3
TDengine 是一个高效的存储、查询、分析时序大数据的平台,专为物联网、车联网、工业互联网、运维监测等优化而设计。您可以像使用关系型数据库 MySQL 一样来使用它,但建议您在使用前仔细阅读一遍下面的文档,特别是 [数据模型](/architecture)[数据建模](/model)。除本文档之外,欢迎 [下载产品白皮书](https://www.taosdata.com/downloads/TDengine%20White%20Paper.pdf)
4

5
## [TDengine 介绍](/evaluation)
6

7 8 9
- [TDengine 简介及特色](/evaluation#intro)
- [TDengine 适用场景](/evaluation#scenes)
- [TDengine 性能指标介绍和验证方法](/evaluation#)
10 11 12

## [立即开始](/getting-started)

13 14 15 16 17 18
- [快捷安装](/getting-started#install):可通过源码、安装包或 Docker 安装,三秒钟搞定
- [轻松启动](/getting-started#start):使用 systemctl 启停 TDengine
- [命令行程序 TAOS](/getting-started#console):访问 TDengine 的简便方式
- [极速体验](/getting-started#demo):运行示例程序,快速体验高效的数据插入、查询
- [支持平台列表](/getting-started#platforms):TDengine 服务器和客户端支持的平台列表
- [Kubernetes 部署](https://taosdata.github.io/TDengine-Operator/zh/index.html):TDengine 在 Kubernetes 环境进行部署的详细说明
19 20 21

## [整体架构](/architecture)

22 23 24 25 26 27
- [数据模型](/architecture#model):关系型数据库模型,但要求每个采集点单独建表
- [集群与基本逻辑单元](/architecture#cluster):吸取 NoSQL 优点,支持水平扩展,支持高可靠
- [存储模型与数据分区、分片](/architecture#sharding):标签数据与时序数据完全分离,按 VNode 和时间两个维度对数据切分
- [数据写入与复制流程](/architecture#replication):先写入 WAL、之后写入缓存,再给应用确认,支持多副本
- [缓存与持久化](/architecture#persistence):最新数据缓存在内存中,但落盘时采用列式存储、超高压缩比
- [数据查询](/architecture#query):支持各种函数、时间轴聚合、插值、多表聚合
28 29 30

## [数据建模](/model)

31 32 33
- [创建库](/model#create-db):为具有相似数据特征的数据采集点创建一个库
- [创建超级表](/model#create-stable):为同一类型的数据采集点创建一个超级表
- [创建表](/model#create-table):使用超级表做模板,为每一个具体的数据采集点单独建表
34

涛思数据(TDengine)'s avatar
涛思数据(TDengine) 已提交
35 36
## [TAOS SQL](/taos-sql)

37 38 39 40 41 42 43 44 45 46 47 48
- [支持的数据类型](/taos-sql#data-type):支持时间戳、整型、浮点型、布尔型、字符型等多种数据类型
- [数据库管理](/taos-sql#management):添加、删除、查看数据库
- [表管理](/taos-sql#table):添加、删除、查看、修改表
- [超级表管理](/taos-sql#super-table):添加、删除、查看、修改超级表
- [标签管理](/taos-sql#tags):增加、删除、修改标签
- [数据写入](/taos-sql#insert):支持单表单条、多条、多表多条写入,支持历史数据写入
- [数据查询](/taos-sql#select):支持时间段、值过滤、排序、嵌套查询、Union、Join、查询结果手动分页等
- [SQL 函数](/taos-sql#functions):支持各种聚合函数、选择函数、计算函数,如 AVG, MIN, DIFF 等
- [窗口切分聚合](/taos-sql#aggregation):将表中数据按照时间段等方式进行切割后聚合,降维处理
- [边界限制](/taos-sql#limitation):库、表、SQL 等边界限制条件
- [UDF](/taos-sql/udf):用户定义函数的创建和管理方法
- [错误码](/taos-sql/error-code):TDengine 2.0 错误码以及对应的十进制码
涛思数据(TDengine)'s avatar
涛思数据(TDengine) 已提交
49

50 51
## [高效写入数据](/insert)

52 53 54 55 56 57 58 59
- [SQL 写入](/insert#sql):使用 SQL INSERT 命令向一张或多张表写入单条或多条记录
- [Schemaless 写入](/insert#schemaless):免于预先建表,将数据直接写入时自动维护元数据结构
- [Prometheus 写入](/insert#prometheus):配置 Prometheus, 不用任何代码,将数据直接写入
- [Telegraf 写入](/insert#telegraf):配置 Telegraf, 不用任何代码,将采集数据直接写入
- [collectd 直接写入](/insert#collectd):配置 collectd,不用任何代码,将采集数据直接写入
- [StatsD 直接写入](/insert#statsd):配置 StatsD,不用任何代码,将采集数据直接写入
- [EMQX Broker](/insert#emq):配置 EMQX,不用任何代码,就可将 MQTT 数据直接写入
- [HiveMQ Broker](/insert#hivemq):配置 HiveMQ,不用任何代码,就可将 MQTT 数据直接写入
60 61 62

## [高效查询数据](/queries)

63 64 65
- [主要查询功能](/queries#queries):支持各种标准函数,设置过滤条件,时间段查询
- [多表聚合查询](/queries#aggregation):使用超级表,设置标签过滤条件,进行高效聚合查询
- [降采样查询值](/queries#sampling):按时间段分段聚合,支持插值
66 67 68

## [高级功能](/advanced-features)

69 70 71
- [连续查询(Continuous Query)](/advanced-features#continuous-query):基于滑动窗口,定时自动的对数据流进行查询计算
- [数据订阅(Publisher/Subscriber)](/advanced-features#subscribe):类似典型的消息队列,应用可订阅接收到的最新数据
- [缓存(Cache)](/advanced-features#cache):每个设备最新的数据都会缓存在内存中,可快速获取
72 73 74

## [连接器](/connector)

75 76 77 78 79 80 81 82 83
- [C/C++ Connector](/connector#c-cpp):通过 libtaos 客户端的库,连接 TDengine 服务器的主要方法
- [Java Connector(JDBC)](/connector/java):通过标准的 JDBC API,给 Java 应用提供到 TDengine 的连接
- [Python Connector](/connector#python):给 Python 应用提供一个连接 TDengine 服务器的驱动
- [RESTful Connector](/connector#restful):提供一最简单的连接 TDengine 服务器的方式
- [Go Connector](/connector#go):给 Go 应用提供一个连接 TDengine 服务器的驱动
- [Node.js Connector](/connector#nodejs):给 Node.js 应用提供一个连接 TDengine 服务器的驱动
- [C# Connector](/connector#csharp):给 C# 应用提供一个连接 TDengine 服务器的驱动
- [Windows 客户端](https://www.taosdata.com/blog/2019/07/26/514.html):自行编译 Windows 客户端,Windows 环境的各种连接器都需要它
- [Rust Connector](/connector/rust): Rust 语言下通过 libtaos 客户端或 RESTful 接口,连接 TDengine 服务器。
84

S
Shuaiqiang Chang 已提交
85
## TDengine 组件与工具
S
Shuaiqiang Chang 已提交
86

87 88 89 90 91
- [taosAdapter](/tools/adapter): TDengine 集群和应用之间的 RESTful 接口适配服务。
- [TDinsight](/tools/insight): 监控 TDengine 集群的 Grafana 面板集合。
- [taosTools](/tools/taos-tools): taosTools 是用于 TDengine 的辅助工具软件集合。。
- [taosdump](/tools/taosdump): TDengine 数据备份工具。使用 taosdump 请安装 taosTools。
- [taosBenchmark](/tools/taosbenchmark): TDengine 压力测试工具。
S
Shuaiqiang Chang 已提交
92

93 94
## [与其他工具的连接](/connections)

95 96 97
- [Grafana](/connections#grafana):获取并可视化保存在 TDengine 的数据
- [IDEA Database](https://www.taosdata.com/blog/2020/08/27/1767.html):通过 IDEA 数据库管理工具可视化使用 TDengine
- [TDengineGUI](https://github.com/skye0207/TDengineGUI):基于 Electron 开发的跨平台 TDengine 图形化管理工具
S
sparklezzz 已提交
98
- [DataX](https://www.taosdata.com/blog/2021/10/26/3156.html):支持 TDengine 和其他数据库之间进行数据迁移的工具
99
- [Awesome TDengine](https://github.com/taosdata/awesome-tdengine):与 TDengine 有关的精彩项目精选清单
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131

## [TDengine 集群的安装、管理](/cluster)

- [准备工作](/cluster#prepare):部署环境前的几点注意事项
- [创建第一个节点](/cluster#node-one):与快捷安装完全一样,非常简单
- [创建后续节点](/cluster#node-other):配置新节点的 taos.cfg, 在现有集群添加新的节点
- [节点管理](/cluster#management):增加、删除、查看集群的节点
- [VNode 的高可用性](/cluster#high-availability):通过多副本的机制来提供 VNode 的高可用性
- [MNode 的管理](/cluster#mnode):系统自动创建、无需任何人工干预
- [负载均衡](/cluster#load-balancing):一旦节点个数或负载有变化,自动进行
- [节点离线处理](/cluster#offline):节点离线超过一定时长,将从集群中剔除
- [Arbitrator](/cluster#arbitrator):对于偶数个副本的情形,使用它可以防止脑裂(Split-brain)问题

## [TDengine 的运营和维护](/administrator)

- [容量规划](/administrator#planning):根据场景,估算硬件资源
- [容错和灾备](/administrator#tolerance):设置正确的 WAL 和数据副本数
- [系统配置](/administrator#config):端口,缓存大小,文件块大小和其他系统配置
- [用户管理](/administrator#user):添加、删除 TDengine 用户,修改用户密码
- [数据导入](/administrator#import):可按脚本文件导入,也可按数据文件导入
- [数据导出](/administrator#export):从 Shell 按表导出,也可用 taosdump 工具做各种导出
- [系统连接、任务查询管理](/administrator#status):检查系统现有的连接、查询、流式计算,日志和事件等
- [系统监控](/administrator#monitoring):系统监控,使用 TDinsight 进行集群监控等
- [性能优化](/administrator#optimize):对长期运行的系统进行维护优化,保障性能表现
- [文件目录结构](/administrator#directories):TDengine 数据文件、配置文件等所在目录
- [参数限制与保留关键字](/administrator#keywords):TDengine 的参数限制与保留关键字列表

## TDengine 的技术设计

- [系统模块](/architecture/taosd):taosd 的功能和模块划分
- [数据复制](/architecture/replica):支持实时同步、异步复制,保证系统的高可用性
- [技术博客](https://www.taosdata.com/cn/blog/?categories=3):更多的技术分析和架构设计文章
132

H
Hui Li 已提交
133
## 应用 TDengine 快速搭建 IT 运维系统
134

135 136 137
- [DevOps](/devops/telegraf):使用 TDengine + Telegraf + Grafana 快速搭建 IT 运维系统
- [DevOps](/devops/collectd):使用 TDengine + collectd/StatsD + Grafana 快速搭建 IT 运维系统
- [最佳实践](/devops/immigrate):OpenTSDB 应用迁移到 TDengine 的最佳实践
138

139
## TDengine 与其他数据库的对比测试
140

141 142 143 144 145
- [用 InfluxDB 开源的性能测试工具对比 InfluxDB 和 TDengine](https://www.taosdata.com/blog/2020/01/13/1105.html)
- [TDengine 与 OpenTSDB 对比测试](https://www.taosdata.com/blog/2019/08/21/621.html)
- [TDengine 与 Cassandra 对比测试](https://www.taosdata.com/blog/2019/08/14/573.html)
- [TDengine 与 InfluxDB 对比测试](https://www.taosdata.com/blog/2019/07/19/419.html)
- [TDengine 与 InfluxDB、OpenTSDB、Cassandra、MySQL、ClickHouse 等数据库的对比测试报告](https://www.taosdata.com/downloads/TDengine_Testing_Report_cn.pdf)
146 147 148

## 物联网大数据

149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
- [物联网、工业互联网大数据的特点](https://www.taosdata.com/blog/2019/07/09/105.html)
- [物联网大数据平台应具备的功能和特点](https://www.taosdata.com/blog/2019/07/29/542.html)
- [通用大数据架构为什么不适合处理物联网数据?](https://www.taosdata.com/blog/2019/07/09/107.html)
- [物联网、车联网、工业互联网大数据平台,为什么推荐使用 TDengine?](https://www.taosdata.com/blog/2019/07/09/109.html)

## 培训和 FAQ

- [FAQ:常见问题与答案](/faq)
- [技术公开课:开源、高效的物联网大数据平台,TDengine 内核技术剖析](https://www.taosdata.com/blog/2020/12/25/2126.html)
- [TDengine 视频教程 - 快速上手](https://www.taosdata.com/blog/2020/11/11/1941.html)
- [TDengine 视频教程 - 数据建模](https://www.taosdata.com/blog/2020/11/11/1945.html)
- [TDengine 视频教程 - 集群搭建](https://www.taosdata.com/blog/2020/11/11/1961.html)
- [TDengine 视频教程 - Go Connector](https://www.taosdata.com/blog/2020/11/11/1951.html)
- [TDengine 视频教程 - JDBC Connector](https://www.taosdata.com/blog/2020/11/11/1955.html)
- [TDengine 视频教程 - Node.js Connector](https://www.taosdata.com/blog/2020/11/11/1957.html)
- [TDengine 视频教程 - Python Connector](https://www.taosdata.com/blog/2020/11/11/1963.html)
- [TDengine 视频教程 - RESTful Connector](https://www.taosdata.com/blog/2020/11/11/1965.html)
- [TDengine 视频教程 - “零”代码运维监控](https://www.taosdata.com/blog/2020/11/11/1959.html)
- [应用案例:一些使用实例来解释如何使用 TDengine](https://www.taosdata.com/cn/blog/?categories=4)