Created
December 2, 2019 10:25
-
-
Save karngyan/2427ca07ac8a2103b107f158b9f1f2b0 to your computer and use it in GitHub Desktop.
Things to edit: file.system.id & region in ConfigMap; server in Deployment
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
kind: StorageClass | |
apiVersion: storage.k8s.io/v1 | |
metadata: | |
name: aws-efs | |
provisioner: example.com/aws-efs | |
--- | |
apiVersion: v1 | |
kind: ConfigMap | |
metadata: | |
name: efs-provisioner | |
data: | |
file.system.id: fs-d25d52ab # EFS File System ID | |
aws.region: us-east-2 # Region | |
provisioner.name: example.com/aws-efs | |
dns.name: "" | |
--- | |
kind: ClusterRole | |
apiVersion: rbac.authorization.k8s.io/v1 | |
metadata: | |
name: efs-provisioner-runner | |
rules: | |
- apiGroups: [""] | |
resources: ["persistentvolumes"] | |
verbs: ["get", "list", "watch", "create", "delete"] | |
- apiGroups: [""] | |
resources: ["persistentvolumeclaims"] | |
verbs: ["get", "list", "watch", "update"] | |
- apiGroups: ["storage.k8s.io"] | |
resources: ["storageclasses"] | |
verbs: ["get", "list", "watch"] | |
- apiGroups: [""] | |
resources: ["events"] | |
verbs: ["create", "update", "patch"] | |
--- | |
kind: ClusterRoleBinding | |
apiVersion: rbac.authorization.k8s.io/v1 | |
metadata: | |
name: run-efs-provisioner | |
subjects: | |
- kind: ServiceAccount | |
name: efs-provisioner | |
# replace with namespace where provisioner is deployed | |
namespace: default | |
roleRef: | |
kind: ClusterRole | |
name: efs-provisioner-runner | |
apiGroup: rbac.authorization.k8s.io | |
--- | |
kind: Role | |
apiVersion: rbac.authorization.k8s.io/v1 | |
metadata: | |
name: leader-locking-efs-provisioner | |
rules: | |
- apiGroups: [""] | |
resources: ["endpoints"] | |
verbs: ["get", "list", "watch", "create", "update", "patch"] | |
--- | |
kind: RoleBinding | |
apiVersion: rbac.authorization.k8s.io/v1 | |
metadata: | |
name: leader-locking-efs-provisioner | |
subjects: | |
- kind: ServiceAccount | |
name: efs-provisioner | |
# replace with namespace where provisioner is deployed | |
namespace: default | |
roleRef: | |
kind: Role | |
name: leader-locking-efs-provisioner | |
apiGroup: rbac.authorization.k8s.io | |
--- | |
apiVersion: v1 | |
kind: ServiceAccount | |
metadata: | |
name: efs-provisioner | |
--- | |
kind: Deployment | |
apiVersion: extensions/v1beta1 | |
metadata: | |
name: efs-provisioner | |
spec: | |
replicas: 1 | |
strategy: | |
type: Recreate | |
template: | |
metadata: | |
labels: | |
app: efs-provisioner | |
spec: | |
serviceAccount: efs-provisioner | |
containers: | |
- name: efs-provisioner | |
image: quay.io/external_storage/efs-provisioner:latest | |
env: | |
- name: FILE_SYSTEM_ID | |
valueFrom: | |
configMapKeyRef: | |
name: efs-provisioner | |
key: file.system.id | |
- name: AWS_REGION | |
valueFrom: | |
configMapKeyRef: | |
name: efs-provisioner | |
key: aws.region | |
- name: DNS_NAME | |
valueFrom: | |
configMapKeyRef: | |
name: efs-provisioner | |
key: dns.name | |
optional: true | |
- name: PROVISIONER_NAME | |
valueFrom: | |
configMapKeyRef: | |
name: efs-provisioner | |
key: provisioner.name | |
volumeMounts: | |
- name: pv-volume | |
mountPath: /persistentvolumes | |
volumes: | |
- name: pv-volume | |
nfs: | |
server: fs-d25d52ab.efs.us-east-2.amazonaws.com # dns name | |
path: / | |
--- | |
kind: PersistentVolumeClaim | |
apiVersion: v1 | |
metadata: | |
name: efs | |
annotations: | |
volume.beta.kubernetes.io/storage-class: "aws-efs" | |
spec: | |
accessModes: | |
- ReadWriteMany | |
resources: | |
requests: | |
storage: 1Mi |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment