云进入以「利用为核心」的云原生阶段,Operator 模式的呈现,则为 Kubernetes 中的自动化工作创立配置与治理提供了一套卓有成效的标准规范。通过将运维常识固化成高级语言 Go/Java 代码,使得运维常识能够像一般软件一样交付,并能反对高牢靠、具备高级运维能力的有状态利用批量交付。

针对大规模分布式物联网 MQTT 音讯服务器 EMQX 全生命期治理的自动化管理工具 EMQX Kubernetes Operator(本文中简称 EMQX Operator)应运而生。它作为 Kubernetes 上的自定义控制器运行,并与 Kubernetes API 服务器(kube-apiserver)进行通信,将高层形容转换为失常的 Kubernetes 资源,以放弃所需的应用程序状态。

EMQX Operator 使 EMQX 的部署、调优和运维变成一种低成本、标准化、可重复性的能力,帮忙用户高效实现集群扩容、无缝降级、故障解决和对立监控。

本文章将以 EMQX 企业版为例,具体解说如何应用 EMQX Operator 在华为云 CCE 私有云平台上创立部署 MQTT 服务集群,并实现自动化治理与监控。

云平台简介:华为云 CCE

云容器引擎(Cloud Container Engine,简称CCE)提供高度可扩大的、高性能的企业级 Kubernetes 集群,反对运行 Docker 容器。借助云容器引擎,您能够在华为云上轻松部署、治理和扩大容器化应用程序,详见:成长地图_云容器引擎 CCE_华为云

创立 CCE 集群

购买 CCE 集群

登录华为云 CCE控制台,购买“Turbo 集群”或者“CCE 集群”,EMQX Operator 要求Kubernetes 版本>=1.20.0 ,因而咱们在此抉择 Kubernetes 1.21,网络与其余资源信息依据本身需要来制订。

创立节点池(间接增加节点也能够)

这里增加的节点必须能够拜访外网(能够通过加 NAT 网关解决)

节点装置的操作系统倡议是 Ubuntu,否则有可能会短少必要的库(socat)

拜访 Kubernetes 集群

点击 Cloud Shell

详情参考:通过 kubectl 连贯集群_云容器引擎 CCE_用户指南_集群治理_旧版UI_拜访集群_华为云

StorageClass 配置

查看以后的 StroageClass

kubectl get sc

这里咱们用 csi-disk。

应用 EMQX Operator 部署 EMQX 集群

部署 cert-manager

参考 cert-manager 装置文档:https://cert-manager.io/docs/...

部署 EMQX Operator

kubectl apply -f "https://github.com/emqx/emqx-operator/releases/download/1.2.6/emqx-operator-controller.yaml"

部署 EMQX 企业版集群

这里 service type 采纳 LoadBalancer

cat << "EOF" | kubectl apply -f -apiVersion: apps.emqx.io/v1beta3kind: EmqxEnterprisemetadata:  name: emqx-ee  labels:    "foo": "bar"spec:  persistent:    storageClassName: csi-disk    resources:      requests:        storage: 1Gi    accessModes:    - ReadWriteOnce  emqxTemplate:    image: emqx/emqx-ee:4.4.6    serviceTemplate:      metadata:        annotations:          kubernetes.io/elb.pass-through: "true"          kubernetes.io/elb.class: union          kubernetes.io/elb.autocreate:              '{                "type": "public",                "name": "emqx",                "bandwidth_name": "cce-emqx",                "bandwidth_chargemode": "bandwidth",                "bandwidth_size": 5,                "bandwidth_sharetype": "PER",                "eip_type": "5_bgp"              }'      spec:        type: LoadBalancerEOF

Load Balancer参数阐明

  • bandwidth_chargemode

    带宽付费模式。 bandwidth:按带宽计费 traffic:按流量计费 默认类型:bandwidth
  • bandwidth_size

    带宽大小,默认 1Mbit/s~2000Mbit/s,请依据 Region 带宽反对范畴设置。
  • bandwidth_sharetype

    带宽共享形式。 PER:独享带宽
  • eip_type

    弹性公网IP类型 5_telcom:电信 5_union:联通 5_bgp:全动静BGP 5_sbgp:动态BGP

查看集群状态

$ kubectl get pods  NAME              READY   STATUS    RESTARTS   AGE  emqx-ee-0   2/2     Running   0          22m  emqx-ee-1   2/2     Running   0          22m  emqx-ee-2   2/2     Running   0          22m  $ kubectl exec -it emqx-ee-0 -c emqx -- emqx_ctl status  Node '[email protected]' 4.4.7 is started  $ kubectl exec -it emqx-ee-0 -c emqx -- emqx_ctl cluster status  Cluster status: #{running_nodes =>                   ['[email protected]',                    '[email protected]',                    '[email protected]'],               stopped_nodes => []}

对于 LoadBalancer 终结 TLS

结语

至此,咱们实现了在华为云 CCE 上部署 EMQX 集群的全副流程。EMQX Operator 能够帮忙用户在 Kubernetes 环境上疾速创立和治理 EMQX 集群,不仅极大简化部署和治理流程,也升高了治理和配置的专业技能要求,是用户疾速体验云原生的最佳抉择。

版权申明: 本文为 EMQ 原创,转载请注明出处。

原文链接:https://www.emqx.com/zh/blog/category/emqx