当前位置: 首页 > 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的查询。

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

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

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

  • 微服务的测试;

  • 微服务的集群部署。

http://www.lryc.cn/news/451019.html

相关文章:

  • 【QT Quick】基础语法:导入外部QML文件
  • Llama 系列简介与 Llama3 预训练模型推理
  • 【AIGC】ChatGPT提示词助力自媒体内容创作升级
  • SSTI基础
  • 10.1软件工程知识详解上
  • 03Frenet与Cardesian坐标系(Frenet转Cardesian公式推导)
  • knowLedge-Vue I18n 是 Vue.js 的国际化插件
  • 【开源免费】基于SpringBoot+Vue.JS微服务在线教育系统(JAVA毕业设计)
  • expressjs 中的mysql.createConnection,execute 怎么使用
  • 每日一题|983. 最低票价|动态规划、记忆化递归
  • oracle 正则 匹配 身份正 手机号
  • 在树莓派上部署开源监控系统 ZoneMinder
  • 2022年6月 Frontier 获得性能第一的论文翻译
  • B2B商城交易解决方案:赋能企业有效重塑采购与销售新生态
  • 初始C语言(五)
  • mysql学习教程,从入门到精通,SQL 修改表(ALTER TABLE 语句)(29)
  • 【网络基础】网络常识快速入门知识清单,看这篇文章就够了
  • OceanBase 关于一号表笔记与ERROR 1060(42S21)问题
  • 【四】Spring Cloud OpenFeign原理分析
  • EDM平台大比拼 用户体验与营销效果双重测评
  • 开卷可扩展自动驾驶(OpenDriveLab)
  • 基于大数据的二手电子产品需求分析及可视化系统
  • SpringBoot——基础配置
  • Android OpenGLES2.0开发(三):绘制一个三角形
  • 数据清洗的重要性与方法
  • AI与大数据的结合:如何从海量数据中提取价值
  • 【漏洞复现】孚盟云oa AjaxSendDingdingMessage接口 存在sql注入漏洞
  • 【VUE】案例:商场会员管理系统
  • IDEA 最新版创建 Sping Boot 项目没有 JDK8 选项的解决方案
  • Unity Asset Store的默认下载位置及更改下载路径的方法