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

JetLinks物联网平台微服务化系列文章介绍

橙蜂智能公司致力于提供先进的人工智能和物联网解决方案,帮助企业优化运营并实现技术潜能。公司主要服务包括AI数字人、AI翻译、AI知识库、大模型服务等。其核心价值观为创新、客户至上、质量、合作和可持续发展。

橙蜂智农的智慧农业产品涵盖了多方面的功能,如智能化推荐、数据分析、远程监控和决策支持系统。用户可以通过应用获得个性化的作物种植建议、实时的生长状态监控以及精确的灌溉和施肥指导,提升农业生产效率。

        JetLinks物联网平台是国内开源(JetLinks提供开源的社区版和付费的企业版两个版本,下面的描述都是针对JetLinks社区版进行)的一款企业级的物联网平台,在国内开源的物联网平台中,star数和活跃度均名列前茅。JetLinks物联网平台的功能齐全,设备接入方面支持多种网络协议和私有协议;采用全异步的设计,从模块级到方法级都采用了异步通讯,web层和db层也都是异步化的;支持多种时序数据库,如ElasticSearch、ClickHouse、InfluxDB、TDengine、Cassandra。

        JetLinks物联网平台功能齐全,足够应对小设备量或者业务简单的场景,但是如果设备量比较大,或者业务复杂,需要做一些定制化开发时,其单体架构将会是一大限制因素。

  1. 因为JetLinks是单体架构,而其功能又比较多,必然造成代码量大而且复杂,开发者在不了解整体代码的前提下开发容易引入bug,系统可用性降低。

  2. 同样由于项目庞大,启动缓慢,使得开发、测试的流程很长,开发效率低,且由于测试不充分导致引入bug。

  3. 单体项目只能横向扩容,会浪费一定服务器资源。

  4. JetLinks整体采用基于Project Reactor的响应式编程,虽然方便构建异步非阻塞的应用,但是它也有着生态不完善(支持响应式的数据库和orm框架不多,无法进行复杂的多表查询),学习成本高,调试复杂等缺点。因此,重业务的模块如设备管理、数据查询等,并不适合采用响应式框架,但是由于是单体架构,我们不得已所有模块都采用这同一种技术。

        本系列的目的就是带着大家一步步地将JetLinks物联网平台重构为微服务架构,重构后的系统能够解决以上问题:

  1. 微服务拆分后,各服务的代码量较小,功能单一,代码更容易理解和维护,测试可以更充分,引入bug的概率小,可用性提高。

  2. 各微服务可以独立扩容,相对更加节省服务器资源。

  3. 各微服务可以采用不同的技术栈,如设备管理模块可以不同响应式,这样就可以使用MyBatis框架,进行复杂sql的查询。

通过本系列文档,希望和大家一起掌握如下技能:

  • 遗留系统重构的方法论和实操;

  • 微服务设计的方法论,包括领域驱动设计的应用;

  • 微服务的测试;

  • 微服务的集群部署。

相关文章:

  • linux 目录文件夹操作
  • 使用 Docker 制作 YashanDB 镜像:深度解析与实战指南
  • 番外篇 | 复现AC-YOLOv5,进行自动化织物缺陷检测
  • CSP-J 复赛算法 贪心策略应用
  • 棒材翘头翘尾影响大 在线直线度测量仪监测保品质!
  • index.html 调用 ajax
  • [spring]SpringBoot拦截器 统一数据返回格式 统一异常处理
  • QML使用Qt自带软键盘例子
  • Robot Operating System——带有协方差矩阵的三维空间中的位姿(位置和方向)
  • 成都睿明智科技有限公司赋能商家高效变现
  • OpenHarmony(鸿蒙南向)——平台驱动开发【PIN】
  • N诺计算机考研-错题(DS)
  • Qt C++设计模式->享元模式
  • [C++][IO流][流输入输出][截断理解]详细讲解
  • 【EXCEL数据处理】000011 案列 EXCEL带有三角形图标的单元格转换
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • JSDuck 与 AngularJS 融合技巧
  • MD5加密原理解析及OC版原理实现
  • mockjs让前端开发独立于后端
  • nodejs实现webservice问题总结
  • Objective-C 中关联引用的概念
  • redis学习笔记(三):列表、集合、有序集合
  • 百度地图API标注+时间轴组件
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 欢迎参加第二届中国游戏开发者大会
  • 手写一个CommonJS打包工具(一)
  • 无服务器化是企业 IT 架构的未来吗?
  • 因为阿里,他们成了“杭漂”
  • No resource identifier found for attribute,RxJava之zip操作符
  • ​你们这样子,耽误我的工作进度怎么办?
  • #前后端分离# 头条发布系统
  • #图像处理
  • (19)夹钳(用于送货)
  • (仿QQ聊天消息列表加载)wp7 listbox 列表项逐一加载的一种实现方式,以及加入渐显动画...
  • (附源码)spring boot建达集团公司平台 毕业设计 141538
  • (附源码)计算机毕业设计SSM疫情居家隔离服务系统
  • (佳作)两轮平衡小车(原理图、PCB、程序源码、BOM等)
  • (四十一)大数据实战——spark的yarn模式生产环境部署
  • (一)80c52学习之旅-起始篇
  • (转)nsfocus-绿盟科技笔试题目
  • (转)为C# Windows服务添加安装程序
  • (转)用.Net的File控件上传文件的解决方案
  • *1 计算机基础和操作系统基础及几大协议
  • .[hudsonL@cock.li].mkp勒索加密数据库完美恢复---惜分飞
  • .gitignore
  • .MyFile@waifu.club.wis.mkp勒索病毒数据怎么处理|数据解密恢复
  • .NET 8 中引入新的 IHostedLifecycleService 接口 实现定时任务
  • .NET Core跨平台微服务学习资源
  • .net FrameWork简介,数组,枚举
  • .NET 分布式技术比较
  • .NET/C# 项目如何优雅地设置条件编译符号?
  • .NET/C# 在 64 位进程中读取 32 位进程重定向后的注册表
  • .NET的微型Web框架 Nancy
  • .NET国产化改造探索(一)、VMware安装银河麒麟
  • .NET面试题(二)