Linux以Ubuntu和CentOS为主流,以此两个发行版为例进行流程命令示例,截图按照Ubuntu Server实际环境。
安装JDK11。(Debain apt源下载慢可以考虑换国内软件源,yum也是如此)
sudo apt update
sudo apt install openjdk-11-jdk
# Add latest EPEL release for CentOS 7
sudo yum install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
sudo yum install java-11-openjdk
此时用java -version
查看是JDK11的版本信息
java -version
如果出现的1.8或者其他的版本信息,证明你之前装过JDK并正确配置,需要手动配置,手动配置方式如下:
sudo update-alternatives --config java
选择JDK11对应的版本切换到当前的环境下。
# 下载安装包
wget https://github.com/thingsboard/thingsboard/releases/download/v3.4.4/thingsboard-3.4.4.deb
# 安装
sudo dpkg -i thingsboard-3.4.4.deb
# 下载安装包
wget https://github.com/thingsboard/thingsboard/releases/download/v3.4.4/thingsboard-3.4.4.rpm
# 安装
sudo rpm -Uvh thingsboard-3.4.4.rpm
鉴于初期的场景message不会并发大于5000条,在此仅安装PostgreSQL
# 一般服务器自带wget,如果没有请用如下命令安装
sudo apt install -y wget
# 引入镜像源密钥
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
# 将镜像源添加到本机软件源
RELEASE=$(lsb_release -cs)
echo "deb http://apt.postgresql.org/pub/repos/apt/ ${RELEASE}"-pgdg main | sudo tee /etc/apt/sources.list.d/pgdg.list
# 安装并启动 postgresql 服务:
sudo apt update
sudo apt -y install postgresql-12
sudo systemctl start postgresql
# 设置开机启动
sudo systemctl enable postgresql
sudo yum install -y wget
# 更新软件源
sudo yum update
# 安装
sudo yum -y install https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
# 配置
sudo yum -y install epel-release yum-utils
sudo yum-config-manager --enable pgdg12
sudo yum install postgresql12-server postgresql12
# 初始化PostgreSQL DB
sudo /usr/pgsql-12/bin/postgresql-12-setup initdb
sudo systemctl start postgresql-12
# 开机启动
sudo systemctl enable --now postgresql-12
为thingsboard的例程添加数据库的初始化配置:
切换到postgres用户下,为登录postgresql用户设置密码
sudo su - postgres
psql
# 此行命令后按照提示输入密码
\password
# 输入后退出
\q
(注意)CentOS下多一步配置:
编辑配置文件/var/lib/pgsql/12/data/pg_hba.conf
sudo vim /var/lib/pgsql/12/data/pg_hba.conf
定位到以下内容,将ident修改为md5
# IPv4 local connections: host all all 127.0.0.1/32 ident
修改后
host all all 127.0.0.1/32 md5
重启服务
sudo systemctl restart postgresql-12.service
登录数据库并创建数据库
psql -U postgres -d postgres -h 127.0.0.1 -W
CREATE DATABASE thingsboard;
\q
编辑thingsboard的配置文件
sudo vim /etc/thingsboard/conf/thingsboard.conf
在配置文件中添加以下内容,注意密码那一行替换成自己的密码
# DB Configuration
export DATABASE_TS_TYPE=sql
export SPRING_DATASOURCE_URL=jdbc:postgresql://localhost:5432/thingsboard
export SPRING_DATASOURCE_USERNAME=postgres
export SPRING_DATASOURCE_PASSWORD=PUT_YOUR_POSTGRESQL_PASSWORD_HERE
# Specify partitioning size for timestamp key-value storage. Allowed values: DAYS, MONTHS, YEARS, INDEFINITE.
export SQL_POSTGRES_TS_KV_PARTITIONING=MONTHS
注意下面的配置内容可选,如果你的服务器内存是1G的,比较受限,需要额外配置以下jvm以保证效率。
# Update ThingsBoard memory usage and restrict it to 256MB in /etc/thingsboard/conf/thingsboard.conf
export JAVA_OPTS="$JAVA_OPTS -Xms256M -Xmx256M"
我们没有经过消息队列等辅助高效缓存配件的安装,后续需要用到MQ、Kafka等可以再行安装,这里采用纯内存的策略。
运行安装脚本,--loadDemo
其会导入几个用户、设备、资产、规则等用于示例
# --loadDemo option will load demo data: users, devices, assets, rules, widgets.
sudo /usr/share/thingsboard/bin/install/install.sh --loadDemo
重启thingsboard服务
systemctl restart thingsboard.service
# 查看一下
systemctl status thingsboard.service
安全组策略放行8080端口,防火墙放行8080端口。
安全组策略需要在你的云实例控制台上自行配置,而防火墙因人而异,你的服务器用iptables或者firewalld均有不同的操作方式
这里采用firewalld
sudo firewall-cmd --add-port=8080/tcp --zone=public --permanent
sudo firewall-cmd --reload
访问http://【你的服务器ip】:8080测试
这里有几个默认的账户
人员 | 账号 | 密码 |
---|---|---|
系统管理员 | [email protected] | sysadmin |
租户管理员 | [email protected] | tenant |
客户管理员 | [email protected] | customer |
注意:资源有限的服务器(1-2CPU、1-2GB RAM),一般Web UI的启动需要等待90秒左右。
登录系统管理员:
登录租户管理员:
运行日志在/var/log/thingsboard
过滤错误日志可以快速使用如下命令:
cat /var/log/thingsboard/thingsboard.log | grep ERROR
如下是官方智慧农业仪表盘案例
https://thingsboard.io/smart-farming/
点击查看在线案例
右上角选择导出
导出后是个json文件
添加一个客户
客户组里添加一个用户,激活方式可以选择激活链接或者邮箱链接,我们是测试,邮箱也是虚构的,那么就选择链接激活。
点击激活
激活后就到了设置密码的界面。
创建完密码就登录进来了
我们返回租户管理员的账号
将导入的仪表盘分配给客户
选择新添加的用户
设置首页为仪表盘
编辑仪表盘
打开设置的显示仪表盘标题
登录新增用户,首页便是仪表盘
可以全屏显示,也可以将某个小部分进行全屏显示。
活动数据需要写硬件程序并生成数字孪生的实体进行相应映射。