本章将介绍ThingsBoard的本地环境搭建,以及源码的编译安装。本机环境:jdk1.8、postgresql-12.2-2-windows-x64、maven 3.6.2、node v12.18.2、idea 2020.1、redis 3.2。
开发环境要求:
Jdk 1.8 版本 ;Postgresql 9 以上;Maven 3.6 以上;Git 工具;Idea 开发工具;Redis;Node.js,npm;上述条件满足后,接下来是通过 Git 拉取代码。
温馨提醒:由于网络原因等因素,若安装过程中失败,建议先清空maven本地仓库的jar以及ui-ngx工程下的node_modules目录。然后再执行下面操作。
在本地创建代码存放位置的文件目录,然后进入当前目录点击鼠标右键,选择 Git Bash Here,输入 git 命令克隆源代码。本章节以3.0版本为例。
git clone -b release-3.0 https://github.com/thingsboard/thingsboard.git由于默认仓库地址的下载速度很慢,因此使用阿里云的镜像会节省很多时间。maven conf目录下的settings.xml配置如下:
<mirrors> <mirror> <id>nexus-aliyun</id> <mirrorOf>central</mirrorOf> <name>Nexus aliyun</name> <url>https://maven.aliyun.com/repository/public</url> </mirror> </mirrors>导入后,先使用maven工具清理项目编译文件。 导入IDEA后,需要改下pom文件里面的node和npm版本与你本地的一致。如图: 注意!!!!thingsboard 3.1版本包管理换成了yarn,因此要看清pom文件的xml标签,yarnVersion对应yarn的版本。
改完之后可以去掉license检查步骤,节省编译时间。
在 IDEA 控制台(左下方)Terminal 输入以下命令进行编译:
mvn clean install -DskipTests等一段时间后,看到下面这张图就算编译成功,如果没有编译成功请按照本教程最后的常见问题进行排查。
原因:本地缓存缺少 fetched-v10.15.3-linux-x64 和 fetched-v10.15.3-win-x64 或 fetched-v10.17.10-linux-x64 和 fetched-v10.17.10-win-x64 这两个文件。 解决办法:
下载这两个文件到本地,下载后记得重命名,下载地址:Github地址 如果github上的这几个文件下载很慢,可以直接使用csdn下载,链接如下: fetched-v10.17.0-win-x64 fetched-v10.17.0-linux-x64 fetched-v10.15.3-win-x64 fetched-v10.15.3-linux-x64
如何你的csdn没有积分,可直接在物联工坊免费下载,链接如下: fetched-v10.17.0-win-x64 fetched-v10.17.0-linux-x64 fetched-v10.15.3-win-x64 fetched-v10.15.3-linux-x64
下载完成后,放到C盘用户下的.pkg目录,如图:
原因:没有安装git或者是没有配置git的环境变量
编译前需要安装proto和lombok插件,可直接在插件市场安装,如图: 安装完成后重启idea进行编译。如果是2020版本的idea,可能还会报找不到符号之类的错误,这个时候需要清理下缓存重启idea: 还报这个错误的话,需要重置下idea的配置:
解决:将已经安装的C:\Program Files\nodejs\node.exe(node的安装路径)复制到maven本地仓库F:\share\local_repo\com\github\eirslett\node\12.18.2(本地仓库的node目录,版本号自行对应,名称自行修改)
原因:thingsboard 项目地址不支持中文。 解决:将项目转移到全英文路径
自己在编译Thingsboard 3.0也遇到了很多麻烦,在此总结一下,也希望可以帮助到更多的小伙伴,避免和我踩一样的坑。文章来自我的个人站:物联工坊