物联网平台选择GO还是JAVA语言开发,纠结吗?

文章讲述了作者在物联网平台技术选型中,弃Java转用Go语言的决策,强调了Go语言的性能优势和团队技术栈的适应性。通过模块化设计和插件化架构,实现了高可维护性和可扩展性,成功应用于多个智慧能源和环境监控项目。
摘要由CSDN通过智能技术生成

       物联网平台技术选型中,大多数人通常会选择使用Java语言进行开发。早些年,我们的物联网平台也是采用了Java开发。然而,Go语言也是一个出色的选择。有一年,我们接到了一个二轮换电柜的项目,对服务器性能和灵活性有着较高的要求。尽管我们的团队都是Java开发人员,虽然Java也可以胜任,但考虑到未来的发展方向和我们团队的技术栈,我做出了选择,决定采用Go语言进行开发。

       结果非常令人满意,我们只需要一台4核8GB的服务器,性能资源利用率不到30%,每天能够处理约10多万个订单。这个系统已经稳定运行了四年多,以至于我们几乎忘记了服务器的存在。现在回头看,这个选择无疑是非常正确的。

       慢慢地,我们开始将之前用Java开发的产品逐步迁移到Go语言开发。如今,我们的物联网平台已经全部采用Go语言开发。尽管我知道Java目前有一些非常流行的物联网开源项目,比如thingsboard以及国内的jetlinks,但我仍然选择了自己开发。这并不是为了重复造轮子,而是因为我们的产品定位和客户需求不同。另外,我一直不太喜欢过于重的架构体系,我希望以更轻量的方式实现我们的目标。在这一套技术栈下,我们能够应用在边缘网关、云服务、桌面端、嵌入式环境等各个领域。最初的构想是打造一套松耦合的底层平台,专为应用服务而生。业务架构图

业务架构

       模块化设计:我们采用插件化架构,将应用程序分解为多个独立的模块,每个模块专注于处理特定功能。这种方法有助于提高代码的可维护性和可重用性。

       可扩展性:通过支持动态加载和卸载插件的方式,应用程序可以根据需求灵活地增加或减少功能模块,而不会影响整体系统的稳定性。

        松耦合设计:插件化架构将各个模块之间的依赖关系解耦,使得这些模块能够独立开发、测试和部署。

插件服务管理:

应用服务管理

基于这一能力平台,我们成功开发了以下产品:

  1. 智慧能源综合管理平台(适用于燃气行业)
  2. 智能换电SaaS系统
  3. 动环监测系统
  4. 综合能源管理系统(涵盖水、电、气)
  5. 智慧公厕系统
  6. 环境监控系统
  7. SCADA系统
  8. WEB组态
  9. GIS系统
  10. 三维平台

这些产品在不同领域中发挥作用,为我们的客户提供了多种解决方案。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JetLinks开源物联网平台基于Java8、Spring Boot 2.x、WebFlux、Netty、Vert.x、Reactor等开发,是一个开箱即用,可二次开发的企业级物联网基础平台。平台实现了物联网相关的众多基础功能,能帮助你快速建立物联网相关业务系统。 JetLinks开源物联网平台核心特性: 支持统一物模型管理,多种设备,多种厂家,统一管理。 统一设备连接管理,多协议适配(TCP、MQTT、UDP、CoAP、HTTP等),屏蔽网络编程复杂性,灵活接入不同厂家不同协议的设备。 灵活的规则引擎,设备告警,消息通知,数据转发。可基于SQL进行复杂的数据处理逻辑。 地理位置:统一管理地理位置信息,支持区域搜索。 数据可视化:实现拖拽配置数据图表,设备组态等。 JetLinks开源物联网平台技术栈: Spring Boot 2.2.x Spring WebFlux 响应式Web支持 R2DBC 响应式关系型数据库驱动 Project Reactor 响应式编程框架 Netty、Vert.x 高性能网络编程框架 ElasticSearch 全文检索,日志,时序数据存储 PostgreSQL 业务功能数据管理 hsweb framework 4 业务功能基础框架     JetLinks开源物联网平台 更新日志: v1.9 1、增加设备独立物模型支持,可给单独的设备配置物模型. 2、基本实现GB28181国标视频设备接入,支持直播,云台控制,级联操作.(选配模块) 3、RabbitMQ增加routeKey配置,可在配置文件中指定device.message.writer.rabbitmq.consumer-route-key和device.message.writer.rabbitmq.producer-route-key.(Pro) 4、当设置了device.message.writer.rabbitmq.consumer=false时,不创建MQ消费者.(Pro) 5、设备支持独立物模型,可单独配置设备的物模型. 6、适配tdengine 2.0.16.0,优化sql长度策略. (pro) 7、优化规则引擎编辑器,实现组件模块化动态加载.(Pro) 8、修复启动服务时,如果某个产品物模型发布失败,导致后面的产品终止发布的问题. 9、增加ignoreLatest消息头,message.addHeader("ignoreLatest",true) 忽略记录最新数据到数据库. 10、修复租户下操作设备告警提示无权限.(Pro) 11、优化租户在解绑成员时,同时解绑成员的资产信息.(Pro) 12、优化子设备消息回复处理 13、物模型属性增加存储方式功能,可配置部分属性不存储. 14、增加虚拟属性功能,可通过规则来计算出虚拟属性值.(Pro) 15、增加租户成员绑定(TenantMemberBindEvent),解绑(TenantMemberUnBindEvent)事件.可通过spring-event订阅处理此事件.(Pro) 16、优化子设备状态检查,当检查子设备状态时,将会尝试发送ChildDeviceMessage<DeviceStateCheckMessage>给网关,处理后返回ChildDeviceMessageReply<DeviceStateCheckMessageReply>. 17、增加ClickHouse设备数据存储策略支持.(Pro) 18、增加权限过滤功能,可配置禁止赋予自己没有的权限给其他用户.hsweb.permission.filter相关配置 19、设备和产品的租户绑定逻辑优化: 绑定设备时,自动绑定产品.解绑产品时,自动解绑设备.(Pro) 20、用户管理增加租户权限控制.(Pro) 21、当向keepOnline的设备发送消息时,如果原始连接已断开,将返回CONNECTION_LOST错误. 22、设置keepOnline的会话将被持久化,重启服务后自动恢复.(Pro) 23、默认关闭设备最新数据存储,通过jetlinks.device.storage.enable-last-data-in-db=true开启.(Pro) 24、属性物模型增加属性值来源,配置为手动时,在发送修改属性指令(WritePropertyMessage)时,将直接生效,不会发送到设备. 25、优化租户资产解绑逻辑,当删除数据时,解绑资产全部的绑定关系.(Pro) 26、用户管理,机构管理增加租户端支持,租户可以自己管理自己的用户和机构.(Pro)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值