ubuntu kubernetes中使用NFS建立pv_pvc

一、NFS 介绍
NFS 即网络文件系统(Network File-System),能够经过网络让不一样机器、不一样系统之间能够实现文件共享。经过 NFS,能够访问远程共享目录,就像访问本地磁盘同样。NFS 只是一种文件系统,自己并无传输功能,是基于 RPC(远程过程调用)协议实现的,采用 C/S 架构。html

二、安装 NFS 软件包apache

#1安装nfs服务端
sudo apt install nfs-kernel-server -y
 
#2. 建立目录
sudo mkdir -p /data/k8s/
 
#3. 使任何客户端都可访问
sudo chown nobody:nogroup /data/k8s/  
#sudo chmod 755 /data/k8s/
sudo chmod 777 /data/k8s/
 
#4. 配置/etc/exports文件, 使任何ip都可访问(加入如下语句)
vi /etc/exports
/data/k8s/ *(rw,sync,no_subtree_check)
  
#5. 检查nfs服务的目录
sudo exportfs -ra (从新加载配置)
sudo showmount -e (查看共享的目录和容许访问的ip段)
 
#6. 重启nfs服务使以上配置生效
sudo systemctl restart nfs-kernel-server
#sudo /etc/init.d/nfs-kernel-server restart
 
#查看nfs服务的状态是否为active状态:active(exited)或active(runing)
systemctl status nfs-kernel-server
 
#7. 测试nfs服务是否成功启动
 
#安装nfs 客户端
sudo apt-get install nfs-common
#建立挂载目录
 sudo mkdir /data/k8s/
 
#7.4 在主机上的Linux中测试是否正常
sudo mount -t nfs -o nolock -o tcp 192.168.100.11:/data/k8s/ /data/k8s/(挂载成功,说明nfs服务正常)
 
#错误 mount.nfs: access denied by server while mounting

3建立pv(master上)vim mypv.yaml //内容以下vim

apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv001
spec:
  capacity:
    storage: 100M
  accessModes:
    - ReadWriteMany
  nfs:
    path: /data/k8s/
    server: 192.168.100.11

kubectl create -f mypv.yamlapi

kubectl get pvbash

状态为Available,这是由于它尚未绑定到任何的pvc上面,当定义完pvc后,就能够自动绑定了。网络

4 建立pvc(master上)vim mypvc.yaml //内容以下架构

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: myclaim
spec:
  accessModes:
    - ReadWriteMany
  resources:
    requests:
      storage: 8M

kubectl create -f mypvc.yamlcurl

kubectl get pvctcp

能够看到,pvc状态为Bound,它绑定了pv001ide

5 定义pod    vim pvpod.yaml //内容以下

apiVersion: v1
kind: Pod
metadata:
  name: httpd-pvpod
spec:
  containers:
  - image: httpd
    name: httpd-withpvc-pod
    imagePullPolicy: Always
    volumeMounts:
    - mountPath: "/usr/local/apache2/htdocs/"
      name: httpd-volume
  volumes:
    - name: httpd-volume
      persistentVolumeClaim:
        claimName: myclaim

kubectl create -f pvpod.yaml

kubectl describe pod httpd-pvpod //查看Volumes那部分里的ClaimName

6 验证

#1到NFS的共享目录下建立一个文件
cd /data/k8s/
echo "Test file" > 1.html
#2进入到httpd-pod里
#kubectl exec -it httpd-pvpod bash
kubectl exec -it httpd-pvpod /bin/sh
cat /usr/local/apache2/htdocs/1.html
#3删除httpd-pvpod
kubectl delete pod httpd-pvpod
cat /data/k8s/1.html
#4重建httpd-pod
kubectl create -f pvpod.yaml
#5curl访问
kubectl get pod httpd-pvpod -o wide //查看其对应的IP
相关文章
相关标签/搜索