三、物联网平台部署
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年嵌入式&物联网开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!
1715760317863)]
[外链图片转存中…(img-CYReZswa-1715760317864)]
[外链图片转存中…(img-OOixOHrg-1715760317864)]
[外链图片转存中…(img-0D088WnN-1715760317865)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上嵌入式&物联网开发知识点,真正体系化!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新!!