使用StorageClass挂载ceph rbd须要用到2个cephx角色。一个用于建立和管理rbd,在这里咱们使用admin,另外一个用于挂载rbd到Pod中,咱们能够在ceph中手动建立一个。html
准备:nginx
假设已有一套ceph
集群,Monitor
分别为192.168.1.1
,192.168.1.2
和192.168.1.3
web
须要保证Monitor
的6379
端口和OSD
的6800
端口对kubelet
节点开放api
为每一个kubelet
节点都安装ceph-common
app
1、建立一个k8s
存储池,用于存放数据卷编码
# ceph osd pool create k8s 64 64
spa
2、建立cephx用户,用于挂载由admin
建立好的rbd
code
# ceph auth get-or-create client.k8s mon 'allow r' osd 'allow * pool=k8s'
orm
3、获取k8s
用户的key
,以base64
编码htm
# ceph auth get-key client.k8s|base64
记录输出的内容,如:QVFEQjlmcFpjUE5lS0JBQU40NnZxZ2dIT0dRTEtaeUx1blNjR1E9PQ==
4、获取admin
用户的key
,以base64
编码
# ceph auth get-key client.admin|base64
记录输出的内容,如:QVFDUDNrQllRRVBJR0JBQXFuVXJQbHZQaC9xZEQ2ZGVZOXRoVXc9PQ==
5、建立storage-class-rbd.yaml
--- apiVersion: v1 data: key: QVFEQjlmcFpjUE5lS0JBQU40NnZxZ2dIT0dRTEtaeUx1blNjR1E9PQ== kind: Secret metadata: name: ceph-secret-user namespace: default type: kubernetes.io/rbd --- apiVersion: v1 data: key: QVFDUDNrQllRRVBJR0JBQXFuVXJQbHZQaC9xZEQ2ZGVZOXRoVXc9PQ== kind: Secret metadata: name: ceph-secret-admin namespace: kube-system type: kubernetes.io/rbd --- apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: rbd provisioner: kubernetes.io/rbd parameters: monitors: 192.168.1.1:6789,192.168.1.2:6789,192.168.1.3:6789 adminId: admin adminSecretName: ceph-secret-admin adminSecretNamespace: kube-system pool: k8s userId: k8s userSecretName: ceph-secret-user fsType: xfs imageFormat: "2" imageFeatures: "layering"
6、建立StorageClass
# kubectl create -f ./storage-class-rbd.yaml
7、建立nginx-statefulset.yaml
, 经过StatefulSet
动态挂载卷
--- apiVersion: apps/v1beta1 kind: StatefulSet metadata: name: web spec: serviceName: "nginx" replicas: 2 volumeClaimTemplates: - metadata: annotations: volume.beta.kubernetes.io/storage-class: "rbd" # 这里配置 上面建立的 storageclass 的名称 spec: accessModes: [ "ReadWriteOnce" ] resources: requests: storage: 2Gi template: metadata: labels: app: nginx spec: containers: - name: nginx image: nginx:latest volumeMounts: - mountPath: "/usr/share/nginx/html/" name: html
StatefulSet
会为每一个Pod
建立一个rbd
数据卷,并挂载到/usr/share/nginx/html/
目录中,数据卷会随着StatefulSet
的伸缩而动态建立和销毁。