通信服务协议

Thrift rpc 接口

简介

Thrift是一个远程方法调用软件框架,用来进行可扩展且跨语言的服务的开发。 它结合了功能强大的软件堆栈和代码生成引擎, 以构建在 C++, Java, Go,Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 这些编程语言间无缝结合的、高效的服务。

IoTDB服务端和客户端之间使用thrift进行通信,实际使用中建议使用IoTDB提供的原生客户端封装: Session或Session Pool。如有特殊需要,您也可以直接针对RPC接口进行编程

默认IoTDB服务端使用6667端口作为RPC通信端口,可修改配置项中的

  1. rpc_port=6667

更改默认接口

rpc接口

  1. // 打开一个 session
  2. TSOpenSessionResp openSession(1:TSOpenSessionReq req);
  3. // 关闭一个 session
  4. TSStatus closeSession(1:TSCloseSessionReq req);
  5. // 执行一条 SQL 语句
  6. TSExecuteStatementResp executeStatement(1:TSExecuteStatementReq req);
  7. // 批量执行 SQL 语句
  8. TSStatus executeBatchStatement(1:TSExecuteBatchStatementReq req);
  9. // 执行查询 SQL 语句
  10. TSExecuteStatementResp executeQueryStatement(1:TSExecuteStatementReq req);
  11. // 执行插入、删除 SQL 语句
  12. TSExecuteStatementResp executeUpdateStatement(1:TSExecuteStatementReq req);
  13. // 向服务器取下一批查询结果
  14. TSFetchResultsResp fetchResults(1:TSFetchResultsReq req)
  15. // 获取元数据
  16. TSFetchMetadataResp fetchMetadata(1:TSFetchMetadataReq req)
  17. // 取消某次查询操作
  18. TSStatus cancelOperation(1:TSCancelOperationReq req);
  19. // 关闭查询操作数据集,释放资源
  20. TSStatus closeOperation(1:TSCloseOperationReq req);
  21. // 获取时区信息
  22. TSGetTimeZoneResp getTimeZone(1:i64 sessionId);
  23. // 设置时区
  24. TSStatus setTimeZone(1:TSSetTimeZoneReq req);
  25. // 获取服务端配置
  26. ServerProperties getProperties();
  27. // 设置存储组
  28. TSStatus setStorageGroup(1:i64 sessionId, 2:string storageGroup);
  29. // 创建时间序列
  30. TSStatus createTimeseries(1:TSCreateTimeseriesReq req);
  31. // 创建多条时间序列
  32. TSStatus createMultiTimeseries(1:TSCreateMultiTimeseriesReq req);
  33. // 删除时间序列
  34. TSStatus deleteTimeseries(1:i64 sessionId, 2:list<string> path)
  35. // 删除存储组
  36. TSStatus deleteStorageGroups(1:i64 sessionId, 2:list<string> storageGroup);
  37. // 按行插入数据
  38. TSStatus insertRecord(1:TSInsertRecordReq req);
  39. // 按String格式插入一条数据
  40. TSStatus insertStringRecord(1:TSInsertStringRecordReq req);
  41. // 按列插入数据
  42. TSStatus insertTablet(1:TSInsertTabletReq req);
  43. // 按列批量插入数据
  44. TSStatus insertTablets(1:TSInsertTabletsReq req);
  45. // 按行批量插入数据
  46. TSStatus insertRecords(1:TSInsertRecordsReq req);
  47. // 按行批量插入同属于某个设备的数据
  48. TSStatus insertRecordsOfOneDevice(1:TSInsertRecordsOfOneDeviceReq req);
  49. // 按String格式批量按行插入数据
  50. TSStatus insertStringRecords(1:TSInsertStringRecordsReq req);
  51. // 测试按列插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  52. TSStatus testInsertTablet(1:TSInsertTabletReq req);
  53. // 测试批量按列插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  54. TSStatus testInsertTablets(1:TSInsertTabletsReq req);
  55. // 测试按行插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  56. TSStatus testInsertRecord(1:TSInsertRecordReq req);
  57. // 测试按String格式按行插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  58. TSStatus testInsertStringRecord(1:TSInsertStringRecordReq req);
  59. // 测试按行插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  60. TSStatus testInsertRecords(1:TSInsertRecordsReq req);
  61. // 测试按行批量插入同属于某个设备的数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  62. TSStatus testInsertRecordsOfOneDevice(1:TSInsertRecordsOfOneDeviceReq req);
  63. // 测试按String格式批量按行插入数据的延迟,注意:该接口不真实插入数据,只用来测试网络延迟
  64. TSStatus testInsertStringRecords(1:TSInsertStringRecordsReq req);
  65. // 删除数据
  66. TSStatus deleteData(1:TSDeleteDataReq req);
  67. // 执行原始数据查询
  68. TSExecuteStatementResp executeRawDataQuery(1:TSRawDataQueryReq req);
  69. // 向服务器申请一个查询语句ID
  70. i64 requestStatementId(1:i64 sessionId);

IDL定义文件位置

IDL定义文件的路径是thrift/src/main/thrift/rpc.thrift,其中包括了结构体定义与函数定义、

生成文件位置

在mvn编译过程中,会调用thrift编译IDL文件,生成最终的.class文件 生成的文件夹路径为thrift/target/classes/org/apache/iotdb/service/rpc/thrift