使用rabbitmq-operator在k8s集群上部署rabbitmq实例

文章目录


前言

使用rabbitmq-operator在k8s集群上部署rabbitmq实例。时区设置为上海


一、rabbitmq-operator

官网地址:https://www.rabbitmq.com/kubernetes/operator/install-operator

github上的tag列表网址:https://github.com/rabbitmq/cluster-operator/tags

二、进行部署

1.部署cluster-operator

首先获取cluster-operator.yml文件,然后增加上海时区的参数

我使用的是v2.9.0版本

shell 复制代码
wget https://github.com/rabbitmq/cluster-operator/releases/download/v2.9.0/cluster-operator.yml

增加上海时区的参数

yaml 复制代码
    spec:
      containers:
      - command:
        - /manager
        env:
        - name: OPERATOR_NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: TZ
          value: Asia/Shanghai

创建operator

shell 复制代码
kubectl create -f cluster-operator.yml

2.创建自己需要的特定命名空间

准备rabbitmq-namespace.yaml文件

yaml 复制代码
#https://www.rabbitmq.com/kubernetes/operator/install-operator

apiVersion: v1
kind: Namespace
metadata:
  name: slw-rabbitmq # Change this value if you want a different namespace name
  labels:
    name: slw-rabbitmq # Change this value to match metadata.name

创建命名空间

shell 复制代码
kubectl create -f rabbitmq-namespace.yaml

3.创建rabbitmq的instance

准备rabbitmq.yaml文件.

时区配置需要写在override下,卸载spec.env是不支持的。

yaml 复制代码
apiVersion: rabbitmq.com/v1beta1
kind: RabbitmqCluster
metadata:
  name: rabbitmqcluster-slw
  namespace: slw-rabbitmq
  labels:
    app: rabbitmq
spec:
  image: docker.io/rabbitmq:3.13.2-management
  replicas: 3
  service:
    type: ClusterIP
    #type: NodePort
  persistence:
    storageClassName: rook-cephfs 
    storage: 5Gi
  rabbitmq:
    additionalConfig: |
      default_user = guest
      default_pass = guest
  override:
    statefulSet:
      spec:
        template:
          spec:
            containers:
              - name: rabbitmq
                env:
                - name: TZ
                  value: Asia/Shanghai

通过yaml文件创建实例

shell 复制代码
kubectl create -f rabbitmq.yaml

4.创建nodeport访问

配置文件准备rabbitmq-nodeport.yaml

yaml 复制代码
kind: Service
apiVersion: v1
metadata:
  name: rabbitmqcluster-slw-nodeport
  namespace: slw-rabbitmq
  labels:
    app: rabbitmq
    app.kubernetes.io/component: rabbitmq
    app.kubernetes.io/name: rabbitmqcluster-slw
    app.kubernetes.io/part-of: rabbitmq
spec:
  ports:
    - name: amqp
      protocol: TCP
      appProtocol: amqp
      port: 5672
      targetPort: 5672
      nodePort: 30903
    - name: management
      protocol: TCP
      appProtocol: http
      port: 15672
      targetPort: 15672
      nodePort: 30904
    - name: prometheus
      protocol: TCP
      appProtocol: prometheus.io/metrics
      port: 15692
      targetPort: 15692
      nodePort: 30905
  selector:
    app.kubernetes.io/name: rabbitmqcluster-slw
  type: NodePort
  sessionAffinity: None
  externalTrafficPolicy: Cluster
  ipFamilies:
    - IPv4
  ipFamilyPolicy: SingleStack

通过yaml文件创建service

shell 复制代码
kubectl create -f rabbitmq-nodeport.yaml

结果验证

通过网页访问管理页面http://IP:30904/

账号密码均为guest

相关推荐
来一杯龙舌兰6 小时前
【RabbitMQ】RabbitMQ保证消息不丢失的N种策略的思想总结
分布式·rabbitmq·ruby·持久化·ack·消息确认
魏 无羡7 小时前
linux CentOS系统上卸载docker
linux·kubernetes·centos
Karoku0667 小时前
【k8s集群应用】kubeadm1.20高可用部署(3master)
运维·docker·云原生·容器·kubernetes
凌虚9 小时前
Kubernetes APF(API 优先级和公平调度)简介
后端·程序员·kubernetes
探索云原生12 小时前
在 K8S 中创建 Pod 是如何使用到 GPU 的: nvidia device plugin 源码分析
ai·云原生·kubernetes·go·gpu
启明真纳12 小时前
elasticache备份
运维·elasticsearch·云原生·kubernetes
jwolf214 小时前
基于K8S的微服务:一、服务发现,负载均衡测试(附calico网络问题解决)
微服务·kubernetes·服务发现
nangonghen14 小时前
在华为云通过operator部署Doris v2.1集群
kubernetes·华为云·doris·operator
Allen Bright16 小时前
Spring Boot 整合 RabbitMQ:从入门到实践
spring boot·rabbitmq·java-rabbitmq
会飞的土拨鼠呀16 小时前
chart文件结构
运维·云原生·kubernetes