物联网边缘计算云边协同

文章目录

    • 一、物联网云边协同
      • 1.IoT云边协同设计
      • 2.物联网平台设计
      • 3.物联网平台实现
    • 二、部署环境
      • 1.节点配置
      • 2.版本信息
    • 三、IoT云边协同部署
      • 1.部署Kubernetes集群
      • 2.部署KubeEdge
      • 3.部署ThingsBoard集群
      • 4.部署Node-RED边缘网关
        • 4.1.边缘网关功能
        • 4.2.部署EMQX
        • 4.2.部署Node-RED
      • 5.配置边缘网关
        • 5.1.ThingsBaord创建网关
        • 5.2.Node-RED上传遥测
        • 5.3.Node-RED连接EMQX
        • 5.4.MQTTX连接EMQX
      • 6.云边协同测试
        • 6.1.测试方法
        • 6.2.上传遥测数据

  • KubeEdge
# KubeEdgehttps://iothub.org.cn/docs/kubeedge/
https://iothub.org.cn/docs/kubeedge/edge/iot/

一、物联网云边协同

1.IoT云边协同设计

物联网平台(IoT)部署在云上,网关部署在边缘节点,设备通过边缘网关接入物联网平台。

云边协同设计:

  • Kubernetes 在云端部署 IoT 平台
  • KubeEdge 在边缘节点部署网关
  • IoT 设备通过 MQTT 协议接入边缘网关

2.物联网平台设计

物联网平台选择 ThingsBoard,边缘网关选择 EMQX、Node-RED,MQTTX 工具模拟终端设备。

IoT平台设计:

  • 使用 Kubernetes 在云端部署 ThingsBoard 集群

  • 使用 KubeEdge 在边缘节点部署 EMQX、Node-Red,实现边缘网关

  • MQTTX 工具模拟终端设备,通过 MQTT 协议接入边缘网关

3.物联网平台实现

物联网平台(IoT)具体实现:

  1. 部署 Kubernetes 集群
  2. 部署 KubeEdge
  3. 部署 ThingsBoard 集群
  4. 部署 EMQX、Node-RED 边缘网关
  5. 配置 Node-RED、MQTTX
  6. 测试 IoT 设备向 ThingsBoard 发送遥测数据

二、部署环境

1.节点配置

主机名IP地址角色
k8s-master192.168.202.201master
k8s-node1192.168.202.202node
k8s-node2192.168.202.203node
edge-1192.168.202.211edge

在这里插入图片描述

2.版本信息

信息版本备注
K8sv1.23.12
centos7.8# cat /etc/redhat-release
KubeEdgev1.13.4
ThingsBoardv3.5.1
EMQX4.4.17
Node-REDlatest

三、IoT云边协同部署

1.部署Kubernetes集群

部署 Kubernetes 集群参考

# 部署 Kubernetes 集群https://iothub.org.cn/docs/kubernetes/pro/deploy-kubernetes/
[root@k8s-master ~]# kubectl get nodes
NAME         STATUS   ROLES                  AGE    VERSION
k8s-master   Ready    control-plane,master   27d    v1.23.12
k8s-node1    Ready    <none>                 27d    v1.23.12
k8s-node2    Ready    <none>                 10d    v1.23.12

在这里插入图片描述

2.部署KubeEdge

部署 KubeEdge 参考

# 部署 KubeEdgehttps://iothub.org.cn/docs/kubeedge/deploy/deploy/
[root@k8s-master ~]# kubectl get nodes
NAME         STATUS   ROLES                  AGE    VERSION
edge-1       Ready    agent,edge             4d4h   v1.23.17-kubeedge-v1.13.4
k8s-master   Ready    control-plane,master   27d    v1.23.12
k8s-node1    Ready    <none>                 27d    v1.23.12
k8s-node2    Ready    <none>                 10d    v1.23.12[root@k8s-master ~]# kubectl get all -n kubeedge
NAME                               READY   STATUS    RESTARTS        AGE
pod/cloud-iptables-manager-592m5   1/1     Running   3 (3d22h ago)   4d5h
pod/cloud-iptables-manager-pg4pl   1/1     Running   3 (3d22h ago)   4d5h
pod/cloudcore-5959c5986f-8hsc4     1/1     Running   3 (3d22h ago)   4d5hNAME                TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)                                                                           AGE
service/cloudcore   NodePort   10.110.71.216   <none>        10000:30976/TCP,10001:31372/TCP,10002:31922/TCP,10003:30163/TCP,10004:31927/TCP   4d5hNAME                                    DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR   AGE
daemonset.apps/cloud-iptables-manager   2         2         2       2            2           <none>          4d5hNAME                        READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/cloudcore   1/1     1            1           4d5hNAME                                   DESIRED   CURRENT   READY   AGE
replicaset.apps/cloudcore-5959c5986f   1         1         1       4d5h

