鼎鼎知识库
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

TDengine在项目中的使用.md 10KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. # TDengine时序数据库安装
  2. 云上Ubuntu服务器前期准备
  3. ```
  4. apt update
  5. sudo apt update
  6. apt-get update
  7. sudo apt-get update
  8. ```
  9. 安装可视化桌面
  10. ```
  11. apg-get install ubuntu-desktop
  12. ```
  13. Windows远程桌面连接Ubuntu.Ubuntu支持xrdp和vnc两种远程桌面协议。vnc是默认的基于RFB协议的远程桌面程序,但不够友好。
  14. ```
  15. sudo apt-get install xrdp
  16. sudo apt-get install vnc4server tightvnserver
  17. sudo apt-get install xubuntu-desktop
  18. echo "xfce4-session" >~/.xsession
  19. sudo service xrdp restart
  20. 通过windows远程桌面连接,连接成功,输入用户名和密码,终于看到ubuntu的界面!并且可以浏览网站!
  21. ```
  22. 安装TDengine
  23. ```
  24. 确认是否有systemd命令:whick systemd
  25. 登录网址:https://www.taosdata.com/cn/getting-started/
  26. 下载:下载deb包,输入邮件地址
  27. 安装位置:/root/Downloads/
  28. 打开命令行终端:alt+f2, gnome-terminal
  29. 查看当前位置:pwd
  30. 来到所在目录:cd Downloads
  31. 安装TDengine: sudo dpkg -i tdengine-1.6.2.2.deb
  32. 安装成功提示:
  33. TDengine is installed successfully!
  34. To configure TDengine: edt /etc/taos/taos.cfg
  35. To start TDengine: sudo systemctrl start taosd
  36. To access TDengine: use taos in shell
  37. 回到根目录: cd ~
  38. 来到TDengine的配置文件:cd /etc/taos/
  39. 检查taosd状态:systemctl status taosd
  40. 启动服务:systemctl start taosd
  41. 再次查看服务状态:systemctl status taosd
  42. ```
  43. 在linux上小试牛刀
  44. ```
  45. taos
  46. 创建数据库:create database db;
  47. 查看所有数据库:show databases;
  48. 使用数据库:use db;
  49. 创建表:create table t(ts timestamp, cdata int);
  50. 插入数据:
  51. insert into t values ('2019-07-15 00:00:00',10);
  52. insert into t values ('2019-07-15 01:00:00', 20);
  53. 查询:select * from t;
  54. ```
  55. Windows连接Ubuntu上的TDengine
  56. ```
  57. 初次连接失败: ./taos.exe -h ip
  58. 查看是否ping通:ping ip
  59. 安装最新的客户端版本
  60. ```
  61. 还是不行。熟悉vi的使用,修改配置文件。
  62. ```
  63. 三种命令模式:
  64. 命令模式切换到插入模式:i
  65. 从插入模式切回到命令模式:esc
  66. 在命令模式下,按 :wq 表示保存并退出, 按 :q! 表示不保存并退出
  67. 三种插入模式:
  68. i 从光标当前位置开始
  69. a 从光标所在位置的下一个位置开始
  70. o 从光标的行首插入一行
  71. 命令模式下光标的移动:
  72. h 向左
  73. l 向右
  74. k 向上
  75. j 向下
  76. 数字0 本行最开头
  77. G 最后一行最开头
  78. $ 本行行尾
  79. ^ 所在行行首
  80. w 下一个字母的开头
  81. e 下一个字母的结尾
  82. b 上一个字母的开头
  83. 命令模式下删除文字
  84. x 每按一次删除光标位置后面的一个字符
  85. 6x 删除光标位置后面的6个字符
  86. X 每按一次删除光标位置前面的一个字符
  87. 20X 删除光标位置前面的20个字符
  88. dd 删除光标所在行
  89. ```
  90. 修改taos.cfg配置文件
  91. ```
  92. - 确认配置:sudo vi /etc/taos/taos.cfg internalIP:是ifconfig中的地址
  93. - 确认开启服务:systemctl stop taosd systemctl start taosd systemctl status taosd
  94. - 确认服务器防火墙没在起作用:sudo ufw status
  95. - 确认服务器开放6020-6040端口,并且是TCP和UDP都要打开(安全组设置tcp和udp都要打开,小于64KB的包默认是udp发送)
  96. - 确认客户端命令正确:./taos.exe -h ip
  97. - ubuntu重启:reboot
  98. ```
  99. # 本地环境搭建
  100. - 本地服务器:192.168.8.131 teche123
  101. - 确认模块ip地址:187ED5314E0C 192.168.9.134
  102. - 登录模块:192.168.9.134:82 root abc123
  103. - 修改服务器指向:192.168.8.131:8080/ebx-bishop/data/carry
  104. - 确认服务打开:MysqlServer, redis-server
  105. - 启动网站:dot.net exe TaiHe.Electricity.Web.dll
  106. - 打开网站:192.168.8.131:8080 TecheFwd2018(泰和网站密码DrrnFwd2018,泰和服务器密码TecheFwd123)
  107. - 测试可视化界面是否可以操作
  108. # SDK使用原理
  109. > Startup.cs中的设置
  110. 包括参数、数据库、普通表和超级表配置、帮助类、模拟数据的背景现场。
  111. ```
  112. //参数配置
  113. services.Configure<TConfiguration>(Configuration.GetSection("TDegnine"));//在appsetting.json中配置TDengine结点
  114. //数据库配置
  115. services.AddTransient<ITDatabase, TDatabase>();//数据库接口和实现
  116. //普通表和超级表配置
  117. services.AddTransient<ITSuperTable<SuperReal>, TSuperTable<SuperReal>>();//超级表,实时数据
  118. services.AddTransient<ITSuperTable<SuperRealTj>, TSuperTable<SuperRealTj>>();//超级表,实时数据统计
  119. services.AddTransient<ITSuperTable<SuperWarning>, TSuperTable<SuperWarning>>();//超级表,报警
  120. services.AddTransient<ITSuperTable<SuperWarningTj>, TSuperTable<SuperWarningTj>>();//超级表,报警统计
  121. services.AddTransient<ITSuperTable<SuperDl>, TSuperTable<SuperDl>>();//超级表,电量
  122. services.AddTransient<ITSuperTable<SuperKg>, TSuperTable<SuperKg>>();//超级表,开关统计
  123. services.AddTransient<ITSuperTable<SuperKgTj>, TSuperTable<SuperKgTj>>();//超级表,开关统计的统计
  124. //子表配置
  125. services.AddTransient<ITChildTable<Real>, TChildTable<Real>>();//子表,实时数据
  126. services.AddTransient<ITChildTable<RealTj>, TChildTable<RealTj>>();//子表,实时数据统计
  127. services.AddTransient<ITChildTable<Warning>, TChildTable<Warning>>();//子表,报警
  128. services.AddTransient<ITChildTable<WarningTj>, TChildTable<WarningTj>>();//子表,报警统计
  129. services.AddTransient<ITChildTable<Dl>, TChildTable<Dl>>();//子表,电量
  130. services.AddTransient<ITChildTable<Kg>, TChildTable<Kg>>();//子表,开关统计
  131. services.AddTransient<ITChildTable<KgTj>, TChildTable<KgTj>>();//子表,开关统计统计
  132. //实时计算流返回结果保存到普通表
  133. //services.AddTransient<ITStream<RealTj>, TStream<RealTj>>(); //实时数据流计算结果
  134. //services.AddTransient<ITStream<WarningTj>, TStream<WarningTj>>();//报警数据流计算结果
  135. //services.AddTransient<ITStream<KgTj>, TStream<KgTj>>();//开关统计流计算结果
  136. //帮助类配置
  137. services.AddSingleton(typeof(CommonHelper));//共用帮助类
  138. services.AddTransient(typeof(MacHelper));//获取模块的帮助类
  139. services.AddSingleton(typeof(RealHelper));//帮助类,实时数据
  140. services.AddSingleton(typeof(RealTjHelper));//帮助类,实时数据统计
  141. services.AddTransient(typeof(WarningHelper));//帮助类,报警数据
  142. services.AddTransient(typeof(WarningTjHelper));//帮助类,报警数据统计
  143. services.AddTransient(typeof(DlHelper));//帮助类,电量数据
  144. services.AddTransient(typeof(KgHelper));//帮助类,开关统计
  145. services.AddTransient(typeof(KgTjHelper));//帮助类,开关统计
  146. //后台背景线程
  147. //services.AddSingleton<IHostedService, RealBackgroundService>();//模拟实时数据上传
  148. //services.AddSingleton<IHostedService, WarningBackgroundService>();//模拟报警数据上传
  149. //电量数据不能随机
  150. services.AddSingleton<IHostedService, KgBackgroundService>();//模拟每次开或关操作记录上传
  151. //统计实时数据、报警数据、开关数据,按分钟
  152. services.AddSingleton<IHostedService, TongJiByMinuteBackgroundService>();
  153. ```
  154. > appsettings.json中的配置
  155. ```
  156. "TDegnine": {
  157. "DataSource": "http://192.168.8.110:6020/rest/sql",
  158. "Username": "root",
  159. "Password": "taosdata",
  160. "Database": "liqun_nuode_1_1",
  161. "PlanInterval": 5000
  162. }
  163. ```
  164. > 生成SDK类库
  165. 类库的名称是:`TDengineTest.DD.dll`
  166. # 实际项目使用
  167. - 引入`TDengineTest.DD.dll`并生成
  168. - 在postman中测试TDengine接口是否可用
  169. ```
  170. POST http://47.102.145.164:6020/rest/sql
  171. Headers
  172. Authorization Basic cm9vdDp0YW9zZGF0YQ==
  173. Body
  174. show databases;
  175. ```
  176. - appsettings.json配置
  177. - Startup.cs配置
  178. - 出现报错:System.Runtime程序集版本高
  179. 修改TDengineTest.DD中如下,因为局域网版本是.net core 2.0版本
  180. ```
  181. <PropertyGroup>
  182. <TargetFramework>netcoreapp2.0</TargetFramework>
  183. </PropertyGroup>
  184. ```
  185. - 根据appSettings.json中的配置,创建`dingding_zhanting_1_1`数据库。
  186. ```
  187. create database dingding_zhanting_1_1;
  188. show databases;
  189. ```
  190. - 创建超级表控制器`SuperTableController`
  191. ```
  192. Microsoft.Extensions.Options版本高了,在类库中改成2.0的
  193. ```
  194. - 创建子表控制器`ChildTableController`
  195. - 打开超级表列表页
  196. ```
  197. 报错,提示没有Flurl
  198. <PackageReference Include="Flurl" Version="2.8.2" />
  199. <PackageReference Include="Flurl.Http" Version="2.4.2" />
  200. Could not load file or assembly 'Flurl.Http, Version=2.4.2.0, Culture=neutral, PublicKeyToken=null
  201. 重新生成,拷贝所有相关程序集到服务器
  202. ```
  203. - 创建子表控制器`ChildTableController`
  204. - 尝试计划任务
  205. ```
  206. //容器配置
  207. services.AddScheduler(); //计划
  208. services.AddTransient<RealDataToTDengine>();//IInvocable
  209. //管道配置
  210. provider.UseScheduler(s =>
  211. {
  212. //使用IInvocable 上传实时数据
  213. s.Schedule<RealDataToTDengine>()
  214. .EveryThirtySeconds();
  215. })
  216. //.LogScheduledTaskProgress(Services.GetService<ILogger<Coravel.Scheduling.Schedule.Interfaces.IScheduler>>())
  217. .OnError(exception => {
  218. Console.WriteLine(exception.Message);
  219. });
  220. //计划任务
  221. public class RealDataToTDengine : IInvocable{}
  222. //报错
  223. the located assembly's manifest definition doesn't match the assembly reference
  224. --重新生成发布解决
  225. //计划任务无法打印实体记录
  226. --改成字符串
  227. ```
  228. - 上传实时数据
  229. ```
  230. //报错
  231. Microsoft.Extensions.Logging.Abstraction Version=2.2.0
  232. --从NuGet下载
  233. ```
  234. - 检查上传的实时数据
  235. ```
  236. ./taos.exe -h
  237. use database
  238. select * from real_187ed5314e0c;
  239. ```
  240. - 报警数据上传
  241. ```
  242. 原理:
  243. -- 局域网breaker→kaiguan→WarningPolicy→breaker.Value.EnableNetCtrl。
  244. -- 在时序数据库中每种报警类型都有两条报警记录,一条开始,一条结束成对出现
  245. -- 当第一次出现报警,局域网创建一条,时序数据库也创建一条开始记录
  246. -- 当第二次出现报警,局域网不再创建,更新报警记录,时序数据库不动作
  247. -- 当某个开关没有报警,局域网闭环,时序数据库创建一条结束记录
  248. -- 放在本地的逻辑中实现
  249. ```
  250. - 电量数据上传:放在`DataServer`中