GlusterFS
分散ファイルが開かれて、並列ネットワーク・ファイル・システムにネットワークによって相互接続されたクライアントの記憶容量のPB及び数千の数をサポートするためのスケールに強力な能力を有しています。スケーラブルで高性能、高可用性特性。
前提条件:GV0・ストレージ・ボリューム:ラボ環境Gluster FSクラスタに展開する必要があり、紙と呼ばれるを作成しました
作成1. endpoint
名前のファイルをglusterfs_ep.yaml
$ vi glusterfs_ep.yaml
apiVersion: v1
kind: Endpoints
metadata:
name: glusterfs
namespace: default
subsets:
# 添加GlusterFS各个集群的IP地址
- addresses:
- ip: 10.0.0.41
- ip: 10.0.0.42
ports:
# 添加GlusterFS端口号
- port: 49152
protocol: TCP
実行YAML
$ kubectl create -f glusterfs_ep.yaml
endpoints/glusterfs created
// 查看创建好的endpoints
[root@k8s-master01 ~]# kubectl get ep
NAME ENDPOINTS AGE
glusterfs 10.0.0.41:49152,10.0.0.42:49152 15s
2.エンドポイントのSVCを作成し
、エンドポイントはGlusterFSのクラスタノードで、あなたはこれらのノードにアクセスする必要がある、あなたは、SVCを作成する必要があります
$ vi glusterfs_svc.yaml
apiVersion: v1
kind: Service
metadata:
# 该名称必须要和endpoint里的name一致
name: glusterfs
spec:
ports:
- port: 49152
protocol: TCP
targetPort: 49152
sessionAffinity: None
type: ClusterIP
実行YAML
$ kubectl create -f glusterfs_svc.yaml
service/glusterfs created
$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
glusterfs ClusterIP 10.1.104.145 <none> 49152/TCP 20s
3. PVを作成することはGlusterfsです
$ vi glusterfs_pv.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
name: gluster
labels:
type: glusterfs
spec:
capacity:
# 指定该pv的容量
storage: 50Gi
accessModes:
- ReadWriteMany
glusterfs:
# 指定glusterfs的endpoint名称
endpoints: "glusterfs"
# path名称是在glusterfs里创建的卷
# 可登录到glusterfs集群执行"gluster volume list"命令来查看已创建的卷
path: "gv0"
readOnly: false
実行YAML
$ kubectl create -f glusterfs_pv.yaml
persistentvolume/gluster created
$ kubectl get pv
NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE
gluster 50Gi RWX Retain Available 10s
4. PVCを作成するGlusterfsです
$ vi glusterfs_pvc.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
# 名称必须和指定的pv一致
name: gluster
spec:
accessModes:
- ReadWriteMany
resources:
requests:
# 指定该pvc使用pv的容量空间
storage: 20Gi
実行YAML
$ kubectl create -f glusterfs_pvc.yaml
persistentvolumeclaim/gluster created
$ kubectl get pvc
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
gluster Bound gluster 50Gi RWX 83s
作成し、PVC nginx_pod.yamlのnginxのポッドクラスタにマウント5.
$ vim nginx-demo.yaml
---
# Pod
apiVersion: v1
kind: Pod
metadata:
name: nginx
labels:
app: web
env: test
spec:
containers:
- name: nginx
image: nginx:1.13
ports:
- containerPort: 80
volumeMounts:
- name: data-gv0
mountPath: /usr/share/nginx/html
volumes:
- name: data-gv0
persistentVolumeClaim:
# 绑定指定的pv
claimName: gluster
実行YAML
$ kubectl create -f nginx-demo.yaml
pod/nginx created
[root@k8s-master01 ~]# kubectl get pods | grep "nginx"
nginx 1/1 Running 0 2m 10.244.1.222 k8s-node01 <none> <none>
任意のクライアントではマウント/mnt
にglusterfs目录
して、作成しindex.html
たファイルを
$ mount -t glusterfs k8s-store01:/gv0 /mnt/
$ cd /mnt && echo "this nginx store used gluterfs cluster" >index.html
カールアクセスポッドによるマスターノード上で
$ curl 10.244.1.220/index.html
this nginx store used gluterfs cluster