在这里插入图片描述
在这里插入图片描述

3.部署ThingsBoard集群

部署 ThingsBoard 参考

# ThingsBoard 单机部署
https://iothub.org.cn/docs/iot/deploy/deploy-single/# ThingsBoard 集群部署
https://iothub.org.cn/docs/iot/deploy/deploy-cluster/

备注:考虑测试环境资源有限,部署单机代替ThingsBoard集群
在这里插入图片描述
在这里插入图片描述

4.部署Node-RED边缘网关

4.1.边缘网关功能
  1. 边缘网关使用 EMQX、Node-RED 实现 MQTT-Broker 功能
  2. 边缘网关通过 Node-RED 与 ThingsBoard 平台通信
  3. IoT 设备通过 MQTT 协议与边缘网关 EMQX 通信
4.2.部署EMQX

gateway-emqx.yaml

[root@k8s-master kubeedge]# vim gateway-emqx.yaml apiVersion: apps/v1
kind: Deployment
metadata:name: gateway-emqx
spec:replicas: 1selector:matchLabels:app: emqxtemplate:metadata:labels:app: emqxspec:nodeName: edge-1    #调度到指定机器containers:- name: emqximage: emqx/emqx:4.4.17ports:- containerPort: 1883hostPort: 1884- containerPort: 18083hostPort: 18084- containerPort: 8081hostPort: 8082- containerPort: 8083hostPort: 8085- containerPort: 8883hostPort: 8884- containerPort: 8084hostPort: 8086
[root@k8s-master iot]# kubectl apply -f gateway-emqx.yaml 
deployment.apps/gateway-emqx created[root@k8s-master iot]# kubectl get all
NAME                                READY   STATUS    RESTARTS   AGE
pod/gateway-emqx-6fcb56cb4f-n8z5s   1/1     Running   0          12sNAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   27dNAME                           READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/gateway-emqx   1/1     1            1           12sNAME                                      DESIRED   CURRENT   READY   AGE
replicaset.apps/gateway-emqx-6fcb56cb4f   1         1         1       12s

在这里插入图片描述

访问EMQX

# 访问地址http://192.168.202.211:18084
账号:admin
初始密码:public
修改密码:1qaz2wsx

在这里插入图片描述

# 参考$ docker run -d --name emqx -p 18083:18083 -p 1883:1883 emqx/emqx:latest$ docker run -d --name emqx -p 1883:1883 -p 8081:8081 -p 8083:8083 -p 8883:8883 -p 8084:8084 -p 18083:18083 emqx/emqx:v4.0.0
4.2.部署Node-RED

gateway-node-red.yaml

[root@k8s-master kubeedge]# vim gateway-node-red.yaml apiVersion: apps/v1
kind: Deployment
metadata:name: gateway-node-red
spec:replicas: 1selector:matchLabels:app: noderedtemplate:metadata:labels:app: noderedspec:nodeName: edge-1    #调度到指定机器hostNetwork: true   # 使用主机网络containers:- name: noderedimage: nodered/node-red:latest

部署 Node-RED 到边缘节点

[root@k8s-master iot]# kubectl apply -f gateway-node-red.yaml 
deployment.apps/gateway-node-red created[root@k8s-master iot]# kubectl get all
NAME                           READY   STATUS    RESTARTS   AGE
pod/gateway-5847c4f88c-bqx5j   1/1     Running   0          30sNAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   27dNAME                      READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/gateway   1/1     1            1           31sNAME                                 DESIRED   CURRENT   READY   AGE
replicaset.apps/gateway-5847c4f88c   1         1         1       30s

在这里插入图片描述

访问 Node-RED

# 访问地址http://192.168.202.211:1880

在这里插入图片描述

# 参考# docker run --network host --restart=always -v node_red_data:/data --name nodered nodered/node-red:latest

5.配置边缘网关

5.1.ThingsBaord创建网关

在这里插入图片描述
在这里插入图片描述

5.2.Node-RED上传遥测

将设备遥测发布到ThingsBoard服务器节点,请向以下主题发送publish消息:

Topic: v1/gateway/telemetry

Message:

