# 立即开始 ## 从 Docker 快速开始 如果已经安装了 docker, 只需执行下面的命令。 ```shell docker run -d -p 6030-6049:6030-6049 -p 6030-6049:6030-6049/udp tdengine/tdengine ``` 确定该容器已经启动并且在正常运行 ```shell docker ps ``` 进入该容器并执行 bash ```shell docker exec -it bash ``` 然后就可以执行相关的 Linux 命令操作和访问 TDengine 详细操作方法请参照 [通过 Docker 快速体验 TDengine](/train-fqa/docker)。 :::info 从 2.4.0.10 开始,除 taosd 以外,Docker 镜像还包含:taos、taosAdapter、taosdump、taosBenchmark、TDinsight 安装脚本和示例代码。启动 Docker 容器时,将同时启动 taosAdapter 和 taosd,实现对 RESTful 的支持。 ::: :::note 暂时不建议生产环境采用 Docker 来部署 TDengine 的客户端或服务端,但在开发环境下或初次尝试时,使用 Docker 方式部署是十分方便的。特别是,利用 Docker,可以方便地在 macOS 和 Windows 环境下尝试 TDengine。 ::: ## 安装 import Tabs from "@theme/Tabs"; import TabItem from "@theme/TabItem"; import PkgInstall from "./\_pkg_install.mdx"; import AptGetInstall from "./\_apt_get_install.mdx"; import SrcInstall from "./\_src_install.mdx"; TDengine 包括服务端、客户端和周边生态工具软件,目前 2.0 版服务端仅在 Linux 系统上安装和运行,后续将支持 Windows、macOS 等系统。客户端可以在 Windows 或 Linux 上安装和运行。在任何操作系统上的应用都可以使用 RESTful 接口连接服务端程序 taosd,其中 2.4 之后版本默认使用单独运行的独立组件 taosAdapter 提供 http 服务和更多数据写入方式。taosAdapter 需要手动启动。 之前版本 TDengine 服务端,以及所有服务端 lite 版,均使用内置 http 服务。 TDengine 支持 X64/ARM64/MIPS64/Alpha64 硬件平台,后续将支持 ARM32、RISC-V 等 CPU 架构。 ## 启动 使用 `systemctl` 命令来启动 TDengine 的服务进程。 ```bash systemctl start taosd ``` 检查服务是否正常工作: ```bash systemctl status taosd ``` 如果 TDengine 服务正常工作,那么您可以通过 TDengine 的命令行程序 `taos` 来访问并体验 TDengine。 :::info - systemctl 命令需要 _root_ 权限来运行,如果您非 _root_ 用户,请在命令前添加 sudo 。 - 为更好的获得产品反馈,改善产品,TDengine 会采集基本的使用信息,但您可以修改系统配置文件 taos.cfg 里的配置参数 telemetryReporting,将其设为 0,就可将其关闭。 - TDengine 采用 FQDN(一般就是 hostname)作为节点的 ID,为保证正常运行,需要给运行 taosd 的服务器配置好 hostname,在客户端应用运行的机器配置好 DNS 服务或 hosts 文件,保证 FQDN 能够解析。 - `systemctl stop taosd` 指令在执行后并不会马上停止 TDengine 服务,而是会等待系统中必要的落盘工作正常完成。在数据量很大的情况下,这可能会消耗较长时间。 TDengine 支持在使用 [`systemd`](https://en.wikipedia.org/wiki/Systemd) 做进程服务管理的 Linux 系统上安装,用 `which systemctl` 命令来检测系统中是否存在 `systemd` 包: ```bash which systemctl ``` 如果系统中不支持 `systemd`,也可以用手动运行 `/usr/local/taos/bin/taosd` 方式启动 TDengine 服务。 :::note ## 进入命令行 执行 TDengine 客户端程序,您只要在 Linux 终端执行 `taos` 即可。 ```bash taos ``` 如果连接服务成功,将会打印出欢迎消息和版本信息。如果失败,则会打印错误消息出来(请参考 [FAQ](/train-fqa/faq) 来解决终端连接服务端失败的问题)。客户端的提示符号如下: ```cmd taos> ``` 在 TDengine 客户端中,用户可以通过 SQL 命令来创建/删除数据库、表等,并进行插入查询操作。在终端中运行的 SQL 语句需要以分号结束来运行。示例: ```mysql create database demo; use demo; create table t (ts timestamp, speed int); insert into t values ('2019-07-15 00:00:00', 10); insert into t values ('2019-07-15 01:00:00', 20); select * from t; ts | speed | ======================================== 2019-07-15 00:00:00.000 | 10 | 2019-07-15 01:00:00.000 | 20 | Query OK, 2 row(s) in set (0.003128s) ``` 除执行 SQL 语句外,系统管理员还可以从 TDengine 客户端进行检查系统运行状态、添加删除用户账号等操作。 ## 命令行参数 您可通过配置命令行参数来改变 TDengine 客户端的行为。以下为常用的几个命令行参数: - -c, --config-dir: 指定配置文件目录,默认为 `/etc/taos` - -h, --host: 指定服务的 FQDN 地址或 IP 地址,默认为连接本地服务 - -s, --commands: 在不进入终端的情况下运行 TDengine 命令 - -u, --user: 连接 TDengine 服务端的用户名,缺省为 root - -p, --password: 连接 TDengine 服务端的密码,缺省为 taosdata - -?, --help: 打印出所有命令行参数 示例: ```bash taos -h h1.taos.com -s "use db; show tables;" ``` ## 运行 SQL 命令脚本 TDengine 终端可以通过 `source` 命令来运行 SQL 命令脚本。 ```mysql taos> source ; ``` ## taos shell 小技巧 - 可以使用上下光标键查看历史输入的指令 - 修改用户密码:在 shell 中使用 `alter user` 命令,缺省密码为 taosdata - ctrl+c 中止正在进行中的查询 - 执行 `RESET QUERY CACHE` 可清除本地缓存的表 schema - 批量执行 SQL 语句。可以将一系列的 shell 命令(以英文 ; 结尾,每个 SQL 语句为一行)按行存放在文件里,在 shell 里执行命令 `source ` 自动执行该文件里所有的 SQL 语句 - 输入 q 回车,退出 taos shell ## 使用 taosBenchmark 体验写入速度 启动 TDengine 的服务,在 Linux 终端执行 `taosBenchmark` (曾命名为 taosdemo): ```bash taosBenchmark ``` 该命令将在数据库 test 下面自动创建一张超级表 meters,该超级表下有 1 万张表,表名为 "d0" 到 "d9999",每张表有 1 万条记录,每条记录有 (ts, current, voltage, phase) 四个字段,时间戳从 "2017-07-14 10:40:00 000" 到 "2017-07-14 10:40:09 999",每张表带有标签 location 和 groupId,groupId 被设置为 1 到 10, location 被设置为 "beijing" 或者 "shanghai"。 这条命令很快完成 1 亿条记录的插入。具体时间取决于硬件性能,即使在一台普通的 PC 服务器往往也仅需十几秒。 ## taosBenchmark 详细功能列表 taosBenchmark 命令本身带有很多选项,配置表的数目、记录条数等等,请执行 `taosBenchmark --help` 详细列出。您可以设置不同参数进行体验。 taosBenchmark 详细使用方法请参照 [如何使用 taosBenchmark 对 TDengine 进行性能测试](https://www.taosdata.com/2021/10/09/3111.html)。 ## 使用 taos shell 体验查询速度 在 TDengine 客户端输入查询命令,体验查询速度。 查询超级表下记录总条数: ```mysql taos> select count(*) from test.meters; ``` 查询 1 亿条记录的平均值、最大值、最小值等: ```mysql taos> select avg(current), max(voltage), min(phase) from test.meters; ``` 查询 location="beijing" 的记录总条数: ```mysql taos> select count(*) from test.meters where location="beijing"; ``` 查询 groupId=10 的所有记录的平均值、最大值、最小值等: ```mysql taos> select avg(current), max(voltage), min(phase) from test.meters where groupId=10; ``` 对表 d10 按 10s 进行平均值、最大值和最小值聚合统计: ```mysql taos> select avg(current), max(voltage), min(phase) from test.d10 interval(10s); ```