当前位置: 首页 > news >正文

如何使用k8s安装redis呢

在Kubernetes (k8s) 上安装Redis
在Kubernetes上安装Redis有几种方法,下面我将介绍两种常见的方式:使用StatefulSet直接部署和使用Helm chart部署。
一、安装redis
1.1 拉去ARM镜像(7.4.2)

docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/linux_arm64_redis:latest

1.2 拉去x86镜像(8.0.1)版本

docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latest

方法一:使用StatefulSet部署Redis
首先创建一个Redis的配置文件ConfigMap:

apiVersion: v1
kind: ConfigMap
metadata:name: redis-config
data:redis.conf: |bind 0.0.0.0protected-mode noport 6379tcp-backlog 511timeout 0tcp-keepalive 300daemonize nosupervised nopidfile /var/run/redis_6379.pidloglevel noticelogfile ""databases 16always-show-logo yessave 900 1save 300 10save 60 10000stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename dump.rdbdir /data

创建Redis的StatefulSet和Service:

apiVersion: apps/v1
kind: StatefulSet
metadata:name: redis
spec:serviceName: redisreplicas: 1selector:matchLabels:app: redistemplate:metadata:labels:app: redisspec:containers:- name: redisimage: registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latestports:- containerPort: 6379name: redisvolumeMounts:- name: redis-datamountPath: /data- name: redis-configmountPath: /usr/local/etc/redis/redis.confsubPath: redis.confvolumes:- name: redis-configconfigMap:name: redis-configitems:- key: redis.confpath: redis.confvolumeClaimTemplates:- metadata:name: redis-dataspec:accessModes: [ "ReadWriteOnce" ]resources:requests:storage: 1Gi
---
apiVersion: v1
kind: Service
metadata:name: redis
spec:ports:- port: 6379targetPort: 6379selector:app: redis
kubectl apply -f redis-configmap.yaml
kubectl apply -f redis-statefulset.yaml

方法二:使用Helm安装Redis
如果你已经安装了Helm,这是更简单的方法:

添加Bitnami仓库(包含Redis chart):

helm repo add bitnami https://charts.bitnami.com/bitnami

安装Redis:

helm install redis registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latest

获取密码(如果启用了认证):

export REDIS_PASSWORD=$(kubectl get secret --namespace default my-redis -o jsonpath="{.data.redis-password}" | base64 --decode)

连接Redis:

kubectl run --namespace default edis-client --rm --tty -i --restart='Never' \--env REDIS_PASSWORD=$REDIS_PASSWORD \--image registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latest -- bash
redis-cli -h redis-master -a $REDIS_PASSWORD
redis-cli -h redis-replicas -a $REDIS_PASSWORD

验证安装

kubectl get pods
kubectl logs <redis-pod-name>

完整版本 redis-deployment-all.yaml

apiVersion: apps/v1
kind: Deployment
metadata:name: redis-deployment
spec:replicas: 1selector:matchLabels:app: redistemplate:metadata:labels:app: redisspec:containers:- name: redisimage: registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latestports:- containerPort: 6379env:- name: REDIS_PASSWORDvalue: "87vhqEneQ5u8"volumeMounts:- name: redis-logmountPath: /var/log/redis/- name: redis-datamountPath: /datacommand: ["redis-server", "--appendonly", "yes", "--requirepass", "$(REDIS_PASSWORD)"]volumes:- name: redis-logemptyDir: {}- name: redis-dataemptyDir: {}---
apiVersion: v1
kind: Service
metadata:name: redis-service
spec:type: NodePortports:- port: 6379targetPort: 6379nodePort: 30379selector:app: redis

应用配置:

kubectl apply -f  redis-deployment-all.yaml

第三种:

完整的 Redis 部署配置(包含 PV 和 PVC)
首先创建 PersistentVolume (PV):

