如何在树莓派上通过K3S部署EMQ X edge集群

发布时间:2021-11-20 10:02:11 作者:小新
来源:亿速云 阅读:140

这篇文章给大家分享的是有关如何在树莓派上通过K3S部署EMQ X edge集群的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

环境

k3s需要raspberrypi可以正常访问google,如果没有条件的话推荐在AWS上尝试部署。

HostnameIP角色硬件
raspberrypi192.168.1.99server树莓派3
emqx1192.168.1.100agent树莓派3
emqx2192.168.1.101agent树莓派3

准备

在树莓派上部署k3s集群

1.下载k3s,k3s支持x86_64,armhf和arm64,树莓派上应该安装armhf

$ wget https://github.com/rancher/k3s/releases/download/v0.2.0/k3s-armhf
$ mv k3s-armhf /usr/local/bin/k3s
$ chmod +x /usr/local/bin/k3s

2.启动Server

$ sudo k3s server

3.加入集群

a.在Server节点上查看 /var/lib/rancher/k3s/server/node-token 获取node token

$ NODE_TOKEN=$(sudo cat /var/lib/rancher/k3s/server/node-token)

b.在agent节点上执行 sudo k3s agent --server https://192.168.1.99:6443 --token ${NODE_TOKEN} 加入k3s集群。

4.(可选)外部设备使用 kubectl 管理 k3s集群

a.选取任意能与集群通信并安装了kubectl 的外部设备

b.拷贝/etc/rancher/k3s/k3s.yaml文件到外部设备的 ~/.kube/config

c.修改 ~/.kube/config, 将 https://localhost:6443 替换为https://192.168.1.99:6443

d.使用 kubectl 管理集群

$ kubectl get nodes
NAME         STATUS  ROLES  AGE  VERSION
emqx2        Ready   <none>  29m  v1.13.4-k3s.1
emqx1         Ready   <none>  29m  v1.13.4-k3s.1
raspberrypi Ready   <none>  31m   v1.13.4-k3s.1

安装HELM

安装helm客户端
安装 Tiller 服务器

创建一个名为 tiller 的 Service Account

$ kubectl create serviceaccount tiller --namespace kube-system

授予名为 tiller 的 Service Account 集群管理员角色 cluster-admin:

$ cat <<EOF >rbac-config.yaml
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
name: tiller
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: cluster-admin
subjects:
- kind: ServiceAccount
name: tiller
namespace: kube-system
EOF
$ kubectl create -f rbac-config.yaml

安装 Tiller 服务器

$ helm init --service-account tiller
验证安装

在安装完成后,可以通过执行如下命令来检查是安装成功:

$ helm version

如果正确显示 Helm 客户端和 Tiller 服务器的版本,这表示安装成功。

或者通过执行 kubectl 的如下命令来查看是否已正常按照 Tiller 服务器:

$ kubectl get pods -n kube-system

部署EMQX集群

1.通过Helm部署EMQX

$ git clone https://github.com/emqx/emqx-chart $ cd emqx-chart $ helm install --name myemqx --set deployment.image="emqx/emqx-edge:latest" .

关于此仓库更多的设置,请查看README

2.查看EMQX的集群状态

a.查看pods列表

$ kubectl get pods |grep myemqx myemqx-emqx-chart-54974fc5f5-v8chq           1/1     Running   0          2m9s myemqx-emqx-chart-54974fc5f5-zz9gc           1/1     Running   0          2m9s

b.使用emqx_ctl cluster status查看集群状态

$ kubectl exec myemqx-emqx-chart-54974fc5f5-v8chq /opt/emqx/bin/emqx_ctl cluster status Cluster status: [{running_nodes,['emqx@10.42.2.11','emqx@10.42.1.15']}]

感谢各位的阅读!关于“如何在树莓派上通过K3S部署EMQ X edge集群”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

推荐阅读:
  1. k3s高可用部署
  2. EMQ X Cloud - MQTT 5.0 公有云服务正式发布

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

树莓派 k3s

上一篇:如何通过串口连接树莓派4B

下一篇:树莓派如何安装selenium和iceweasel

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》