{"Device A": [{"ts": 1483228800000,"values": {"temperature": 42,"humidity": 80}},{"ts": 1483228801000,"values": {"temperature": 43,"humidity": 82}}],"Device B": [{"ts": 1483228800000,"values": {"temperature": 42,"humidity": 80}}]
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.3.Node-RED连接EMQX

Node-RED 连接 EMQX,接收 IoT 设备遥测数据

Topic: v1/gateway/telemetry

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5.4.MQTTX连接EMQX

在这里插入图片描述
在这里插入图片描述

6.云边协同测试

6.1.测试方法
  1. 使用 MQTTX 工具模拟物联网设备,向 EMQX 发送遥测数据
  2. Node-RED 通过 EMQX 订阅遥测数据
  3. Node-RED 把遥测数据上传到 ThingsBoard
6.2.上传遥测数据
  • 通过 MQTTX 工具 上传遥测数据
v1/gateway/telemetry{"Device A": [{"ts": 1483228800000,"values": {"temperature": 42,"humidity": 80}},{"ts": 1483228801000,"values": {"temperature": 43,"humidity": 82}}],"Device B": [{"ts": 1483228800000,"values": {"temperature": 42,"humidity": 80}}]
}

在这里插入图片描述

  • ThingsBoard
    在这里插入图片描述
    在这里插入图片描述

  • Node-RED
    在这里插入图片描述

  • KubeEdge

# KubeEdgehttps://iothub.org.cn/docs/kubeedge/
https://iothub.org.cn/docs/kubeedge/edge/iot/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/710315.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(正规api接口代发布权限)短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态

短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态源头开发&#xff08;本篇禁止抄袭复刻&#xff09; 一、短视频矩阵系统开发者架构 云罗短视频矩阵系统saas化系统&#xff0c;开发层将在CAP原则基础上使用分布式架构,对此网站的整体架构采用了基于B/S三层架构模式…

React 模态框的设计(五)主体设计

弹窗的主体设计没什么特别&#xff0c;就是把细分化后的各个功能封装在一个个的小组件内&#xff0c;然后再整合。这样逻辑就分开了&#xff0c;不乱。 弹窗容器 这个容器是弹窗主体的根组件(不含遮罩)&#xff0c;要能根据主题的变化能做出相应的改变。还要记录渲染后的主体…

java016学习记录

Java Web 使用 Java 开发语言完成 Web 后端的项目开发 基于 Web 的应用&#xff1a;网站、APP、小程序 Java 不是做前端的&#xff0c;做后端 Tomcat、Servlet Tomcat 的作用让 Java Web 程序可以正常运行&#xff0c;被浏览器访问 浏览器默认不能访问电脑上的资源&#…

Django Web架构:全面掌握Django模型字段(下)

Django Web架构 全面掌握Django模型字段&#xff08;下&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article…

C++之vector

1、vector概念 功能&#xff1a;vector的功能和数组非常相似&#xff0c;可以看成是一个升级版的数组。 vector和普通数组的区别&#xff1a; &#xff08;1&#xff09;数组是静态的&#xff0c;长度不可改变&#xff0c;而vector可以动态扩展&#xff0c;增加长度。…

协议和序列化反序列化

“协议”和序列化反序列化 “协议”的概念&#xff1a; “协议”本身是一种约定俗成的东西&#xff0c;由通讯双方必须共同遵从的一组约定&#xff0c;因此我们一定要将这种约定用计算机语言表达出来&#xff0c;此时双方计算机才能识别约定的相关内容 我们把这个规矩叫做“…

机器学习|决策树

左图的点是一种线性不可分的情况&#xff0c;无法拿一条直线去将进行分开。 每一个节点都代表一个决策&#xff0c;从而导致节点的分流。 最终的目标肯定是要达到分类。 但取得目标的过程是有所谓的好坏。 而这个好坏用熵/信息增益来衡量。 熵是一种用于反映系统混乱程度的物理…

思科网络设备监控

思科是 IT 行业的先驱之一&#xff0c;提供从交换机到刀片服务器的各种设备&#xff0c;以满足中小企业和企业的各种 IT 管理需求。管理充满思科的 IT 车间涉及许多管理挑战&#xff0c;例如监控可用性和性能、管理配置更改、存档防火墙日志、排除带宽问题等等&#xff0c;这需…

Makefile从入门到项目编译实战(学习笔记)

1.make和makefile介绍 1. make make 是一个应用程序&#xff0c;位于 /usr/bin/make 目录下&#xff0c;make 有如下的功能&#xff1a; &#xff08;1&#xff09;解析源程序之间的依赖关系 &#xff08;2&#xff09;根据依赖关系自动维护编译工作 &#xff08;3&#xff09…

Jmeter插件PerfMon Metrics Collector安装使用及报错解决

Jmeter作为一个轻量级的性能测试工具&#xff0c;开源、小巧、灵活的特性使其越来越受到测试人员喜爱。在实际的项目中&#xff0c;特别是跨地区项目&#xff0c;排除合作方指定要求使用Loadrunner作为性能测试工具外&#xff0c;Jmeter会是首选。 本篇文章&#xff0c;就着重…

Python 全栈系列226 GlobalBuffer

说明 为了简化开发程序&#xff0c;特别是需要依赖全局数据的程序&#xff0c;例如&#xff1a;分布式任务需要知道当前可处理的任务&#xff1b;定时程序需要依据某个约束性全局变量。一个附带的好处是会大量减少对数据库产生的请求。 GlobalBuffer的代价并不高&#xff1a;…

基于C++的http通信记录,使用httplib,Windows环境,vscode,mingw

使用了 httplib库&#xff0c;链接&#xff0c;使用该库只需要包含头文件即可&#xff0c;另外在Windows环境下&#xff0c;使用mingw构建项目&#xff0c;需要在编译时链接网络编程库&#xff0c;task.json如下&#xff1a; {"version": "2.0.0","t…

【MATLAB源码-第149期】基于MATLAB的2ASK,2FSK,2PSK,2DPSK等相干解调仿真,输出各节点波形。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 2ASK&#xff08;二进制幅移键控&#xff09;、2FSK&#xff08;二进制频移键控&#xff09;、2PSK&#xff08;二进制相移键控&#xff09;和2DPSK&#xff08;二进制差分相移键控&#xff09;是数字调制技术中的基本调制方…

汽车三元催化器的废品项目详解,三元催化再生项目的回收技术教学

一、教程描述 这是一个收废品项目&#xff0c;就收那些别人不懂的&#xff0c;三元催化器的附加值高&#xff0c;只要掌握技术&#xff0c;怎么玩都行的&#xff0c;只是要放得下你的面子。三元催化器&#xff0c;是安装在汽车排气系统中最重要的机外净化装置&#xff0c;它可…

MATLAB环境基于全局和局部多特征融合的红外图像分割主动轮廓模型

红外图像是一种热图像&#xff0c;不受光照影响&#xff0c;在光照条件差、有烟雾遮挡的环境中&#xff0c;可以辅助或代替可见光成像在各个领域中应用&#xff0c;同时作为热成像&#xff0c;对景物的热辐射敏感&#xff0c;在安全监测、质量检验等领域具有优势。在以下几个方…

Apache Doris Sink Connector部署指南

在当今数据驱动的时代&#xff0c;如何高效、准确地处理和分析大数据成为了各行各业面临的共同挑战。Apache Doris&#xff0c;作为一个基于 MPP 架构的高性能、实时的分析型数据库&#xff0c;为大规模数据分析提供了强大的支持。 在当今数据驱动的时代&#xff0c;如何高效、…

CSS的弹性布局

CSS 的弹性布局 前言 前端中为了实现页面的布局效果&#xff0c;采用的一个技术手段&#xff0c;它在前端开发的技术场景是非常广泛的 实现上述区域的页面相关的布局效果&#xff0c;就可以使用弹性布局来完成 弹性布局(flex布局) flex 是 flexible box 的缩写&#xff0c;…

MongoDB聚合运算符:$cos

文章目录 语法使用举例余弦值角度余弦值弧度 $cos聚合运算符用来计算余弦值&#xff0c;返回指定表达式的余弦值。 语法 { $cos: <expression> }<expression>为可被解析为数值的表达式$cos返回弧度&#xff0c;使用$radiansToDegrees运算符可以把弧度转换为角度$…

现代企业架构框架——应用架构

现代企业架构框架——应用架构。 现代企业架构中的应用架构是指企业在构建和维护应用系统时所采用的一种架构框架。应用架构旨在实现应用系统的可扩展性、灵活性、可维护性和可重用性,以满足企业在数字化时代对应用系统的快速交付和持续创新的需求。下面将详细介绍应用架构的…

文生视频基础1:sora技术报告学习

sora技术报告学习 背景学后理解训练流程技术拆解编码解码扩散模型训练用数据 28号直播交流会后的一些想法自身的一点点想法 参考 原文地址&#xff1a;Video generation models as world simulators 背景 此项目的背景是基于Datawhale的关于sora技术文档的拆解和相关技术讲解…