基于k8s环境部署redis-cluster集群

本文详细描述了如何在Kubernetes中创建和管理RedisStatefulSet,包括配置文件redis.yaml的编写,设置Service暴露服务,以及使用redis-cli进行集群初始化、连接和测试操作。
摘要由CSDN通过智能技术生成

创建redis.yaml文件

apiVersion: apps/v1
kind: StatefulSet
metadata:
  namespace: yozo
  name: redis
  labels:
    app: redis
spec:
  serviceName: redis-service
  replicas: 6
  selector:
    matchLabels:
      app: redis
      appCluster: redis-cluster
  template:
    metadata:
      labels:
        app: redis
        appCluster: redis-cluster
    spec:  #反亲和性配置
      terminationGracePeriodSeconds: 20
      affinity:
        podAntiAffinity:
          preferredDuringSchedulingIgnoredDuringExecution:
          - weight: 100
            podAffinityTerm:
              labelSelector:
                matchExpressions:
                - key: app
                  operator: In
                  values:
                  - redis
              topologyKey: kubernetes.io/hostname
#      nodeName: k3s-master-common
      securityContext:
        runAsUser: 1099
        runAsGroup: 1099
        fsGroup: 1099
      containers:
      - name: yozo-redis
        image: hub.yozosoft.com:4431/common/x86_64/redis:6.2.13_uuid
        imagePullPolicy: IfNotPresent
        ports:
        - name: redis
          containerPort: 6379
          protocol: "TCP"
        - name: cluster
          containerPort: 16379
          protocol: "TCP"
        command: ["redis-server"]
        args: ["/etc/redis.conf"]
        volumeMounts:
          - name: redis-data
            mountPath: /data/redis/data
            subPath: data/redis
          - name: redis-conf
            mountPath: /etc/redis.conf
            subPath: redis.conf
      volumes:
        - name: redis-conf
          configMap:
            name: redis-config
      restartPolicy: Always
  volumeClaimTemplates:
  - metadata:
      name: redis-data
    spec:
      accessModes: [ "ReadWriteMany" ]
      storageClassName: "sc-yozo-data"
      resources:
        requests:
          storage: 500M

---
apiVersion: v1
kind: Service
metadata:
  name: redis-service
  namespace: yozo
#  labels:
#    app: redis
spec:
  ports:
  - name: redis
    port: 6379
    targetPort: 6379
  - name: redis-cluster
    port: 16379
    targetPort: 16379
  clusterIP: None
  selector:
    app: redis
    appCluster: redis-cluster

---
apiVersion: v1
kind: ConfigMap
metadata:
  namespace: yozo
  name: redis-config
data:
  redis.conf: |
    bind 0.0.0.0
    port 6379
    masterauth 123456
    requirepass 123456
    dbfilename dump.rdb
    dir /data/redis/data
    cluster-enabled yes
    cluster-config-file /data/redis/data/redis-cluster.conf
    cluster-node-timeout 10000
    slave-read-only yes
#    ignore-warnings ARM64-COW-BUG

任意进入其中一个pod

kubectl exec -it redis-0 -nyozo sh

#初始化redis集群,ip为pod的ip

redis-cli --cluster create 10.42.0.62:6379 10.42.0.63:6379 10.42.1.236:6379 10.42.1.237:6379  10.42.2.223:6379 10.42.2.224:6379  --cluster-replicas 1 --cluster-yes -a 123456

#以集群方式连接

redis-cli -c -a 123456

#查看集群连接信息

cluster nodes

32c9cf1d03fa7d145d3345a96dab6ef3b2eb2681 10.42.2.172:6379@16379 slave 1348a85cca84b6bb14d12e36293cb1dac195b72c 0 1720096783000 3 connected
476ffa1939f26caee40cdfb3185d3f1b37b9301f 10.42.2.167:6379@16379 myself,master - 0 1720096786000 1 connected 0-5460
dd58c2f7d9eb140577dad4574bb57e52b35ccef9 10.42.0.36:6379@16379 master - 0 1720096786715 2 connected 5461-10922
5e466ee40fc264e08ffdee33ca8fb38b3b3b3fa6 10.42.1.226:6379@16379 slave dd58c2f7d9eb140577dad4574bb57e52b35ccef9 0 1720096785000 2 connected
5e8f98dd9eb29901ac9f7a42bd3066fb2fdd590c 10.42.0.37:6379@16379 slave 476ffa1939f26caee40cdfb3185d3f1b37b9301f 0 1720096784705 1 connected
1348a85cca84b6bb14d12e36293cb1dac195b72c 10.42.1.225:6379@16379 master - 0 1720096785708 3 connected 10923-16383

