k8s-数据卷NFS共享卷
1. k8s数据卷NFS共享卷
-
安装示例:
# yum install nfs-utils -y # vi /etc/exports /ifs/kubernetes *(rw,no_root_squash) # mkdir -p /ifs/kubernetes # systemctl start nfs # systemctl enable nfs
注:每个Node上都要安装nfs-utils包
-
NFS共享卷架构图
-
示例:将网站程序通过NFS数据卷共享,让所有Pod使用
-
示例代码:
apiVersion: apps/v1 kind: Deployment Metadata: name: web-nfs spec: selector: matchLabels: app: Nginx-nfs replicas: 3 template: Metadata: labels: app: Nginx-nfs spec: containers: - name: Nginx-nfs image: Nginx volumeMounts: - name: wwwroot mountPath: /usr/share/Nginx/html ports: - containerPort: 80 volumes: - name: wwwroot nfs: server: 10.100.24.85 path: /ifs/kubernetes
2. 案例
2.1 安装和配置nfs
-
安装nfs
[root@k8s-node1 ~]# yum install nfs-utils -y [root@k8s-node2 ~]# yum install nfs-utils -y [root@k8s-node3 ~]# yum install nfs-utils -y
-
用node3做本次的nfs共享磁盘
-
[root@k8s-node3 ~]# vi /etc/exports [root@k8s-node3 ~]# cat /etc/exports /ifs/kubernetes *(rw,no_root_squash)
-
创建nfs共享目录
[root@k8s-node3 ~]# mkdir -p /ifs/kubernetes
-
创建index.html文件
[root@k8s-node3 ~]# cd /ifs/kubernetes/ [root@k8s-node3 kubernetes]# vim index.html [root@k8s-node3 kubernetes]# cat index.html <h1>Hello World!</h1>
-
-
每个node都启动并设置开机启动
[root@k8s-node3 ~]# systemctl start nfs #启动nfs [root@k8s-node3 ~]# systemctl enable nfs # 设置开机启动 Created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.
2.2 挂载nfs盘到pod容器
-
创建代码目录
[root@k8s-master yaml]# mkdir -p nfs/ [root@k8s-master yaml]# cd nfs/
-
编写pod代码
[root@k8s-master nfs]# vim nfs.yaml [root@k8s-master nfs]# cat nfs.yaml apiVersion: apps/v1 kind: Deployment Metadata: name: web-nfs spec: selector: matchLabels: app: Nginx-nfs replicas: 3 template: Metadata: labels: app: Nginx-nfs spec: containers: - name: Nginx-nfs image: Nginx volumeMounts: - name: wwwroot mountPath: /usr/share/Nginx/html ports: - containerPort: 80 volumes: - name: wwwroot nfs: server: 10.100.24.85 path: /ifs/kubernetes
-
启动服务
[root@k8s-master nfs]# kubectl apply -f nfs.yaml deployment.apps/web-nfs created
-
检查服务是否启动
[root@k8s-master nfs]# kubectl get pods,service -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READInesS GATES pod/configmap-demo-pod 1/1 Running 0 2d4h 10.244.107.209 k8s-node3 <none> <none> pod/my-hostpath 1/1 Running 0 4h45m 10.244.107.211 k8s-node3 <none> <none> pod/secret-demo-pod 1/1 Running 0 46h 10.244.107.210 k8s-node3 <none> <none> pod/web-nfs-84f8d7bf8d-6mj75 1/1 Running 0 2m42s 10.244.107.212 k8s-node3 <none> <none> pod/web-nfs-84f8d7bf8d-n4tpk 1/1 Running 0 2m42s 10.244.169.144 k8s-node2 <none> <none> pod/web-nfs-84f8d7bf8d-qvd2z 1/1 Running 0 2m42s 10.244.36.84 k8s-node1 <none> <none> NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE SELECTOR service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 13d <none>
-
检查内容是否存在
[root@k8s-master nfs]# curl -I 10.244.107.212 HTTP/1.1 200 OK Server: Nginx/1.19.6 Date: Mon, 28 Dec 2020 12:43:19 GMT Content-Type: text/html Content-Length: 22 Last-Modified: Mon, 28 Dec 2020 12:17:10 GMT Connection: keep-alive ETag: "5fe9ccc6-16" Accept-Ranges: bytes [root@k8s-master nfs]# curl 10.244.107.212 <h1>Hello World!</h1>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。