Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 1 | # Copyright (c) 2022 VEXXHOST, Inc. |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 4 | # not use this file except in compliance with the License. You may obtain |
| 5 | # a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 11 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 12 | # License for the specific language governing permissions and limitations |
| 13 | # under the License. |
| 14 | |
guilhermesteinmuller | d946d7a | 2022-04-04 15:04:27 -0300 | [diff] [blame] | 15 | - name: Collect "ceph mon dump" output from a monitor |
| 16 | delegate_to: "{{ groups[ceph_csi_rbd_mons_group][0] }}" |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 17 | run_once: true |
guilhermesteinmuller | d946d7a | 2022-04-04 15:04:27 -0300 | [diff] [blame] | 18 | ansible.builtin.command: ceph mon dump -f json |
| 19 | changed_when: false |
| 20 | register: _ceph_mon_dump |
| 21 | |
| 22 | - name: Generate fact with list of Ceph monitors |
| 23 | run_once: true |
| 24 | ansible.builtin.set_fact: |
| 25 | ceph_monitors: "{{ _ceph_mon_dump.stdout | from_json | community.general.json_query('mons[*].addr') | map('regex_replace', '(.*):(.*)', '\\1') }}" |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 26 | |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 27 | - name: Create Ceph pool |
Mohammed Naser | 63b739d | 2022-05-19 21:51:31 -0400 | [diff] [blame] | 28 | delegate_to: "{{ groups[ceph_csi_rbd_mons_group][0] }}" |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 29 | vexxhost.atmosphere.ceph_pool: |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 30 | name: "{{ ceph_csi_rbd_pool }}" |
Mohammed Naser | 63b739d | 2022-05-19 21:51:31 -0400 | [diff] [blame] | 31 | rule_name: "{{ ceph_csi_rbd_rule_name | default(omit) }}" |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 32 | application: rbd |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 33 | pg_autoscale_mode: "on" |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 34 | |
Mohammed Naser | 4b24d9b | 2022-11-02 13:14:52 -0400 | [diff] [blame] | 35 | - name: Create user {{ ceph_csi_rbd_user }} |
Mohammed Naser | 63b739d | 2022-05-19 21:51:31 -0400 | [diff] [blame] | 36 | delegate_to: "{{ groups[ceph_csi_rbd_mons_group][0] }}" |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 37 | vexxhost.atmosphere.ceph_key: |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 38 | name: "{{ ceph_csi_rbd_user }}" |
| 39 | caps: |
| 40 | mon: profile rbd |
| 41 | mgr: profile rbd pool={{ ceph_csi_rbd_pool }} |
| 42 | osd: profile rbd pool={{ ceph_csi_rbd_pool }} |
| 43 | |
Mohammed Naser | 4b24d9b | 2022-11-02 13:14:52 -0400 | [diff] [blame] | 44 | - name: Retrieve keyring for {{ ceph_csi_rbd_user }} |
Mohammed Naser | 63b739d | 2022-05-19 21:51:31 -0400 | [diff] [blame] | 45 | delegate_to: "{{ groups[ceph_csi_rbd_mons_group][0] }}" |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 46 | vexxhost.atmosphere.ceph_key: |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 47 | name: "{{ ceph_csi_rbd_user }}" |
| 48 | state: info |
| 49 | output_format: json |
| 50 | register: _ceph_key |
| 51 | |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 52 | - name: Store keyring inside fact |
| 53 | ansible.builtin.set_fact: |
Mohammed Naser | b7b97d6 | 2022-03-12 16:30:00 -0500 | [diff] [blame] | 54 | _ceph_rbd_csi_ceph_keyring: "{{ _ceph_key.stdout | from_json | first }}" |
| 55 | |
Mohammed Naser | 511c3fa | 2022-03-17 17:54:10 -0400 | [diff] [blame] | 56 | - name: Deploy Helm chart |
Mohammed Naser | c8e1a45 | 2022-08-11 16:16:13 -0400 | [diff] [blame] | 57 | kubernetes.core.k8s: |
| 58 | state: present |
| 59 | definition: |
Mohammed Naser | c8e1a45 | 2022-08-11 16:16:13 -0400 | [diff] [blame] | 60 | - apiVersion: helm.toolkit.fluxcd.io/v2beta1 |
| 61 | kind: HelmRelease |
| 62 | metadata: |
| 63 | name: ceph-csi-rbd |
| 64 | namespace: kube-system |
| 65 | spec: |
| 66 | interval: 60s |
| 67 | chart: |
| 68 | spec: |
| 69 | chart: ceph-csi-rbd |
| 70 | version: 3.5.1 |
| 71 | sourceRef: |
| 72 | kind: HelmRepository |
| 73 | name: ceph |
| 74 | values: |
| 75 | csiConfig: |
| 76 | - clusterID: "{{ ceph_csi_rbd_ceph_fsid }}" |
| 77 | monitors: "{{ ceph_monitors }}" |
| 78 | nodeplugin: |
| 79 | httpMetrics: |
| 80 | containerPort: 8081 |
Mohammed Naser | 71ebfe8 | 2022-12-28 05:28:16 +0000 | [diff] [blame] | 81 | registrar: |
| 82 | image: |
| 83 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_node_driver_registrar', output='name') }}" |
| 84 | plugin: |
| 85 | image: |
| 86 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_rbd_plugin', output='name') }}" |
Mohammed Naser | c8e1a45 | 2022-08-11 16:16:13 -0400 | [diff] [blame] | 87 | provisioner: |
| 88 | nodeSelector: |
| 89 | openstack-control-plane: enabled |
Mohammed Naser | 71ebfe8 | 2022-12-28 05:28:16 +0000 | [diff] [blame] | 90 | provisioner: |
| 91 | image: |
| 92 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_rbd_provisioner', output='name') }}" |
| 93 | attacher: |
| 94 | image: |
| 95 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_rbd_attacher', output='name') }}" |
| 96 | resizer: |
| 97 | image: |
| 98 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_rbd_resizer', output='name') }}" |
| 99 | snapshotter: |
| 100 | image: |
| 101 | repository: "{{ lookup('vexxhost.atmosphere.image_ref', 'csi_rbd_snapshotter', output='name') }}" |
Mohammed Naser | c8e1a45 | 2022-08-11 16:16:13 -0400 | [diff] [blame] | 102 | storageClass: |
| 103 | create: true |
| 104 | name: general |
| 105 | annotations: |
| 106 | storageclass.kubernetes.io/is-default-class: "true" |
| 107 | clusterID: "{{ ceph_csi_rbd_ceph_fsid }}" |
| 108 | pool: "{{ ceph_csi_rbd_pool }}" |
| 109 | mountOptions: |
| 110 | - discard |
| 111 | secret: |
| 112 | create: true |
| 113 | userID: "{{ ceph_csi_rbd_id }}" |
| 114 | userKey: "{{ _ceph_rbd_csi_ceph_keyring.key }}" |