物联网云原生云边协同

三、物联网平台部署

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 参考

# 部署 KubeEdge

https://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)   4d5h

NAME                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   4d5h

NAME                                    DESIRED   CURRENT   READY   UP-TO-DATE   AVAILABLE   NODE SELECTOR   AGE
daemonset.apps/cloud-iptables-manager   2         2         2       2            2           <none>          4d5h

NAME                        READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/cloudcore   1/1     1            1           4d5h

NAME                                   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.部署 ThingsBoard Edge
4.1.创建 Edge 实例

在 ThingsBoard 服务端上配置 Edge
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# ThingsBoard 服务器地址
82.157.166.86

# 边缘键
1d2952e8-227e-b019-7eab-d29664b605c1

# 边缘密钥
iihb0i793etbqct62gpf

4.2.部署 PostgreSQL

postgresql.yaml

[root@k8s-master kubeedge]# vim postgresql.yaml 

apiVersion: apps/v1
kind: Deployment
metadata:
  name: postgresql
spec:
  replicas: 1
  selector:
    matchLabels:
      app: postgresql
  template:
    metadata:
      labels:
        app: postgresql
    spec:
      nodeName: edge-1    #调度到指定机器
      hostNetwork: true   # 使用主机网络
      containers:
      - name: postgresql
        image: postgres:12
        env:
          - name: LANG
            value: "C.UTF-8"
          - name: TZ
            value: "Asia/Shanghai"      
          - name: POSTGRES_DB
            value: "postgres"
          - name: POSTGRES_USER
            value: "postgres"
          - name: POSTGRES_PASSWORD
            value: "postgres"

[root@k8s-master thingsboard]# kubectl apply -f postgresql.yaml 
deployment.apps/postgresql created


[root@k8s-master thingsboard]# kubectl get all
NAME                              READY   STATUS    RESTARTS   AGE
pod/postgresql-867f894fd4-tthq8   1/1     Running   0          31s

NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   84d

NAME                         READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/postgresql   1/1     1            1           31s

NAME                                    DESIRED   CURRENT   READY   AGE
replicaset.apps/postgresql-867f894fd4   1         1         1       31s

在这里插入图片描述

访问PostgreSQL

# 访问地址

192.168.202.211
5432
postgres/postgres

在这里插入图片描述

4.3.创建数据库

在边缘节点创建数据库 tb-edge
在这里插入图片描述

4.4.部署 ThingsBoard Edge

tb-edge.yaml

[root@k8s-master kubeedge]# vim tb-edge.yaml 

apiVersion: apps/v1
kind: Deployment
metadata:
  name: tb-edge
spec:
  replicas: 1
  selector:
    matchLabels:
      app: tb-edge
  template:
    metadata:
      labels:
        app: tb-edge
    spec:
      nodeName: edge-1    #调度到指定机器
      containers:
      - name: tb-edge
        image: thingsboard/tb-edge:3.5.1EDGE
        ports:
        - containerPort: 1883
          hostPort: 11883
        - containerPort: 8080
          hostPort: 18080
        env:
          - name: SPRING_DATASOURCE_URL
            value: "jdbc:postgresql://192.168.202.211:5432/tb-edge"          
          - name: SPRING_DATASOURCE_USERNAME
            value: "postgres"
          - name: SPRING_DATASOURCE_PASSWORD
            value: "postgres"
          - name: CLOUD_ROUTING_KEY
            value: "1d2952e8-227e-b019-7eab-d29664b605c1"     
          - name: CLOUD_ROUTING_SECRET
            value: "iihb0i793etbqct62gpf"     
          - name: CLOUD_RPC_HOST
            value: "82.157.166.86"
          - name: CLOUD_RPC_PORT
            value: "7070"
          - name: CLOUD_RPC_SSL_ENABLED
            value: "false"

[root@k8s-master thingsboard]# kubectl apply -f tb-edge.yaml 
deployment.apps/tb-edge created


[root@k8s-master thingsboard]# kubectl get all
NAME                              READY   STATUS    RESTARTS   AGE
pod/postgresql-867f894fd4-tthq8   1/1     Running   0          14m
pod/tb-edge-67f4b7c8-xbpjg        1/1     Running   0          2m34s

NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   84d

NAME                         READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/postgresql   1/1     1            1           14m
deployment.apps/tb-edge      1/1     1            1           2m34s

NAME                                    DESIRED   CURRENT   READY   AGE
replicaset.apps/postgresql-867f894fd4   1         1         1       14m
replicaset.apps/tb-edge-67f4b7c8        1         1         1       2m34s

在这里插入图片描述

访问 ThingsBoard Edge

# 访问地址

http://192.168.202.211:18080/login
tenant@thingsboard.org
tenant

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

# 参考
docker run -d --network host --name tb-edge --restart=always \
-e "SPRING\_DATASOURCE\_URL=jdbc:postgresql://192.168.202.166:5432/tb-edge" \
-e "SPRING\_DATASOURCE\_USERNAME=postgres" \
-e "SPRING\_DATASOURCE\_PASSWORD=postgres" \
-e "CLOUD\_ROUTING\_KEY=672b5ad6-cf07-c8af-e7cf-ac8a85114902" \
-e "CLOUD\_ROUTING\_SECRET=tuhk87tqb4l1463revxf" \
-e "CLOUD\_RPC\_HOST=82.157.166.86" \
-e "CLOUD\_RPC\_PORT=7070" \
-e "CLOUD\_RPC\_SSL\_ENABLED=false" \
-v ~/.mytb-edge-data:/data \
-v ~/.mytb-edge-logs:/var/log/tb-edge \
thingsboard/tb-edge:3.5.1EDGE

四、物联网设备接入

1.创建设备

在 Edge 端创建设备 iot-device
在这里插入图片描述
在这里插入图片描述

在服务端查看设备
在这里插入图片描述

# 访问令牌
1ThJ4grl3mXxxw7egHNo

2.MQTTX 工具
192.168.202.211
11883
1ThJ4grl3mXxxw7egHNo

在这里插入图片描述

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

1715760317863)]

[外链图片转存中…(img-CYReZswa-1715760317864)]

[外链图片转存中…(img-OOixOHrg-1715760317864)]

[外链图片转存中…(img-0D088WnN-1715760317865)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值