apiVersion: v1
kind: PersistentVolume
metadata:name: redis-pv
spec:capacity:storage: 1GiaccessModes:- ReadWriteOncehostPath:path: /data/redispersistentVolumeReclaimPolicy: Retain

创建 PersistentVolumeClaim (PVC):

apiVersion: v1
kind: PersistentVolumeClaim
metadata:name: redis-pvc
spec:accessModes:- ReadWriteOnceresources:requests:storage: 1Gi

修改你的 Deployment 使用 PVC 而不是 emptyDir:

apiVersion: apps/v1
kind: Deployment
metadata:name: redis-deployment
spec:replicas: 1selector:matchLabels:app: redistemplate:metadata:labels:app: redisspec:containers:- name: redisimage: registry.cn-hangzhou.aliyuncs.com/qiluo-images/redis:latestports:- containerPort: 6379env:- name: REDIS_PASSWORDvalue: "87vhqEneQ5u8"volumeMounts:- name: redis-logmountPath: /var/log/redis/- name: redis-datamountPath: /datacommand: ["redis-server", "--appendonly", "yes", "--requirepass", "$(REDIS_PASSWORD)"]volumes:- name: redis-logemptyDir: {}- name: redis-datapersistentVolumeClaim:claimName: redis-pvc

Service 配置保持不变:

apiVersion: v1
kind: Service
metadata:name: redis-service
spec:type: NodePortports:- port: 6379targetPort: 6379nodePort: 30379selector:app: redis

如何使用这些配置
依次应用这些配置文件:

kubectl apply -f redis-pv.yaml
kubectl apply -f redis-pvc.yaml
kubectl apply -f redis-deployment.yaml
kubectl apply -f redis-service.yaml

验证资源是否创建成功:

kubectl get pv
kubectl get pvc
kubectl get pods
kubectl get svc

访问 Redis:
集群内部访问: 使用服务名 redis-service 和端口 6379
集群外部访问: 使用节点 IP 和 30379 端口

http://www.xdnf.cn/news/901387.html

相关文章:

  • SOC-ESP32S3部分:31-ESP-LCD控制器库
  • Dynamics 365 Business Central Direct Banking Extention D365 BC ERP 银行接口扩展
  • CountDownLatch和CyclicBarrier
  • P-MySQL SQL优化案例,反观MySQL不死没有天理
  • 衡量嵌入向量的相似性的方法
  • 4D毫米波雷达产品推荐
  • 『React』Fragment的用法及简写形式
  • React 中 HTML 插入的全场景实践与安全指南
  • 【React】React 18 并发特性
  • 练习:对象数组 4
  • 51单片机——计分器
  • 华为×小鹏战略合作:破局智能驾驶深水区的商业逻辑深度解析
  • web框架(Django 与 FastAPI)
  • arduino开发遇见的问题(求助!!)
  • Java-IO流之打印流详解
  • 【免杀】C2免杀技术(十六)反沙箱/反调试
  • 前端开发面试题总结-JavaScript篇(一)
  • caliper中的测试文件写法及其注意事项
  • 第R9周:阿尔茨海默病诊断(优化特征选择版)
  • Visual Studio 中的 MD、MTD、MDD、MT 选项详解
  • 使用Python和TensorFlow实现图像分类
  • 【vue3】十大核心 API 推动前端开发的革新与进阶
  • 振动力学:二自由度系统
  • html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码
  • Nature子刊同款的宏基因组免疫球蛋白测序怎么做?
  • miniforge3安装之后激活anaconda的虚拟环境
  • robot_lab——rsl_rl的train.py整体逻辑
  • 从入门到进阶:Python 学习参考书的深度解析
  • OPenCV CUDA模块光流------高效地执行光流估计的类BroxOpticalFlow
  • 传统的将自然语言转化为嵌入向量的核心机制是:,将离散的语言符号转化为连续的语义向量,其核心依赖“上下文决定语义”的假设和神经网络的特征提取能力。