thingsboard在windows下安装和使用

在官网下载thingsboard和tb-gatewayjava

须要安装java8web

thingsboard服务安装json

https://thingsboard.io/docs/user-guide/install/windows/windows

把thingsboard-windows-1.4.zip解压到C盘app

在这个文件夹打开管理员模式cmd 输入ide

install.bat

安装服务,成功后提示ui

 C:\thingsboard>install.bat --loadDemo Detecting Java version installed. Detecting if it is 64 bit machine CurrentVersion Detecting if it is 32 bit machine CurrentVersion 1.8 Java 1.8 found! Installing thingsboard ... =================================================== :: ThingsBoard :: (v1.4) =================================================== Starting ThingsBoard Installation... Installing DataBase schema... Installing Cassandra DataBase schema... Loading system data... Installation finished successfully! 2017-07-23 21:47:12,079 INFO - Starting ServiceWrapper in the CLI mode 2017-07-23 21:47:12,317 INFO - Completed. Exit code is 0 ThingsBoard installed successfully!

tb-gateway服务安装spa

https://thingsboard.io/docs/iot-gateway/install/windows/code

下载tb-gateway-windows-1.2.1.zip解压到c盘component

输入

install.bat

出现下文就安装成功

C:\tb-gateway>install.bat Detecting if it is 64-bit machine CurrentVersion 1.8 Java 1.8 found! Installing tb-gateway ... 2017-01-31 02:26:50,704 INFO - Starting ServiceWrapper in the CLI mode 2017-01-31 02:26:50,907 INFO - Completed. Exit code is 0 DONE.

 启动服务

安装成功后启动thingsboard服务

net start thingsboard

若是须要重启thingsboard服务:

net stop thingsboard
net start thingsboard

启动服务后查看C:\thingsboard\logs下的log,出现这些才算启动完成

2018-04-13 09:42:59,091 [main] INFO o.s.b.c.e.t.TomcatEmbeddedServletContainer - Tomcat started on port(s): 8080 (http) 2018-04-13 09:42:59,108 [main] INFO o.t.s.ThingsboardServerApplication - Started ThingsboardServerApplication in 54.39 seconds (JVM running for 56.581)

可能的错误:

2018-04-02 14:29:23,215 [main] ERROR o.t.s.s.c.rpc.ClusterGrpcService - Failed to start RPC server! java.io.IOException: Failed to bind

缘由是端口占用,删除占用端口的进程

netstat -ano|findstr 9001 taskkill /pid 4708 /f

使用ThingsBoard GUI进行后续工做

log提示thingsboard启动后能够打开网页  它的做用和live demo同样 只不过在本地

http://localhost:8080/

先登陆admin

sysadmin@thingsboard.org sysadmin

在租户添加下面帐号

  • Username: tenant@thingsboard.org
  • Password: tenant

登陆租户tenant,tenant能够管理设备,添加规则等

image

 

启动完thingsboard后能够启动tb-gateway

net start tb-gateway

启动成功:

YYYY-MM-DD HH:mm:ss,sss [main] INFO  o.t.gateway.GatewayApplication - Started GatewayApplication in x.xxx seconds (JVM running for x.xxx)

 

装完服务后这两个服务会开机启动,若是log提示有问题只能一个个重启,先重启thingsboard再重启tb-gateway

net stop thingsboard net start thingsboard net stop tb-gateway net start tb-gateway

若是要在本地启动,修改 tb-gateway.yml,否则yml写的是live demo的配置,以后再启动tb-gateway

live demo 网址,需注册

https://demo.thingsboard.io/signup

IoT Gateway Configuration

Change gateway.connection.host and gateway.connection.port properties to your ThingsBoard host (leave without modifications in case of live demo instance).

Change gateway.connection.security.accessToken property to your access token that was copied during step 3.

原来的配置:

gateway: reporting: interval: 60000 persistence: type: file path: storage bufferSize: 1000 connection: host: "demo.thingsboard.io" port: 1883 retryInterval: 3000 maxInFlight: 1000 security: accessToken: your_token # keystore: mqttclient.jks # keystorePassword: password # keystoreKeyAlias: clientalias # truststore: mqttclient.jks # truststorePassword: password opc: enabled: false configuration: opc-config.json mqtt: enabled: false configuration: mqtt-config.json sigfox: enabled: false configuration: sigfox-config.json server: # Server bind address address: "0.0.0.0" # Server bind port port: "9090" # Check new version updates parameters updates: # Enable/disable updates checking. enabled: "${UPDATES_ENABLED:true}"

