当前位置: 首页 > article >正文

ThingsBoard源码本地部署实战:从环境准备到成功启动的避坑指南

1. 环境准备打好地基才能盖高楼第一次在本地部署ThingsBoard源码时我像大多数开发者一样直接clone代码就往IDE里导结果被各种依赖问题折腾得够呛。后来才发现源码部署就像装修房子水电改造环境配置没做好后面全是隐患。硬件配置建议我实测8GB内存的机器跑起来比较吃力编译阶段经常卡死。现在用的16GB内存开发机配合SSD硬盘整体流程能控制在30分钟内。如果只是学习测试云服务器建议选择2核4GB以上配置。软件环境需要特别注意版本匹配JDK官方推荐Java 11我用的OpenJDK 11.0.15Maven3.6.x以上3.8.1实测稳定PostgreSQL12.x版本最佳14.x会有兼容性警告Git2.30版本即可注意千万不要用Java 17虽然ThingsBoard新版开始支持但源码编译时会遇到各种反射API的兼容性问题我在这上面浪费过整整一天时间。安装完基础环境后建议先做个快速验证java -version mvn -v psql --version这三个命令能正常输出版本信息说明环境变量配置正确。有个容易忽略的点Maven的settings.xml文件需要提前配置好国内镜像源否则下载依赖时会慢到怀疑人生。2. 源码初始化别让网络问题坑了你从GitHub克隆代码后千万别急着用IDE打开。我吃过亏 - IDEA自动构建会漏掉关键资源文件生成。正确的打开方式是先在命令行执行mvn clean install -DskipTests这个命令背后做了三件重要的事生成protobuf协议文件后面消息通信的基础编译前端资源Vue组件打包准备数据库初始化脚本藏在target/data目录里常见坑点网络超时我在公司内网构建时因为maven中央仓库连接不稳定失败了5次。后来在settings.xml里配了阿里云镜像才解决mirror idaliyun/id urlhttps://maven.aliyun.com/repository/public/url mirrorOfcentral/mirrorOf /mirror内存不足可以临时设置环境变量增大内存export MAVEN_OPTS-Xmx2048m -XX:MaxPermSize1024m前端构建卡住如果停在frontend:build阶段超过10分钟可能是node_modules缓存问题。删除根目录下的node_modules文件夹重新构建即可。3. 数据库配置小心字段里的魔鬼细节PostgreSQL配置是个精细活我建议先创建专用用户和数据库CREATE USER thingsboard WITH PASSWORD 你的密码; CREATE DATABASE thingsboard OWNER thingsboard;修改application.yml时这几个参数最容易出错spring: datasource: url: jdbc:postgresql://localhost:5432/thingsboard username: thingsboard password: 你的密码 driverClassName: org.postgresql.Driver高频踩坑记录SQL文件找不到第一次运行ThingsBoardInstallApplication时报错schema.sql not found。这是因为初始化构建时生成的sql文件在target/data下需要手动复制到application/src/main/data目录。LwM2M模型加载失败这个错误提示很隐蔽Caused by: java.nio.file.NoSuchFileException: lwm2m-registry检查thingsboard.yml文件确保install.data_dir指向正确路径。我这边最后配置的是install: data_dir: application/src/main/data时区问题如果启动后时间显示不对在JDBC连接串后加上时区参数jdbc:postgresql://localhost:5432/thingsboard?currentSchemathingsboardstringtypeunspecifiedTimeZoneAsia/Shanghai4. IDE集成消除那些烦人的红色波浪线用IDEA打开项目后大概率会遇到两类问题第一类Protobuf相关错误症状是org.thingsboard.server.common.msg.gen.MsgProtos等类标红。这是因为项目使用了Google的Protocol Buffers需要安装Protobuf插件不同IDEA版本适配不同在Preferences - Build - Compiler - Annotation Processors中启用处理重新编译生成proto文件第二类License报错打包时出现的Some files do not have the expected license header警告有两种解决方案给新增文件添加头注释模板在根目录LICENSE.header在pom.xml中禁用检查不推荐plugin groupIdcom.mycila/groupId artifactIdlicense-maven-plugin/artifactId configuration skiptrue/skip /configuration /plugin实用技巧遇到反射警告WARNING: Illegal reflective access可以添加JVM参数--add-opens java.base/java.langALL-UNNAMED前端开发时可以单独启动Vue开发服务器cd ui-ngx npm install npm start5. 启动与调试从理论到实践的最后一公里完成上述步骤后通过ThingsBoardServerApplication启动主类。第一次启动会比较慢约1-2分钟控制台看到这个日志说明成功Started ThingsBoardServerApplication in 42.305 seconds常见启动异常处理端口冲突默认的8080端口被占用时修改application.yml中的server: port: 你的端口 address: 0.0.0.0数据库连接池耗尽在高压测试时可能出现调整连接池参数spring: datasource: hikari: maximum-pool-size: 50 connection-timeout: 30000缓存问题修改配置后建议清理缓存mvn clean compile rm -rf application/target/生产环境建议 虽然开发时可以直接运行main方法但正式环境建议用打包后的安装脚本Windowstarget/thingsboard-windows.batLinuxtarget/thingsboard-linux.sh这些脚本会自动处理服务注册、日志轮转等运维操作。我在内网测试时发现Windows脚本执行后窗口会闪退这时需要手动查看logs/thingsboard.log排查问题。

