k8s部署rabbitmq集群

本文档详细介绍了如何在Kubernetes环境中创建RabbitMQ集群,包括创建持久卷声明(PVC)、配置映射(ConfigMap)、服务账户(SA)、StatefulSet以启动Pod,以及进行访问测试。配置文件包括了RabbitMQ的配置参数,如插件、默认用户和密码、集群设置等。通过这种方式,可以在Kubernetes中实现高可用的RabbitMQ服务。
摘要由CSDN通过智能技术生成

目录

1.创建pv/pvc

2.创建configmap

3.创建sa

4.statefulset创建pod

5.访问测试


[root@master1 k8s-rabbitmq-cluster]# tree .
.
├── rabbitmq-config.yaml
├── rabbitmq-pvc.yaml
├── rabbitmq-rabac.yaml
├── rabbitmq-service.yaml
└── rabbitmq-sts-cluster.yaml

0 directories, 5 files

1.创建pv/pvc

sc自行创建,我这里使用的是local pv,用其他如nfs也行。

vim rabbitmq-pvc.yaml

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: rabbitmq-pv-claim
  namespace: rabbitmq
spec:
  storageClassName: local-path
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 2Gi

2.创建configmap

vim rabbitmq-config.yaml

kind: ConfigMap
apiVersion: v1
metadata:
  name: rabbitmq-cluster-config
  namespace: rabbitmq
  labels:
    addonmanager.kubernetes.io/mode: Reconcile
data:
    enabled_plugins: |
      [rabbitmq_management,rabbitmq_peer_discovery_k8s].
    rabbitmq.conf: |
      default_user = admin
      default_pass = 123456
      ## Cluster formation. See https://www.rabbitmq.com/cluster-formation.html to learn more.
      cluster_formation.peer_discovery_backend = rabbit_peer_discovery_k8s
      cluster_formation.k8s.host = kubernetes.default.svc.cluster.local
      ## Should RabbitMQ node name be computed from the pod's hostname or IP address?
      ## IP addresses are not stable, so using [stable] hostnames is recommended when possible.
      ## Set to "hostname" to use pod hostnames.
      ## When this value is changed, so should the variable used to set the RABBITMQ_NODENAME
      ## environment variable.
      cluster_formation.k8s.address_type = hostname
      ## How often should node cleanup checks run?
      cluster_formation.node_cleanup.interval = 30
      ## Set to false if automatic removal of unknown/absent nodes
      ## is desired. This can be dangerous, see
      ##  * https://www.rabbitmq.com/cluster-formation.html#node-health-checks-and-cleanup
      ##  * https://groups.google.com/forum/#!msg/rabbitmq-users/wuOfzEywHXo/k8z_HWIkBgAJ
      cluster_formation.node_cleanup.only_log_warning = true
      cluster_partition_handling = autoheal
      ## See https://www.rabbitmq.com/ha.html#master-migration-data-locality
      queue_master_locator=min-masters
      ## See https://www.rabbitmq.com/access-control.html#loopback-users
      loopback_users.guest = false
      cluster_formation.randomized_startup_delay_range.min = 0
      cluster_formation.randomized_startup_delay_range.max = 2
      # 必须设置service_name,否则Pod无法正常启动,这里设置后可以不设置statefulset下env中的K8S_SERVICE_NAME变量
      #cluster_formation.k8s.service_name = rabbitmq-headless
      # default is rabbitmq-cluster's namespace
      # hostname_suffix  必须设置hostname_suffix,否则节点不能成为集群,注意修改rabbitmq为ns名称
      cluster_formation.k8s.hostname_suffix = .rabbitmq-cluster.rabbitmq.svc.cluster.local
      # 内存上限
      # vm_memory_high_watermark.absolute = 1.6GB
      # 硬盘上限
      disk_free_limit.absolute = 2GB

3.创建sa

vim rabbitmq-rabac.yaml

apiVersion: v1
kind: ServiceAccount
metadata:
  name: rabbitmq-cluster
  namespace: rabbitmq
---
kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: rabbitmq-cluster
  namespace: rabbitmq
rules:
- apiGroups: [""]
  resources: ["endpoints"]
  verbs: ["get"]
---
kind: RoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: rabbitmq-cluster
  namespace: rabbitmq
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: Role
  name: rabbitmq-cluster
subjects:
- kind: ServiceAccount
  name: rabbitmq-cluster
  namespace: rabbitmq

4.statefulset创建pod

kind: StatefulSet
apiVersion: apps/v1
metadata:
  labels:
    app: rabbitmq-cluster
  name: rabbitmq-cluster
  namespace: rabbitmq
spec:
  replicas: 3
  selector:
    matchLabels:
      app: rabbitmq-cluster
  serviceName: rabbitmq-cluster #必须与headless service的name相同,用于hostname传播访问pod
  template:
    metadata:
      labels:
        app: rabbitmq-cluster #在apps/v1中,需与 .spec.template.metadata.label 相同,用于hostname传播访问pod,而在apps/v1beta中无需这样做
    spec:
      containers:
      - args:
        - -c
        - cp -v /etc/rabbitmq/rabbitmq.conf  ${RABBITMQ_CONFIG_FILE} ; exec docker-entrypoint.sh
          rabbitmq-server
        command:
        - sh
        env:
        - name: TZ
          value: 'Asia/Shanghai'
        - name: RABBITMQ_ERLANG_COOKIE
          value: 'SWvCP0Hrqv43NG7GybHC95ntCJKoW8UyNFWnBEWG8TY='
        - name: K8S_SERVICE_NAME
          value: rabbitmq-cluster
        - name: POD_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP
        - name: POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        - name: POD_NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: RABBITMQ_USE_LONGNAME
          value: "true"
        - name: RABBITMQ_NODENAME
          value: rabbit@$(POD_NAME).$(K8S_SERVICE_NAME).$(POD_NAMESPACE).svc.cluster.local
        - name: RABBITMQ_CONFIG_FILE
          value: /var/lib/rabbitmq/rabbitmq.conf
        image: registry.cn-shenzhen.aliyuncs.com/lishanbin/rabbitmq:3.9.10-management 
        imagePullPolicy: IfNotPresent
        livenessProbe:
          exec:
            command:
            - rabbitmq-diagnostics
            - status
          initialDelaySeconds: 60
          periodSeconds: 60
          timeoutSeconds: 15
        name: rabbitmq
        ports:
        - containerPort: 15672
          name: http
          protocol: TCP
        - containerPort: 5672
          name: amqp
          protocol: TCP
        readinessProbe:
          exec:
            command:
            - rabbitmq-diagnostics
            - status
          initialDelaySeconds: 20
          periodSeconds: 60
          timeoutSeconds: 10
        volumeMounts:  #容器挂载路径
        - mountPath: /etc/rabbitmq
          name: config-volume
          readOnly: false
        - mountPath: /var/lib/rabbitmq
          name: rabbitmq-storage
          readOnly: false
        - name: timezone
          mountPath: /etc/localtime
          readOnly: true
      serviceAccountName: rabbitmq-cluster
      terminationGracePeriodSeconds: 30
      volumes:    #物理机路径
      - name: config-volume
        configMap:
          items:
          - key: rabbitmq.conf
            path: rabbitmq.conf
          - key: enabled_plugins
            path: enabled_plugins
          name: rabbitmq-cluster-config
      - name: timezone
        hostPath:
          path: /usr/share/zoneinfo/Asia/Shanghai
      - name: rabbitmq-storage
        persistentVolumeClaim:    #pvc
          claimName: rabbitmq-pv-claim

5.访问测试

 

 

Kubernetes (k8s) 是一个开源的容器编排系统,常用于自动化部署、扩展和管理容器化的应用程序。部署RabbitMQ(一个开源的消息队列服务)到 Kubernetes 单机上,可以通过使用 Deployments 或者 StatefulSets 进行操作,因为 RabbitMQ 需要保持持久的实例。 下面是部署 RabbitMQ 到单个 Kubernetes 节点的简要步骤: 1. 准备RabbitMQ镜像: 使用Dockerfile构建一个包含RabbitMQ的镜像,或者从Docker Hub下载官方RabbitMQ镜像。 2. 创建YAML配置文件: 编写一个 `deployment.yaml` 或 `statefulset.yaml` 文件,定义RabbitMQ的Pod配置。例如,使用Deployment: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: rabbitmq-deployment spec: replicas: 1 selector: matchLabels: app: rabbitmq template: metadata: labels: app: rabbitmq spec: containers: - name: rabbitmq image: rabbitmq:latest ports: - containerPort: 5672 name: amqp - containerPort: 15672 name: management volumes: - name: rabbitmq-data persistentVolumeClaim: claimName: rabbitmq-pvc ``` 如果使用StatefulSet,还需要添加更细致的标识(如Pod名称和Pod序列号)和数据卷(PVC)。 3. 创建PersistentVolumeClaim (PVC): 为RabbitMQ创建一个 PVC 来存储数据,确保有足够的存储空间。 ```yaml apiVersion: v1 kind: PersistentVolumeClaim metadata: name: rabbitmq-pvc namespace: default spec: accessModes: [ "ReadWriteOnce" ] resources: requests: storage: "5Gi" ``` 4. 应用配置: 使用 `kubectl apply -f deployment.yaml` 或 `kubectl apply -f statefulset.yaml` 命令将配置应用到集群中。 5. 验证部署: 查看RabbitMQ服务是否正在运行,以及Pod的状态: ``` kubectl get pods,svc -n default ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

均衡教派.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值