kubernetes集群部署redis5.0.6单机版
2021-05-30 13:04
标签:ada meta template export 服务器 100g 运行 日志 configMap 1、首先,通过Config Map来对容器中redis应用的配置进行管理,如自定义配置文件、密码、日志路径等 redis-standalone-conf.yml 创建configmaps 2、上面部署的redis,数据是存储在当前部署节点的本地的文件系统,现在讲存储改成NFS,创建pv和pvc 首先创建NFS 注:预先在NFS服务器上创建目录:/home/data/nfs/pai/redisstandalone redis-standalone-pv.yml 创建pv和pvc 3、由于redis是一个有状态服务,因此,现需要创建一个StatefulSet,并把数据挂载到宿主机上。 redis-standalone-statefulset.yml 4、通过创建service,提供对外访问pod的服务接口 redis-standalone-service.yml 创建service 5、验证redis是否部署成功 查看pod、pv、pvc、service、ConfigMap运行状态 测试远程连接 注:这里的host为宿主机IP -h 指定 远程redis主机的IP地址(pod所在的k8s节点) -p 指定 远程redis连接的端口 (service暴露的端口) -a 指定 远程redis连接的密码 (ConfigMap文件中设置的密码) 最后,更新完了重新验证redis即可。 登录NFS服务器,查看相应的文件挂载信息 kubernetes集群部署redis5.0.6单机版 标签:ada meta template export 服务器 100g 运行 日志 configMap 原文地址:https://www.cnblogs.com/fengyuanfei/p/14667240.htmlapiVersion: v1
kind: ConfigMap
metadata:
name: redis-standalone-conf
data:
redis.conf: |
bind 0.0.0.0
port 6379
requirepass 111111
appendonly yes
cluster-config-file nodes-6379.conf
pidfile /redis/log/redis-6379.pid
cluster-config-file /redis/conf/redis.conf
dir /redis/data/
logfile /redis/log/redis-6379.log
cluster-node-timeout 5000
protected-mode no
kubectl apply -f redis-standalone-conf.yml
# 创建挂载目录
mkdir /home/data/nfs/pai/redisstandalone -p
cat >>/etc/exports EOF
/home/data/nfs/pai/redisstandalone *(rw,sync,no_root_squash)
EOF
exportfs -r
systemctl restart rpcbind && systemctl restart nfs-server
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: redis-standalone-pv
spec:
capacity:
storage: 200G
accessModes:
- ReadWriteMany
storageClassName: nfsredis
nfs:
server: 192.168.33.157 # NFS服务器地址
path: "/home/data/nfs/pai/redisstandalone" # NFS目录
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: redis-standalone-pvc
spec:
volumeName: redis-standalone-pv
accessModes:
- ReadWriteMany
resources:
requests:
storage: 100Gi
storageClassName: nfsredis
kubectl apply -f redis-standalone-pv.yml
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: redis-standalone
spec:
replicas: 1
serviceName: redis-standalone
selector:
matchLabels:
name: redis-standalone
template:
metadata:
labels:
name: redis-standalone
spec:
#nodeName: gggd12-111-128-105 # 指定调度节点
initContainers:
- name: init-redis-standalone
image: busybox
command: [‘sh‘, ‘-c‘, ‘mkdir -p /redis/log/;mkdir -p /redis/conf/;mkdir -p /redis/data/‘]
volumeMounts:
- name: redis-standalone-pvc
mountPath: /redis/
containers:
- name: redis-standalone
image: redis:5.0.6
imagePullPolicy: IfNotPresent
command:
- sh
- -c
- "exec redis-server /redis/conf/redis.conf"
ports:
- containerPort: 6379
name: redis
protocol: TCP
volumeMounts:
- name: redis-config
mountPath: /redis/conf/
- name: redis-standalone-pvc
mountPath: /redis/
volumes:
- name: redis-config
configMap:
name: redis-standalone-conf
- name: redis-standalone-pvc
persistentVolumeClaim:
claimName: redis-standalone-pvc
kind: Service
apiVersion: v1
metadata:
labels:
name: redis-standalone
name: redis-standalone
spec:
type: NodePort
ports:
- name: redis
port: 6379
targetPort: 6379
nodePort: 31379
selector:
name: redis-standalone
kubectl apply -f redis-standalone-service.yml
kubectl get pod,svc,pv,pvc,cm
redis-cli -h 192.168.33.244 -p 31379 -a 111111
[root@k8s-master redis]# tree /home/data/nfs/pai/redisstandalone/
/home/data/nfs/pai/redisstandalone/
├── conf
├── data
│ └── appendonly.aof
└── log
├── redis-6379.log
└── redis-6379.pid
3 directories, 3 files