乐趣区

Centos7环境下源码部署ThingsBoard

本文为有 thingsboard 二次开发需求的同学准备,可以修改源码后编译运行。

准备工作

一台 4Gb 内存以上的服务器 (官方推荐 8Gb 以上,但实测以下配置即可正常运行)

Centos7 系统

打开 8080 端口

安装 wget

sudo yum install -y wget

更新 EPEL release

sudo yum install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

开始安装

安装 Java JDK-1.8

sudo yum install java-1.8.0-openjdk

sudo update-alternatives --config java

查看 Java 是否安装成功

java -version

期望输出为

openjdk version "1.8.0_xxx"
OpenJDK Runtime Environment (...)
OpenJDK 64-Bit Server VM (build ...)

如果输出不正常则需要配置环境变量

vim /etc/profile
export JAVA_HOME = ${你的安装路径不带 bin}

在 PATH 后边加入

$JAVA_HOME/bin

安装最新版 Maven(直接用 yum 安装可能会导致版本过低无法编译)

下载

wget https://www-eu.apache.org/dist/maven/maven-3/3.6.0/binaries/apache-maven-3.6.0-bin.tar.gz

解压缩

tar xvf apache-maven-3.6.0-bin.tar.gz -C /usr/lib/

配置环境变量

vi /etc/profile

添加以下代码

M2_HOME="/usr/lib/apache-maven-3.6.0"
export M2_HOME

M2="$M2_HOME/bin"
MAVEN_OPTS="-Xms256m -Xmx512m"
export M2 MAVEN_OPTS

PATH=$M2:$PATH
export PATH

加载更新后的 profile

. /etc/profile

source /etc/profile

查看 Maven 是否配置成功

mvn -version

有如下返回则表示成功
Apache Maven 3.6.0 (97c98ec64a1fdfee7767ce5ffb20918da4f719f3; 2018-10-24T23:41:47+05:00)
Maven home: /usr/lib/apache-maven-3.6.0
Java version: 1.8.0_191, vendor: Oracle Corporation, runtime: /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.191.b12-1.el7_6.x86_64/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-957.el7.x86_64", arch: "amd64", family: "unix"

安装 PostgreSQL

更新 yum

sudo yum update

安装 RPM

sudo yum install https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm

安装 Packages

sudo yum install postgresql96-server postgresql96-contrib

初始化 PostgreSQL

sudo /usr/pgsql-9.6/bin/postgresql96-setup initdb

启动服务

sudo systemctl start postgresql-9.6

设置 PostgreSQL 为开机启动

sudo systemctl enable postgresql-9.6

配置 PostgreSQL 密码

切换用户 postgres

sudo su - postgres

进入 PostgreSQL

psql

设置密码 (注意 ’\’ 也需要输入)

\password

记住设置的密码并退出

\q

更改 PostgreSQL 配置项

sudo vim /var/lib/pgsql/9.6/data/pg_hba.conf

更改以下行

# IPv4 local connections:
host    all             all             127.0.0.1/32            ident

# IPv4 local connections:
host    all             all             127.0.0.1/32            md5

重启 PostgreSQL

sudo systemctl restart postgresql-9.6.service

创建 database

进入数据库

如果在 postgres 用户下可以直接输入

psql

否则输入

psql -U postgres -d postgres -h 127.0.0.1 -W

创建 thingsboard 数据库并退出

CREATE DATABASE thingsboard;
\q

下载 Thingsboard 源码

安装 git

yum install git

Clone 源码

cd ~
git clone git@github.com:thingsboard/thingsboard.git

切换版本(这里以 2.3 版为例)

cd thingsboard
git checkout release-2.3

更改 Thingsboard 配置项

绕过 License 选项

vim pom.xml

找到 275 行开始的的
<plugin>
    <groupId>com.mycila</groupId>
    <artifactId>license-maven-plugin</artifactId>
    <version>3.0</version>
    <configuration>
    ....
</plugin>
整体注释掉
<!-- <plugin>
    <groupId>com.mycila</groupId>
    <artifactId>license-maven-plugin</artifactId>
    <version>3.0</version>
    <configuration>
    ....
</plugin> -->
保存并退出 vim

:wq