相关文章:

ThingsBoard源码本地部署实战:从环境准备到成功启动的避坑指南

1. 环境准备:打好地基才能盖高楼 第一次在本地部署ThingsBoard源码时,我像大多数开发者一样直接clone代码就往IDE里导,结果被各种依赖问题折腾得够呛。后来才发现,源码部署就像装修房子,水电改造(环境配置&…...

手把手教你用llama.cpp在树莓派上跑大模型(附完整配置流程)

在树莓派上部署llama.cpp的完整实践指南 树莓派作为一款价格亲民且功能强大的微型计算机,近年来在边缘计算和嵌入式AI领域崭露头角。本文将详细介绍如何在树莓派上部署llama.cpp这一轻量级大语言模型推理框架,让开发者能够在资源受限的环境中体验前沿AI技…...

ChatBI怎么在BI试点中用?3个低门槛落地场景亲测有效

ChatBI试点的前置门槛:先搞定最小可行数据集,不用全量建设 ChatBI是观远数据推出的自然语言分析产品,用户可以通过口语化的提问直接获取数据结果、可视化图表甚至分析结论,无需掌握复杂的报表制作或SQL查询技能。在BI试点阶段引入…...

集团型企业BI试点,为什么一定要先做多域资源隔离?

艾瑞咨询《2025年中国BI市场报告》显示,超7成集团型企业的首次BI试点项目因跨业务单元权限冲突、数据口径混乱延期或终止(统计样本覆盖120家年营收超50亿的国内集团企业,统计窗口为2022-2024年试点项目全生命周期)。这个数据和大部…...

避坑指南:Maya LiveLink插件安装常见报错解决方案(附FBX传输优化技巧)

Maya LiveLink插件避坑实战:从安装报错到FBX传输优化的全流程指南 每次打开Maya准备大干一场时,那个熟悉的.mll加载失败弹窗就像个不速之客——特别是当你需要在截止日期前完成虚幻引擎的动画对接时。作为连接Maya与虚幻引擎的神经中枢,LiveL…...

新手福音:用快马生成你的第一个c盘自动清理python脚本

今天想和大家分享一个特别实用的Python小工具——C盘自动清理脚本。作为一个刚接触编程的新手,我发现清理C盘空间是个常见需求,但手动操作既麻烦又容易误删重要文件。于是我用InsCode(快马)平台生成了一个简单实用的脚本,整个过程特别适合编程…...

根据以上内容,可拟定的标题为:“MATLAB仿真复现光纤激光器中耗散孤子共振DSR的演化过程:...

MATLAB仿真复现耗散孤子共振DSR 根据谱方法求解复立方五次方金兹堡朗道方程 获得光纤激光器中耗散孤子的演化过程耗散孤子共振光纤激光器仿真平台:从 Ginzburg-Landau 方程到多维度脉冲演化分析—— 一套可扩展、可配置、可动画的 MATLAB 谱方法框架一、背景与需求高…...

电池包结构仿真与力学分析指南

电池包结构仿真,电池包力学仿真,电池包CAE分析,新能源电池电池CAE分析,结构仿真,力学分析附带相对应的模型文件,指导书,可直接自己跟着做分析另外附赠完整电池包模型一、概述随着新能源汽车的飞速发展&…...

Modbus协议详解:从原理到工业应用实践

1. Modbus协议概述Modbus是一种应用层报文传输协议,由Modicon公司(现为施耐德电气旗下品牌)于1979年开发。作为工业自动化领域最广泛采用的通信协议之一,它定义了控制器设备之间交换信息的通用语言。关键特性:协议标准…...

Windows平台用CMake+VS2019编译NLopt的完整流程(附环境变量配置)

Windows平台用CMakeVS2019编译NLopt的完整流程(附环境变量配置) 在科学计算和优化算法开发领域,NLopt作为一个功能强大的开源库,提供了多种非线性优化算法的实现。对于Windows平台的C开发者而言,掌握从源码构建NLopt的…...

建筑物缺陷分割图像识别

建筑物缺陷分割图像识别 README 项目概述 建筑物缺陷分割数据集分析数据概览关键信息总数量5213张图像,涵盖类别:裂缝、剥落、锈蚀、污渍数据集数量5200数据集格式YoloVOC;应用价值:支持建筑物缺陷自动分割与识别,用于…...

告别模糊:手把手教你用LAMBDA算法搞定GNSS整周模糊度(附Python代码示例)

告别模糊:手把手教你用LAMBDA算法搞定GNSS整周模糊度(附Python代码示例) 当你在开发高精度定位系统时,是否曾被整周模糊度问题困扰?这个看似简单的整数解问题,实际上影响着厘米级定位的成败。作为GNSS领域的…...

C++ 地址空间随机化(ASLR):探讨 C++ 动态链接库在内存布局上的安全特性

尊敬的各位同仁,各位对系统安全和C编程充满热情的开发者们,大家下午好!今天,我们齐聚一堂,共同探讨一个在现代软件安全领域至关重要的主题——地址空间布局随机化(ASLR),特别是它如何…...

重构求职效率:boss_batch_push批量投递工具的颠覆性价值

重构求职效率:boss_batch_push批量投递工具的颠覆性价值 【免费下载链接】boss_batch_push Boss直聘批量投简历,解放双手 项目地址: https://gitcode.com/gh_mirrors/bo/boss_batch_push boss_batch_push是一款专为Boss直聘平台设计的开源自动化投…...

永磁同步电机矢量控制仿真避坑指南:从PI参数整定到SVPWM模块优化

永磁同步电机矢量控制仿真避坑指南:从PI参数整定到SVPWM模块优化 在工业自动化和电力驱动领域,永磁同步电机(PMSM)凭借其高效率、高功率密度和优异的动态性能,已成为众多应用场景的首选。然而,要实现PMSM的…...

社媒爆款流水线:手把手教你用Runway Gen-4.5的A/B测试功能,批量生产TikTok热门视频

社媒爆款流水线:用Runway Gen-4.5打造数据驱动的短视频生产引擎 在短视频内容爆炸式增长的今天,一个残酷的现实是:99%的内容在发布后的24小时内就会沉入算法深渊。那些能突破重围的爆款视频,往往不是偶然灵感的产物,而…...

2025届学术党必备的五大AI写作网站解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek DeepSeek身为新一代人工智能辅助写作工具,于学术论文撰写的整个流程里&#xff0…...

VictoriaMetrics 集群版实战指南:架构解析与最佳实践

1. VictoriaMetrics集群版架构深度解析 第一次接触VictoriaMetrics集群版时,我被它简洁的组件划分惊艳到了。与常见的时序数据库不同,它的三大核心组件vmstorage、vminsert、vmselect各司其职,这种设计让横向扩展变得异常灵活。在实际部署中&…...

2026届必备的五大AI辅助论文助手实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 基于大语言模型与自然语言处理技术的 AI 写作软件,是内容生产领域新兴工具&…...

数组运算18题:从递归求和解到Kadane算法

1. 数组运算进阶指南:18道经典题目深度解析数组作为最基本的数据结构,在编程面试和实际开发中无处不在。掌握数组的各种运算技巧不仅能帮助你在面试中脱颖而出,更能提升日常编码的效率和质量。本文将深入解析18个经典的数组运算题目&#xff…...

5个维度解析UEFITOOL:BIOS固件分析与修改的全能工具

5个维度解析UEFITOOL:BIOS固件分析与修改的全能工具 【免费下载链接】UEFITOOL28 项目地址: https://gitcode.com/gh_mirrors/ue/UEFITOOL28 UEFITOOL是一款专注于UEFI BIOS固件解析的开源工具,它能够帮助技术人员深入分析固件内部结构、提取关键…...

Bypass Paywalls Clean:智能内容解锁工具的终极使用指南

Bypass Paywalls Clean:智能内容解锁工具的终极使用指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在数字化信息时代,学术研究者、新闻从业者和知识工作者…...

实战指南:基于快马平台生成git自动化部署脚本,实现ci/cd流水线

今天想和大家分享一个实战中特别实用的技巧:如何用git结合自动化脚本来简化版本发布和部署流程。这个方案在我们团队的实际项目中已经稳定运行了大半年,效果非常不错。 版本号自动打tag功能 这个脚本的核心功能之一就是自动读取项目中的版本号文件&…...

STMPE811电阻触摸屏驱动设计与实现

1. 项目概述TS_DISCO_F429ZI 是专为 STMicroelectronics STM32F429ZI 探索套件(DISCO_F429ZI)设计的触摸屏驱动类,其核心职责是抽象并控制该开发板上集成的 LCD 模块所搭载的电阻式触摸屏控制器。该类并非通用型触摸驱动,而是深度…...

新手入门:在快马平台动手实现你的第一个ui-ux-pro-max设计页面

作为一个刚接触前端设计的新手,最近在InsCode(快马)平台尝试做了一个UI-UX-Pro-Max级别的登录注册页面,整个过程意外地顺利。这里记录下我的实践过程,希望能帮到同样想入门的朋友。 从零搭建页面框架 先用HTML搭建基础结构,包含表…...

STM32除零运算不崩溃的机制与配置解析

1. STM32单片机除零运算不崩溃的底层机制解析 在嵌入式开发领域,STM32系列单片机因其出色的性能和丰富的外设资源而广受欢迎。许多从传统PC平台转向嵌入式开发的工程师都会发现一个有趣的现象:在STM32上执行除零操作时,程序竟然不会像在PC上那…...

QtScrcpy全场景投屏效率指南:跨设备协作与多终端控制解决方案

QtScrcpy全场景投屏效率指南:跨设备协作与多终端控制解决方案 【免费下载链接】QtScrcpy Android实时投屏软件,此应用程序提供USB(或通过TCP/IP)连接的Android设备的显示和控制。它不需要任何root访问权限 项目地址: https://gitcode.com/barry-ran/Qt…...

掌握Pwndbg调试器:从入门到精通的界面定制与配置指南

掌握Pwndbg调试器:从入门到精通的界面定制与配置指南 【免费下载链接】pwndbg Exploit Development and Reverse Engineering with GDB & LLDB Made Easy 项目地址: https://gitcode.com/GitHub_Trending/pw/pwndbg Pwndbg作为GDB和LLDB的增强扩展&#…...

MOS管选型实战指南

MOS管(金属氧化物半导体场效应晶体管)是现代电力电子和开关电路的核心元件。选型失误的后果往往是灾难性的——效率低下、发热严重、驱动振荡、甚至炸管冒烟。相比电阻电容,MOS管的选型需要权衡的维度更多:电压、电流、导通电阻、开关速度、驱动电压、热阻、体二极管特性……...

Ant Design X:AI赋能前端开发的革命性工具

1. Ant Design X:当设计系统遇上AI会发生什么? 第一次听说Ant Design X时,我正在为一个电商项目焦头烂额地调试聊天机器人组件。传统方案需要自己对接NLP服务、处理对话状态、设计交互逻辑...直到同事扔给我一个链接:"试试这…...