热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用EMQX与Shifu实现设备联动

使用EMQX与Shifu实现设备联动-EMQX是一个在世界范围内非常受欢迎的MQTTBroker。它拥有基于Kubernetes的云原生架构,使得自身能力极为适合当今越来越复杂的物

EMQX是一个在世界范围内非常受欢迎的MQTT Broker。它拥有基于Kubernetes的云原生架构,使得自身能力极为适合当今越来越复杂的物联网场景,让设备消息的传输更为高效。因此,Shifu作为Kubernetes原生的Shifu框架,可以与EMQX完美结合,为EMQX提供智能的多协议设备联动的能力。

下面就让我们看一下EMQX是如何与Shifu一起让设备直接更方便地联动吧。

简介

本文将介绍如何在集群内部署EMQX和Shifu,接入一个以MQTT为通信方式的温度计和一个以RTSP为传输协议的海康威视摄像头,并加入一个应用与Shifu进行交互,使得每次温度计检测到超过37度的体温就会让摄像头拍下一张当前照片。

本文使用的简单架构如下

准备

本文使用了如下服务和工具:

  1. Kubernetes: 1.20.10
  2. kubectl, kubeadm, kubelet: 1.20.10
  3. golang: 1.16.10
  4. docker: 19.03.9
  5. EMQX: 4.1-rc1

步骤

第一步:部署Kubernetes

本步可以参考Kubernetes的官方教程进行部署:
https://kubernetes.io/docs/se...

在部署完成后我们应当看到终端打印出如下信息:

第二步:部署Shifu

注:Shifu尚未开源,请联系Shifu团队获取repo权限

将Shifu的GitHub repo克隆到本地

git clone https://github.com/Edgenesis/shifu.git

然后可以通过下列命令部署Shifu:

kubectl apply -f shifu/k8s/crd/install/shifu_install.yml

部署完成后我们应当看到Shifu的CRD controller已经完成部署:

第三步:部署EMQX

首先需要安装EMQX Operator Controller:

$ curl -f -L "https://github.com/emqx/emqx-operator/releases/download/1.1.6/emqx-operator-controller.yaml" | kubectl apply -f -

接着我们写一个最简单的deployment.yaml:

然后就可以部署一个EMQX了:

kubectl apply –f deployment.yaml

第四步:接入设备

对于温度计,我们只需要调整它的MQTT设置,让其可以向EMQX发布MQTT信息即可。

(如果是集群外的温度计,我们可以通过Kubernetes Service来开放External IP供访问)

对于摄像头,Shifu的repo已经包括一个使用RTSP的海康威视摄像头的配置文件,我们可以轻松更改配置文件中的IP、用户名、密码,将它接入Shifu:

https://github.com/Edgenesis/shifu/tree/main/examples/rtspDeviceShifu/


至此,我们的设备已经连接完毕,下面就可以开始联动了。

最后一步:联动应用

我们简单写一个python应用,用来实现下面的逻辑:

该应用向EMQX订阅temperature-shifu-mqtt的消息,每次消息都只包括一个表示当前温度的数字;如果当前温度大于37度,则操作摄像头拍摄一张照片并保存在本地。

以下是应用代码:

加个capture function封装所有摄像头的动作。接着我们就可以将其部署到集群中,开始监视了:

python3 app.py 10.244.0.33

总结

本文描述了如何让EMQX为Shifu赋予更高效的MQTT Broker能力,同时让Shifu与MQTT合作为设备提供联动能力。在现实的应用场景之中,我们可以使用一个仅需一百余元的的红外温度计+摄像头组合,来代替数千元且表现并不稳定的测温摄像头,在大规模部署的情况下节省巨额成本。

非常感谢您看到了这里,我们期待您的反馈,如果觉得文章写得不错或者有任何建议请毫不犹豫地留言。

本文由博客群发一文多发等运营工具平台 OpenWrite 发布

推荐阅读
  • 利用GitHub热门资源,成功斩获阿里、京东、腾讯三巨头Offer
    Spring框架作为Java生态系统中的重要组成部分,因其强大的功能和灵活的扩展性,被广泛应用于各种规模的企业级应用开发中。本文将通过一份在GitHub上获得极高评价的Spring全家桶文档,探讨如何掌握Spring框架及其相关技术,助力职业发展。 ... [详细]
  • MQTT协议:轻量级消息传输的基石
    MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是一种基于发布/订阅模式的轻量级通信协议,适用于低带宽、高延迟或不可靠的网络环境。该协议基于TCP/IP构建,由IBM在1999年首次推出,旨在通过最小化网络流量和代码量,为远程设备提供高效、可靠的消息传输服务。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • NFS(Network File System)即网络文件系统,是一种分布式文件系统协议,主要用于Unix和类Unix系统之间的文件共享。本文详细介绍NFS的配置文件/etc/exports和相关服务配置,帮助读者理解如何在Linux环境中配置NFS客户端。 ... [详细]
  • 本文探讨了随着并发需求的增长,MySQL数据库架构如何从简单的单一实例发展到复杂的分布式系统,以及每一步演进背后的原理和技术解决方案。 ... [详细]
  • 本文详细探讨了 Java 中 Daemon 线程的特点及其应用场景,并深入分析了 Random 类的源代码,帮助开发者更好地理解和使用这些核心组件。 ... [详细]
  • 在CentOS 7上部署WebRTC网关Janus
    在CentOS 7上部署WebRTC网关Janus ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
author-avatar
Becky30712701
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有