|
1 | 1 | ---
|
| 2 | +# with kraft combined mode, first install have to define clusterid, instead of getting it from dedicateed controllers |
| 3 | +- name: Check meta.properties |
| 4 | + when: kraft_combined |
| 5 | + ansible.builtin.stat: |
| 6 | + path: "{{ kafka_controller_final_properties['log.dirs'] }}/meta.properties" |
| 7 | + register: meta_properties |
| 8 | + |
| 9 | +- name: Initialize ClusterId |
| 10 | + when: |
| 11 | + - kraft_combined |
| 12 | + - not meta_properties.stat.exists |
| 13 | + run_once: true |
| 14 | + shell: "{{ binary_base_path }}/bin/kafka-storage random-uuid" |
| 15 | + environment: |
| 16 | + KAFKA_OPTS: "-Xlog:all=error -XX:+IgnoreUnrecognizedVMOptions" |
| 17 | + register: random_uuid |
| 18 | + |
| 19 | +- name: Set ClusterId |
| 20 | + when: |
| 21 | + - kraft_combined |
| 22 | + - not meta_properties.stat.exists |
| 23 | + run_once: true |
| 24 | + set_fact: |
| 25 | + clusterid: "{{ random_uuid.stdout }}" |
| 26 | + delegate_to: "{{ item }}" |
| 27 | + delegate_facts: true |
| 28 | + loop: "{{ groups.kafka_broker }}" |
| 29 | + |
| 30 | +# after first install in combined mode, get clusterid from one broker node |
2 | 31 | - name: Extract ClusterId from meta.properties on KRaft Controller
|
| 32 | + when: |
| 33 | + - kraft_combined |
| 34 | + - meta_properties.stat.exists |
| 35 | + run_once: true |
| 36 | + slurp: |
| 37 | + src: "{{ kafka_controller_final_properties['log.dirs'] }}/meta.properties" |
| 38 | + register: uuid_broker |
| 39 | + |
| 40 | +- name: Set ClusterId |
| 41 | + when: |
| 42 | + - kraft_combined |
| 43 | + - meta_properties.stat.exists |
| 44 | + run_once: true |
| 45 | + set_fact: |
| 46 | + clusterid: "{{ (uuid_broker['content'] | b64decode).partition('cluster.id=')[2].partition('\n')[0] }}" |
| 47 | + delegate_to: "{{ item }}" |
| 48 | + delegate_facts: true |
| 49 | + loop: "{{ groups.kafka_broker }}" |
| 50 | + |
| 51 | +# when combined mode, broker must declare scram users |
| 52 | +- name: Prepare SCRAM Users |
| 53 | + when: kraft_combined |
| 54 | + set_fact: |
| 55 | + scram_users_to_create: [] |
| 56 | + |
| 57 | +- name: Prepare SCRAM 512 Users |
| 58 | + when: |
| 59 | + - "'SCRAM-SHA-512' in kafka_broker_sasl_enabled_mechanisms" |
| 60 | + - kraft_combined |
| 61 | + set_fact: |
| 62 | + scram_users_to_create: "{{ scram_users_to_create + [ '--add-scram SCRAM-SHA-512=[name=\"'+ item.value['principal'] + '\",password=\"' + item.value['password'] + '\"]' ] }}" |
| 63 | + loop: "{{ sasl_scram_users_final|dict2items }}" |
| 64 | + loop_control: |
| 65 | + label: "{{ item.value['principal'] }}" |
| 66 | + |
| 67 | +- name: Create SCRAM 256 Users |
| 68 | + when: |
| 69 | + - "'SCRAM-SHA-256' in kafka_broker_sasl_enabled_mechanisms" |
| 70 | + - kraft_combined |
| 71 | + set_fact: |
| 72 | + scram_users_to_create: "{{ scram_users_to_create + [ '--add-scram SCRAM-SHA-256=[name=\"'+ item.value['principal'] + '\",password=\"' + item.value['password'] + '\"]' ] }}" |
| 73 | + loop: "{{ sasl_scram_users_final|dict2items }}" |
| 74 | + loop_control: |
| 75 | + label: "{{ item.value['principal'] }}" |
| 76 | + |
| 77 | +- name: Format Storage Directory |
| 78 | + when: kraft_combined |
| 79 | + shell: "{{ binary_base_path }}/bin/kafka-storage format -t {{ clusterid }} -c {{ kafka_broker.config_file }} --ignore-formatted {{ scram_users_to_create|join(' ') }}" |
| 80 | + register: format_meta |
| 81 | + |
| 82 | +# with dedicated controller nodes, clusterid is already defined onto controller nodes |
| 83 | +- name: Extract ClusterId from meta.properties on KRaft Controller |
| 84 | + when: not kraft_combined |
| 85 | + run_once: true |
3 | 86 | slurp:
|
4 | 87 | src: "{{ kafka_controller_final_properties['log.dirs'] }}/meta.properties"
|
5 | 88 | delegate_to: "{{ groups.kafka_controller[0] }}"
|
6 | 89 | register: uuid_broker
|
7 | 90 |
|
| 91 | +- name: Set ClusterId |
| 92 | + when: not kraft_combined |
| 93 | + run_once: true |
| 94 | + set_fact: |
| 95 | + clusterid: "{{ (uuid_broker['content'] | b64decode).partition('cluster.id=')[2].partition('\n')[0] }}" |
| 96 | + delegate_to: "{{ item }}" |
| 97 | + delegate_facts: true |
| 98 | + loop: "{{ groups.kafka_broker }}" |
| 99 | + |
8 | 100 | - name: Format Storage Directory
|
| 101 | + when: not kraft_combined |
9 | 102 | shell: "{{ binary_base_path }}/bin/kafka-storage format -t {{ clusterid }} -c {{ kafka_broker.config_file }} --ignore-formatted"
|
10 | 103 | register: format_meta
|
11 |
| - vars: |
12 |
| - clusterid: "{{ (uuid_broker['content'] | b64decode).partition('cluster.id=')[2].partition('\n')[0] }}" |
|
0 commit comments