修改 Thingsboard 数据库相关配置

进入目录

cd ~/thingsboard/application/src/main/resources

vim thingsboard.yml

从 297 行起,注释掉 HSQLDB 部分,取消注释 PostgreSQL 部分
# HSQLDB DAO Configuration
#spring:
#  data:
#    jpa:
#      repositories:
#        enabled: "true"
#  jpa:
#    hibernate:
#      ddl-auto: "validate"
#    database-platform: "${SPRING_JPA_DATABASE_PLATFORM:org.hibernate.dialect.HSQLDialect}"
#  datasource:
#    driverClassName: "${SPRING_DRIVER_CLASS_NAME:org.hsqldb.jdbc.JDBCDriver}"
#    url: "${SPRING_DATASOURCE_URL:jdbc:hsqldb:file:${SQL_DATA_FOLDER:/tmp}/thingsboardDb;sql.enforce_si#ze=false;hsqldb.log_size=5}"
#    username: "${SPRING_DATASOURCE_USERNAME:sa}"
#    password: "${SPRING_DATASOURCE_PASSWORD:}"

# PostgreSQL DAO Configuration
spring:
 data:
    sql:
      repositories:
        enabled: "true"
  sql:
    hibernate:
      ddl-auto: "validate"
    database-platform: "${SPRING_JPA_DATABASE_PLATFORM:org.hibernate.dialect.PostgreSQLDialect}"
  datasource:
   driverClassName: "${SPRING_DRIVER_CLASS_NAME:org.postgresql.Driver}"
   url: "${SPRING_DATASOURCE_URL:jdbc:postgresql://localhost:5432/thingsboard}"
    username: "${SPRING_DATASOURCE_USERNAME:postgres}"
    password: "${SPRING_DATASOURCE_PASSWORD:postgres}"
修改此行数据库登录密码为之前步骤中设置的密码

password: "${SPRING_DATASOURCE_PASSWORD:postgres}"

跳过 js-executor 和 web-ui 的 windows 编译

分别修改以下两个文件

vim msa/js-executor/pom.xml
vim msa/web-ui/pom.xml

注释掉以下内容 (两个文件都要改)

 <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-assembly-plugin</artifactId>
    <version>3.0.0</version>
    <configuration>
        <finalName>${pkg.name}</finalName>
        <descriptors>
            <descriptor>src/main/assembly/windows.xml</descriptor>
        </descriptors>
    </configuration>
    <executions>
        <execution>
            <id>assembly</id>
            <phase>package</phase>
            <goals>
                <goal>single</goal>
            </goals>
        </execution>
    </executions>
</plugin>

编译 thingsboard 源码

cd ~/thingsboard

耗时较长需要耐心等待

mvn clean install -DskipTests -X

出现如下提示则编译成功(缺一不可)

安装编译好的 tingsboard

找到编译好的安装文件

cd application/target

运行安装

sudo rpm -Uvh thingsboard.rpm

运行脚本

sudo /usr/share/thingsboard/bin/install/install.sh --loadDemo

启动服务

sudo service thingsboard start

完成

至此从配置环境到源码编译运行的 Thingsboard 运行成功

可以访问 localhost:8080 服务器 ip:8080 访问页面

注意事项

前端的同学注意

thingsboard 有热更新服务,可以用于开发。

具体操作:
cd ~/thingsboard/ui
maven install -P npm-start
即可在 3000 端口启动前端服务。

不过需要注意的是

如果前端后端不在同域名下,例如后端服务在云端,前端服务在本地,则需要修改以下文件中的内容

vim ~/thingsboard/ui/server.js

const forwardHost = 'localhost';

const ruleNodeUiforwardHost = 'localhost';
把 localhost 改成你的域名或 ip 即可

附录

一些相关的命令

PostgreSQL 导入 SQL

psql -d 数据库名称 -U 用户名 -f xxx.sql

如果当前用户是 postgres

psql -d 数据库名称 -f xxx.sql

删除数据库

进入数据库后输入

drop database 数据库名称

Thingsboard 服务启动 / 停止

sudo service thingsboard [start | stop]

查看 Thingsboard 错误日志

cat /var/log/thingsboard/thingsboard.log | grep ERROR

退出移动版