8.1 k8s使用PV/PVC做数据持久化运行redis服务,数据保存至NFS
1.制作redis docker镜像
1.1 准备alpine基础镜像
# 下载
docker pull alpine:3.13
# 更改tag
docker tag alpine:3.13 192.168.1.110/base/alpine:3.13
# 上传到本地harbor
docker push 192.168.1.110/base/alpine:3.13
1.2 准备redis安装包及配置文件
下载redis安装包
wget http://download.redis.io/releases/redis-4.0.14.tar.gz
修改redis.conf
tar xf redis-4.0.14.tar.gz
cp redis-4.0.14/redis.conf .
vim redis.conf
...
save 5 1
save 900 1
save 300 10
save 60 10000
dbfilename dump.rdb
dir /data/
...
镜像中redis的启动脚本
cat run_redis.sh
#!/bin/bash
/usr/local/redis/bin/redis-server /etc/redis.conf
tail -f /etc/hosts
1.3 编写Dockerfile
FROM 192.168.1.110/base/alpine:3.13
ADD redis-4.0.14.tar.gz /tmp/
ADD run_redis.sh /usr/local/redis/
ADD redis.conf /etc/redis.conf
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories \
&& apk add gcc g++ make libffi-dev openssl-dev libtool \
&& mkdir /data/redisdata -p \
&& cd /tmp/redis-4.0.14 \
&& make PREFIX=/usr/local/redis install \
&& rm -rf /tmp/redis-4.0.14
EXPOSE 6379
CMD ["/usr/local/redis/run_redis.sh"]
1.4 制作镜像并上传到本地harbor
# ls -l
总用量 1772
-rw-r--r-- 1 root root 471 10月 22 14:37 Dockerfile
-rw-r--r-- 1 root root 1740967 10月 22 13:58 redis-4.0.14.tar.gz
-rw-r--r-- 1 root root 58792 10月 22 16:30 redis.conf
-rwxr-xr-x 1 root root 82 10月 22 14:15 run_redis.sh
# docker build -t 192.168.1.110/base/alpine3.13-redis4.0.14:v20211022-1631 .
# docker push 192.168.1.110/base/alpine3.13-redis4.0.14:v20211022-1631
2.为redis数据存储部署PV/PVC
2.1 NFS server创建目录
mkdir /data/k8s-data/redis/datadir-pv-1 -p
2.2 编写pv/pvc yaml
apiVersion: v1
kind: PersistentVolume
metadata:
name: redis-datadir-pv-1
spec:
capacity:
storage: 20Gi
accessModes:
- ReadWriteOnce
nfs:
server: 192.168.2.10
path: /data/k8s-data/redis/datadir-pv-1
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: redis-datadir-pvc-1
namespace: yan-test
spec:
accessModes:
- ReadWriteOnce
volumeName: redis-datadir-pv-1
resources:
requests:
storage: 10Gi
2.3 创建pv/pvc并验证
创建namespace
# kubectl create ns yan-test
创建pv/pvc
# kubectl apply -f redis_pv_pvc.yaml
验证
# kubectl get pv
NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE
redis-datadir-pv-1 20Gi RWO Retain Bound yan-test/redis-datadir-pvc-1 78m
# kubectl get pvc -n yan-test
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
redis-datadir-pvc-1 Bound redis-datadir-pv-1 20Gi RWO 78m
3.在k8s上部署redis
3.1 编写yaml
# cat redis_svc_deploy.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis-deployment
labels:
app: redis
namespace: yan-test
spec:
replicas: 1
selector:
matchLabels:
app: redis
template:
metadata:
labels:
app: redis
spec:
containers:
- name: redis-container
image: 192.168.1.110/base/alpine3.13-redis4.0.14:v20211022-1631
imagePullPolicy: IfNotPresent
volumeMounts:
- mountPath: /data/
name: redis-data
volumes:
- name: redis-data
persistentVolumeClaim:
claimName: redis-datadir-pvc-1
---
apiVersion: v1
kind: Service
metadata:
name: redis-svc
namespace: yan-test
spec:
ports:
- name: http
port: 6379
targetPort: 6379
nodePort: 36379
type: NodePort
selector:
app: redis
3.2 创建redis
# kubectl apply -f redis_svc_deploy.yaml
3.3 验证是否创建成功
root@k8-deploy:~/k8s-yaml/redis# kubectl get svc -n yan-test
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
redis-svc NodePort 10.0.12.138 <none> 6379:36379/TCP 36m
root@k8-deploy:~/k8s-yaml/redis# kubectl get pod -n yan-test
NAME READY STATUS RESTARTS AGE
redis-deployment-75b9b94b64-rtj95 1/1 Running 0 36m
4.验证redis服务及数据存储是否正常
# 通过Nodeport端口连接redis
root@k8-deploy:~/k8s-yaml/redis# redis-cli -h 192.168.2.17 -p 36379
192.168.2.17:36379> INFO
# Server
redis_version:4.0.14
redis_git_sha1:00000000
...
# 写入数据测试
192.168.2.17:36379> DBSIZE
(integer) 0
192.168.2.17:36379> set a 1
OK
# 查看NFSsever上redis的目录是否有redis的数据文件
root@k8-deploy:~/k8s-yaml/redis# ls /data/k8s-data/redis/datadir-pv-1/
dump.rdb redis.log
8.1 k8s使用PV/PVC做数据持久化运行redis服务,数据保存至NFS的更多相关文章
- k8s存储 pv pvc ,storageclass
1. pv pvc 现在测试 glusterfs nfs 可读可写, 多个pod绑定到同一个pvc上,可读可写. 2. storageclass 分成两种 (1) 建立pvc, 相当于多个 ...
- 通过DataWorks数据集成归档日志服务数据至MaxCompute进行离线分析
通过DataWorks归档日志服务数据至MaxCompute 官方指导文档:https://help.aliyun.com/document_detail/68322.html但是会遇到大家在分区上或 ...
- 7.2 k8s 基于PV、PVC搭建zookeeper 3节点集群
1.PV,PVC介绍 1.1.StorageClass & PV & PVC关系图 Volumes 是最基础的存储抽象,其支持多种类型,包括本地存储.NFS.FC以及众多的云存储,我们 ...
- Kubernetes 存储卷管理 PV&PVC(十)
目录 一.emptyDir 二.hostPath 三.PV & PVC 1.NFS PersistentVolume 2.创建 PVC 3.创建 Pod 进行挂载 为了持久化保存容器的数据,可 ...
- IOS开发--数据持久化篇之文件存储(一)
前言:个人觉得开发人员最大的悲哀莫过于懂得使用却不明白其中的原理.在代码之前我觉得还是有必要简单阐述下相关的一些知识点. 因为文章或深或浅总有适合的人群.若有朋友发现了其中不正确的观点还望多多指出,不 ...
- Redis之数据持久化RDB与AOF
Redis之数据持久化RDB与AOF https://www.cnblogs.com/zackku/p/10087701.html 大家都知道,Redis之所以性能好,读写快,是因为Redis是一个内 ...
- 进阶的Redis之数据持久化RDB与AOF
大家都知道,Redis之所以性能好,读写快,是因为Redis是一个内存数据库,它的操作都几乎基于内存.但是内存型数据库有一个很大的弊端,就是当数据库进程崩溃或系统重启的时候,如果内存数据不保存的话,里 ...
- Redis数据持久化,安全
一.redis数据持久化 由于redis是一个内存数据库,如果系统遇到致命问题需要关机或重启,内存中的数据就会丢失,这是生产环境所不能允许的.所以redis提供了数据持久化的能力. redis提供了两 ...
- Redis进阶:数据持久化,安全,在PHP中使用
一.redis数据持久化 由于redis是一个内存数据库,如果系统遇到致命问题需要关机或重启,内存中的数据就会丢失,这是生产环境所不能允许的.所以redis提供了数据持久化的能力. redis提供了两 ...
随机推荐
- Linux环境下安装java的方法
linux安装java步骤 方式一:yum方式下载安装 1.查找java相关的列表 yum -y list java* 或者 yum search jdk 2.安装jdk yum install ja ...
- python flask1
以这个服务端代码为例,简单了解一下flask的运用. 1.app = Flask(__name__)记住就好了 2.@app.route("/")记住就好了:注意括号里的是调用这个 ...
- Go语言核心36讲(Go语言进阶技术七)--学习笔记
13 | 结构体及其方法的使用法门 我们都知道,结构体类型表示的是实实在在的数据结构.一个结构体类型可以包含若干个字段,每个字段通常都需要有确切的名字和类型. 前导内容:结构体类型基础知识 当然了,结 ...
- 2020BUAA软工个人博客作业
2020BUAA软工个人博客作业 17373010 杜博玮 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 个人博客作业 我在这个课程的目标是 学 ...
- makedown笔记
makedown语法 表格 这个表格的主题 |姓名|性别|年龄|职业| | ----- | ----- | ----- | ----- | |张三|男|34|码农| |李四|男|27|代驾| 这个表格 ...
- 莱特币(LTC)开发环境搭建
Linux系统下搭建莱特币LTC开发环境 1.简介 2.LTC 客户端下载 3.解压到一个固定的目录中 4.启动客户端 4.1.参数解释: 4.2.更多详细的配置 5.执行命令测试一下 6.获取莱特币 ...
- Noip模拟31 2021.8.5
T1 Game 当时先胡了一发$\textit{Next Permutation}$... 然后想正解,只想到贪心能求最大得分,然后就不会了.. 然后就甩个二十分的走了... 正解的最大得分(叫它$k ...
- 关于string转换为wstring问题
方法一:需要调用windows的api函数进行转换,在vs2017上试验转换成功 #ifdef _MSC_VER #include <Windows.h> #endif // _MSC_V ...
- Java-基础-LinkedList
1. 简介 LinkedList 同时实现了List和Deque接口,也就是说它既可以看作是一个顺序容器,又可以看作是双向队列. 既然是双向列表,那么它的每个数据节点都一定有两个指针,分别指向它的前驱 ...
- 设计的MOS管三极管简单开关电路驱动能力不够3
16楼说得非常明白,补充一点,R3如果不要,会有下冲产生.4 Q: Z/ G G1 s8 Z- } 能解释下为什么会产生过冲吗?9 i, P* D* X) u. t/ b ^ 让我们这些菜鸟学习学 ...