kubernetes app add
This commit is contained in:
1
jenkins/defaults/main.yml
Normal file
1
jenkins/defaults/main.yml
Normal file
@@ -0,0 +1 @@
|
||||
HOSTNAME: jenkins.jhcloud.kr
|
||||
7
jenkins/tasks/main.yml
Normal file
7
jenkins/tasks/main.yml
Normal file
@@ -0,0 +1,7 @@
|
||||
---
|
||||
- name: Jenkins Helm Chart Install
|
||||
kubernetes.core.helm:
|
||||
name: jenkins
|
||||
chart_ref: /root/kubespray/roles/kubernetes-apps/jenkins/templates/
|
||||
namespace: jenkins
|
||||
create_namespace: true
|
||||
1
jenkins/templates
Submodule
1
jenkins/templates
Submodule
Submodule jenkins/templates added at 5d17197d23
9
nfs_external_provisioner/defaults/main.yml
Normal file
9
nfs_external_provisioner/defaults/main.yml
Normal file
@@ -0,0 +1,9 @@
|
||||
---
|
||||
# defaults file for nfs_external_provisioner
|
||||
nfs_external_provisioner_enabled: true
|
||||
# replace with namespace where provisioner will be deployed
|
||||
nfs_namespace: nfs
|
||||
# replace with your nfs server
|
||||
nfs_server: 192.168.7.17
|
||||
# replace with your nfs exported path
|
||||
nfs_path: /root/test
|
||||
37
nfs_external_provisioner/tasks/main.yml
Normal file
37
nfs_external_provisioner/tasks/main.yml
Normal file
@@ -0,0 +1,37 @@
|
||||
---
|
||||
# tasks file for nfs_external_provisioner
|
||||
#- name: NFS External Provisioner | Install Pre-Packages
|
||||
# yum:
|
||||
# name: "{{ item }}"
|
||||
# state: present
|
||||
# update_cache: True
|
||||
# with_items:
|
||||
# - nfs-utils.x86_64
|
||||
# when:
|
||||
# - not is_this_offline
|
||||
- name: NFS External Provisioner | Generate Manifests
|
||||
template:
|
||||
src: "{{ item }}.j2"
|
||||
dest: "{{ kube_config_dir }}/{{ item }}"
|
||||
with_items: ["nfs-namespace.yml", "nfs-rbac.yml", "nfs-deployment.yml", "nfs-storageclass.yml"]
|
||||
register: nfs_provisioner_manifests
|
||||
when: inventory_hostname == groups['kube_control_plane'][0]
|
||||
|
||||
- name: NFS External Provisioner | Apply Manifests
|
||||
kube:
|
||||
kubectl: "{{ bin_dir }}/kubectl"
|
||||
filename: "{{ kube_config_dir }}/{{ item.item }}"
|
||||
state: "latest"
|
||||
wait: true
|
||||
with_items:
|
||||
- "{{ nfs_provisioner_manifests.results }}"
|
||||
when:
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
loop_control:
|
||||
label: "{{ item.item }}"
|
||||
|
||||
- name: NFS External Provisioner | Default Storage Class
|
||||
shell: >-
|
||||
{{ bin_dir }}/kubectl --kubeconfig {{ kube_config_dir }}/admin.conf
|
||||
patch storageclass nfs
|
||||
-p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
|
||||
40
nfs_external_provisioner/templates/nfs-deployment.yml.j2
Normal file
40
nfs_external_provisioner/templates/nfs-deployment.yml.j2
Normal file
@@ -0,0 +1,40 @@
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: nfs-client-provisioner
|
||||
labels:
|
||||
app: nfs-client-provisioner
|
||||
namespace: {{ nfs_namespace }}
|
||||
spec:
|
||||
replicas: 1
|
||||
strategy:
|
||||
type: Recreate
|
||||
selector:
|
||||
matchLabels:
|
||||
app: nfs-client-provisioner
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: nfs-client-provisioner
|
||||
spec:
|
||||
serviceAccountName: nfs-client-provisioner
|
||||
containers:
|
||||
- name: nfs-client-provisioner
|
||||
image: >-
|
||||
gcr.io/k8s-staging-sig-storage/nfs-subdir-external-provisioner:v4.0.0
|
||||
volumeMounts:
|
||||
- name: nfs-client-root
|
||||
mountPath: /persistentvolumes
|
||||
env:
|
||||
- name: PROVISIONER_NAME
|
||||
value: k8s-sigs.io/nfs-subdir-external-provisioner
|
||||
- name: NFS_SERVER
|
||||
value: {{ nfs_server }}
|
||||
- name: NFS_PATH
|
||||
value: {{ nfs_path }}
|
||||
volumes:
|
||||
- name: nfs-client-root
|
||||
nfs:
|
||||
server: {{ nfs_server }}
|
||||
path: {{ nfs_path }}
|
||||
5
nfs_external_provisioner/templates/nfs-namespace.yml.j2
Normal file
5
nfs_external_provisioner/templates/nfs-namespace.yml.j2
Normal file
@@ -0,0 +1,5 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: {{ nfs_namespace }}
|
||||
62
nfs_external_provisioner/templates/nfs-rbac.yml.j2
Normal file
62
nfs_external_provisioner/templates/nfs-rbac.yml.j2
Normal file
@@ -0,0 +1,62 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
name: nfs-client-provisioner
|
||||
namespace: {{ nfs_namespace }}
|
||||
---
|
||||
kind: ClusterRole
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
name: nfs-client-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-nfs-client-provisioner
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: nfs-client-provisioner
|
||||
# replace with namespace where provisioner is deployed
|
||||
namespace: nfs
|
||||
roleRef:
|
||||
kind: ClusterRole
|
||||
name: nfs-client-provisioner-runner
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
---
|
||||
kind: Role
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
name: leader-locking-nfs-client-provisioner
|
||||
namespace: {{ nfs_namespace }}
|
||||
rules:
|
||||
- apiGroups: [""]
|
||||
resources: ["endpoints"]
|
||||
verbs: ["get", "list", "watch", "create", "update", "patch"]
|
||||
---
|
||||
kind: RoleBinding
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
metadata:
|
||||
name: leader-locking-nfs-client-provisioner
|
||||
namespace: {{ nfs_namespace }}
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: nfs-client-provisioner
|
||||
namespace: {{ nfs_namespace }}
|
||||
roleRef:
|
||||
kind: Role
|
||||
name: leader-locking-nfs-client-provisioner
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
@@ -0,0 +1,9 @@
|
||||
---
|
||||
apiVersion: storage.k8s.io/v1
|
||||
kind: StorageClass
|
||||
metadata:
|
||||
name: nfs
|
||||
provisioner: k8s-sigs.io/nfs-subdir-external-provisioner
|
||||
parameters:
|
||||
onDelete: delete
|
||||
pathPattern: "${.PVC.namespace}/${.PVC.name}"
|
||||
140
roles/kubernetes-apps/meta/main.yml
Normal file
140
roles/kubernetes-apps/meta/main.yml
Normal file
@@ -0,0 +1,140 @@
|
||||
---
|
||||
dependencies:
|
||||
- role: kubernetes-apps/ansible
|
||||
when:
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
|
||||
- role: kubernetes-apps/helm
|
||||
when:
|
||||
- helm_enabled
|
||||
tags:
|
||||
- helm
|
||||
|
||||
- role: kubernetes-apps/krew
|
||||
when:
|
||||
- krew_enabled
|
||||
tags:
|
||||
- krew
|
||||
|
||||
- role: kubernetes-apps/registry
|
||||
when:
|
||||
- registry_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- registry
|
||||
|
||||
- role: kubernetes-apps/metrics_server
|
||||
when:
|
||||
- metrics_server_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- metrics_server
|
||||
|
||||
- role: kubernetes-apps/csi_driver/csi_crd
|
||||
when:
|
||||
- cinder_csi_enabled or csi_snapshot_controller_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/cinder
|
||||
when:
|
||||
- cinder_csi_enabled
|
||||
tags:
|
||||
- cinder-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/aws_ebs
|
||||
when:
|
||||
- aws_ebs_csi_enabled
|
||||
tags:
|
||||
- aws-ebs-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/azuredisk
|
||||
when:
|
||||
- azure_csi_enabled
|
||||
tags:
|
||||
- azure-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/gcp_pd
|
||||
when:
|
||||
- gcp_pd_csi_enabled
|
||||
tags:
|
||||
- gcp-pd-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/upcloud
|
||||
when:
|
||||
- upcloud_csi_enabled
|
||||
tags:
|
||||
- upcloud-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/csi_driver/vsphere
|
||||
when:
|
||||
- vsphere_csi_enabled
|
||||
tags:
|
||||
- vsphere-csi-driver
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/persistent_volumes
|
||||
when:
|
||||
- persistent_volumes_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- persistent_volumes
|
||||
|
||||
- role: kubernetes-apps/snapshots
|
||||
when: inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- snapshots
|
||||
- csi-driver
|
||||
|
||||
- role: kubernetes-apps/container_runtimes
|
||||
when:
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- container-runtimes
|
||||
|
||||
- role: kubernetes-apps/container_engine_accelerator
|
||||
when: nvidia_accelerator_enabled
|
||||
tags:
|
||||
- container_engine_accelerator
|
||||
|
||||
- role: kubernetes-apps/cloud_controller/oci
|
||||
when:
|
||||
- cloud_provider is defined
|
||||
- cloud_provider == "oci"
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- oci
|
||||
|
||||
- role: kubernetes-apps/metallb
|
||||
when:
|
||||
- metallb_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- metallb
|
||||
|
||||
- role: kubernetes-apps/argocd
|
||||
when:
|
||||
- argocd_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- argocd
|
||||
|
||||
- role: kubernetes-apps/nfs_external_provisioner
|
||||
when:
|
||||
- nfs_external_provisioner_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- nfs_external_provisioner
|
||||
|
||||
- role: kubernetes-apps/jenkins
|
||||
when:
|
||||
- jenkins_enabled
|
||||
- inventory_hostname == groups['kube_control_plane'][0]
|
||||
tags:
|
||||
- jenkins
|
||||
Reference in New Issue
Block a user