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

创建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

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
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值