Merge pull request #816 from taosdata/feature/slguan

Instructions for using the RESTful interface
This commit is contained in:
fangpanpan 2019-12-03 10:12:27 +08:00 committed by GitHub
commit 1eda3f1b21
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 129 additions and 21 deletions

View File

@ -306,21 +306,34 @@ import taos
### HTTP请求格式 ### HTTP请求格式
`http://<ip>:<PORT>/rest/sql` ```
http://<ip>:<PORT>/rest/sql
```
​参数说明: ​参数说明:
IP: 集群中的任一台主机 - IP: 集群中的任一台主机
- PORT: 配置文件中httpPort配置项缺省为6020
PORT: 配置文件中httpPort配置项缺省为6020 例如http://192.168.0.1:6020/rest/sql 是指向IP地址为192.168.0.1的URL.
http://192.168.0.1:6020/rest/sql 是指向IP地址为192.168.0.1的URL. HTTP请求的Header里需带有身份认证信息TDengine支持Basic认证与自定义认证两种机制后续版本将提供标准安全的数字签名机制来做身份验证。
HTTP请求的Header里需带有身份认证信息TDengine单机版仅支持Basic认证机制。 - 自定义身份认证信息如下所示(<token>稍后介绍)
```
Authorization: Taosd <TOKEN>
```
- Basic身份认证信息如下所示
```
Authorization: Basic <TOKEN>
```
HTTP请求的BODY里就是一个完整的SQL语句SQL语句中的数据表应提供数据库前缀例如\<db-name>.\<tb-name>。如果表名不带数据库前缀系统会返回错误。因为HTTP模块只是一个简单的转发没有当前DB的概念。 HTTP请求的BODY里就是一个完整的SQL语句SQL语句中的数据表应提供数据库前缀例如\<db-name>.\<tb-name>。如果表名不带数据库前缀系统会返回错误。因为HTTP模块只是一个简单的转发没有当前DB的概念。
使用curl来发起一个HTTP Request, 语法如下: 使用curl通过自定义身份认证方式来发起一个HTTP Request, 语法如下:
``` ```
curl -H 'Authorization: Basic <TOKEN>' -d '<SQL>' <ip>:<PORT>/rest/sql curl -H 'Authorization: Basic <TOKEN>' -d '<SQL>' <ip>:<PORT>/rest/sql
@ -332,11 +345,12 @@ curl -H 'Authorization: Basic <TOKEN>' -d '<SQL>' <ip>:<PORT>/rest/sql
curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql
``` ```
其中,`TOKEN`为`{username}:{password}`经过Base64编码之后的字符串例如`root:taosdata`编码后为`cm9vdDp0YW9zZGF0YQ==` 其中,`TOKEN`为`{username}:{password}`经过Base64编码之后的字符串, 例如`root:taosdata`编码后为`cm9vdDp0YW9zZGF0YQ==`
### HTTP返回格式 ### HTTP返回格式
返回值为JSON格式如下 返回值为JSON格式如下:
``` ```
{ {
"status": "succ", "status": "succ",
@ -351,17 +365,51 @@ curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql
说明: 说明:
- 第一行”status”告知操作结果是成功还是失败; - status: 告知操作结果是成功还是失败
- 第二行”head”是表的定义如果不返回结果集仅有一列“affected_rows”; - head: 表的定义如果不返回结果集仅有一列“affected_rows”
- 第三行是具体返回的数据,一排一排的呈现。如果不返回结果集,仅[[affected_rows]] - data: 具体返回的数据,一排一排的呈现,如果不返回结果集,仅[[affected_rows]]
- 第四行”rows”表明总共多少行数据 - rows: 表明总共多少行数据
### 自定义授权码
HTTP请求中需要带有授权码`<TOKEN>`, 用于身份识别。授权码通常由管理员提供, 可简单的通过发送`HTTP GET`请求来获取授权码, 操作如下:
```
curl http://<ip>:6020/rest/login/<username>/<password>
```
其中, `ip`是TDengine数据库的IP地址, `username`为数据库用户名, `password`为数据库密码, 返回值为`JSON`格式, 各字段含义如下:
- status请求结果的标志位
- code返回值代码
- desc: 授权码
获取授权码示例:
```
curl http://192.168.0.1:6020/rest/login/root/taosdata
```
返回值:
```
{
"status": "succ",
"code": 0,
"desc":
"/KfeAzX/f9na8qdtNZmtONryp201ma04bEl8LcvLUd7a8qdtNZmtONryp201ma04"
}
```
### 使用示例 ### 使用示例
- 在demo库里查询表t1的所有记录, curl如下 - 在demo库里查询表t1的所有记录
`curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'select * from demo.t1' 192.168.0.1:6020/rest/sql`
```
curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'select * from demo.t1' 192.168.0.1:6020/rest/sql`
```
返回值: 返回值:
``` ```
@ -369,8 +417,8 @@ curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql
"status": "succ", "status": "succ",
"head": ["column1","column2","column3"], "head": ["column1","column2","column3"],
"data": [ "data": [
["2017-12-12 23:44:25.730", 1, 2.3], ["2017-12-12 22:44:25.728",4,5.60000],
["2017-12-12 22:44:25.728", 4, 5.6] ["2017-12-12 23:44:25.730",1,2.30000]
], ],
"rows": 2 "rows": 2
} }
@ -378,7 +426,9 @@ curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql
- 创建库demo - 创建库demo
`curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'create database demo' 192.168.0.1:6020/rest/sql` ```
curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'create database demo' 192.168.0.1:6020/rest/sql`
```
返回值: 返回值:
``` ```
@ -390,6 +440,64 @@ curl -u username:password -d '<SQL>' <ip>:<PORT>/rest/sql
} }
``` ```
### 其他用法
#### 结果集采用Unix时间戳
HTTP请求URL采用`sqlt`时返回结果集的时间戳将采用Unix时间戳格式表示例如
```
curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'select * from demo.t1' 192.168.0.1:6020/rest/sqlt
```
返回值:
```
{
"status": "succ",
"head": ["column1","column2","column3"],
"data": [
[1513089865728,4,5.60000],
[1513093465730,1,2.30000]
],
"rows": 2
}
```
#### 结果集采用UTC时间字符串
HTTP请求URL采用`sqlutc`时返回结果集的时间戳将采用UTC时间字符串表示例如
```
curl -H 'Authorization: Basic cm9vdDp0YW9zZGF0YQ==' -d 'select * from demo.t1' 192.168.0.1:6020/rest/sqlutc
```
返回值:
```
{
"status": "succ",
"head": ["column1","column2","column3"],
"data": [
["2017-12-12T22:44:25.728+0800",4,5.60000],
["2017-12-12T23:44:25.730+0800",1,2.30000]
],
"rows": 2
}
```
### 重要配置项
下面仅列出一些与RESTFul接口有关的配置参数其他系统参数请看配置文件里的说明。注意配置修改后需要重启taosd服务才能生效
- httpIp: 对外提供RESTFul服务的IP地址默认绑定到0.0.0.0
- httpPort: 对外提供RESTFul服务的端口号默认绑定到6020
- httpMaxThreads: 启动的线程数量默认为2
- httpCacheSessions: 缓存连接的数量并发请求数目需小于此数值的10倍默认值为100
- restfulRowLimit: 返回结果集JSON格式的最大条数默认值为10240
- httpEnableCompress: 是否支持压缩默认不支持目前TDengine仅支持gzip压缩格式
- httpDebugFlag: 日志开关131仅错误和报警信息135所有默认131
## Go Connector ## Go Connector
#### 安装TDengine #### 安装TDengine