本地使用,修改了host 和accessToken :

若是要经过ThingsBoard GUI设置ThingsBoard Gateway, remoteConfigurationtb-gateway.yaml必须设置为true:

gateway: tenants: label: "Tenant" # Some configuration omitted remoteConfiguration: true reporting: interval: 60000 persistence: type: file path: storage bufferSize: 1000 connection: host: "localhost" port: 1883 retryInterval: 3000 maxInFlight: 1000 security: accessToken: "6BW88NMt0nbsfVefQsGc" # keystore: mqttclient.jks # keystorePassword: password # keystoreKeyAlias: clientalias # truststore: mqttclient.jks # truststorePassword: password opc: enabled: false configuration: opc-config.json mqtt: enabled: false configuration: mqtt-config.json sigfox: enabled: false configuration: sigfox-config.json server: # Server bind address address: "0.0.0.0" # Server bind port port: "9090" # Check new version updates parameters updates: # Enable/disable updates checking. enabled: "${UPDATES_ENABLED:true}"

remoteConfiguration官方例子:

gateways: tenants: - label: "Tenant" # Some configuration omitted remoteConfiguration: true

If remoteConfiguration is set to false, GUI configuration will not take effect and ThingsBoard Gateway will look for configuration in config files.

得到Gateway的Access Token

在租户帐号下:

In order to connect your IoT gateway to ThingsBoard server, you need to provision gateway credentials first. We will use access token credentials as the most simple one. See device authentication options for more details.

新建设备

Login as tenant administrator. Use default credentials in case of local ThingsBoard server. Open Devices and click on big red “+” button in the bottom right corner.

image

Populate your gateway name and select “Is gateway” checkbox.

设置为网关

image

NOTE: Gateway and device names should be unique in the scope of a tenant.

Open new device card and click on “Copy Access Token” button.

查看gateway设备详情,复制 Access Token

image

若是gateway和thingsboard连上gateway设备的last elementry会出现“devicesOnline”, “attributesUploaded” and “telemetryUploaded”.:

Open the web UI of your ThingsBoard server and review statistics that is uploaded from your thingsboard gateway. Login as Tenant Administrator and open Devices page. Click on the gateway device card. Open “Latest Telemetry” tab and review following statistics: “devicesOnline”, “attributesUploaded” and “telemetryUploaded”. All values should be set to “0”.

image

使用GateWay链接到MQTT broker

https://thingsboard.io/docs/iot-gateway/getting-started/#step-8-connect-to-external-mqtt-broker

首先下载安装Mosquitto MQTT broker

有两种配置方式,一种是经过file configuration,一种是在ThingsBoard GUI

tb-gateway.yaml配置文件须要注意:

file configuration:remoteConfiguration:false

ThingsBoard GUI:remoteConfiguration:ture

同时若是用file启动要修改配置文件mqtt-config.json,且tb-gateway.yaml应该修改

mqtt: enabled: true configuration: mqtt-config.json

 

官方的配置无论怎么作都没法作到status出现sync但愿会的人告知(无论是mqtt仍是opcua

不须要网关Sync链接MQTT并创建dashboard:

救命视频:Creating an MQTT (IOT) Dashboard Using Thingsboard

https://www.youtube.com/watch?v=eqbTNXf2m7s

视频中的代码

http://www.steves-internet-guide.com/thingsboard-mqtt-dashboard/

 

用kafka plugin发送数据到kafka

Kafka plugin is responsible for sending messages to Kafka brokers triggered by specific rules

https://thingsboard.io/docs/reference/plugins/kafka/

须要注意的最后发送数据他写错了,引号写的不对,应该是

mosquitto_pub -d -h "localhost" -p 1883 -t "v1/devices/me/telemetry" -u "1EU6SlQetuBTC4I5a0bk" -m "{'temp':73.4}"

这里1883是tb-gateway的端口,mqtt和它原本是同一个端口,我修改了mqtt的端口

v1/devices/me/telemetry是固定的语句

1EU6SlQetuBTC4I5a0bk是accesstoken

关键点是把数据发送到特定access token,这样有这个access token的device就能够读取发送的数据

 

Kafka Plugin Action 没试过

This component allows creating a kafka message by substitution of device attributes and message data into configurable templates.

https://thingsboard.io/docs/reference/actions/kafka-plugin-action/

 

thingsboard拜拜喽

相关文章
相关标签/搜索