#重启一个pod,集群ip会动态识别podip变化,但是重启的那个pod自己本身却不会识别到ip变化

#调整一下启动参数,使其动态获取ip

        command: ["redis-server"]
        args: ["/etc/redis.conf"]
        args:
        - /etc/redis.conf
        - --cluster-announce-ip
        - "$(POD_IP)"
        env:
        - name: POD_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP

cluster info

#测试添加一个key值

set 1 v1

#登录其他节点验证

get 1

创建一个service暴漏服务

apiVersion: v1
kind: Service
metadata:
  name: redis-yozo
  namespace: yozo
  labels:
    app: redis
spec:
  ports:
  - name: redis-port
    protocol: "TCP"
    port: 6379
    targetPort: 6379
  - name: redis-cluster
    protocol: "TCP"
    port: 16379
    targetPort: 16379
  type: LoadBalancer
  selector:
    app: redis
    appCluster: redis-cluster 

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在 Kubernetes部署 Redis Cluster 集群,可以按照以下步骤进行: 1. 创建 Redis ConfigMap 首先,需要创建一个 Redis 配置文件 ConfigMap。可以使用以下命令创建: ``` kubectl create configmap redis-conf --from-file=redis.conf ``` 其中,`redis.conf` 是 Redis 配置文件的名称。可以根据实际情况进行修改。 2. 创建 Redis StatefulSet 接下来,可以创建 Redis StatefulSet。可以使用以下 YAML 文件作为模板: ``` apiVersion: apps/v1 kind: StatefulSet metadata: name: redis-cluster spec: serviceName: redis-cluster replicas: 6 selector: matchLabels: app: redis-cluster template: metadata: labels: app: redis-cluster spec: containers: - name: redis image: redis:6.0.9 ports: - containerPort: 6379 name: client - containerPort: 16379 name: gossip volumeMounts: - name: config mountPath: /usr/local/etc/redis/redis.conf subPath: redis.conf command: - sh - -c - | if [ -n "${POD_NAME}" ]; then sed -i "s/%cluster-name%/redis-cluster/g" /usr/local/etc/redis/redis.conf sed -i "s/%node-name%/${POD_NAME}/g" /usr/local/etc/redis/redis.conf fi volumes: - name: config configMap: name: redis-conf volumeClaimTemplates: - metadata: name: data spec: accessModes: [ "ReadWriteOnce" ] resources: requests: storage: 1Gi ``` 在上述 YAML 文件中,`replicas` 字段指定了 Redis 集群的节点数,`volumeClaimTemplates` 字段指定了每个节点的数据卷大小。另外,还需要注意以下几点: - `serviceName` 字段需要与 `metadata.name` 字段相同。 - `selector.matchLabels` 字段需要与 `metadata.labels` 字段相同。 - `command` 字段用于修改 Redis 配置文件中的节点名称和集群名称。 3. 创建 Redis Service 最后,需要创建 Redis Service。可以使用以下 YAML 文件作为模板: ``` apiVersion: v1 kind: Service metadata: name: redis-cluster labels: app: redis-cluster spec: ports: - name: client port: 6379 targetPort: 6379 - name: gossip port: 16379 targetPort: 16379 clusterIP: None selector: app: redis-cluster ``` 在上述 YAML 文件中,`clusterIP` 字段需要设置为 `None`,以便创建一个 Headless Service,让每个 Redis 节点可以通过 DNS 解析到自己的 IP 地址。 4. 部署 Redis Cluster 完成以上步骤后,可以使用以下命令部署 Redis Cluster: ``` kubectl apply -f redis-cluster.yaml ``` 其中,`redis-cluster.yaml` 是包含 Redis StatefulSet 和 Redis Service 的 YAML 文件。可以根据实际情况进行修改。 部署完成后,可以使用以下命令查看 Redis Cluster 的状态: ``` kubectl exec -it redis-cluster-0 -- redis-cli cluster nodes ``` 其中,`redis-cluster-0` 是 Redis Cluster 中的一个节点名称。可以根据实际情况进行修改。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值