mirror of
https://gitea.0xace.cc/ansible-galaxy/consul.git
synced 2025-04-05 13:41:56 +00:00
first commit
This commit is contained in:
commit
0acba68443
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.galaxy_install_info
|
30
defaults/main.yaml
Normal file
30
defaults/main.yaml
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
consul_version: 1.12.2
|
||||||
|
consul_config_path: "/etc/consul.d"
|
||||||
|
consul_data_path: "/opt/consul"
|
||||||
|
consul_user: consul
|
||||||
|
consul_group: consul
|
||||||
|
consul_install_repo: yes
|
||||||
|
|
||||||
|
consul_cluster_group: consul
|
||||||
|
consul_server_group: consul_server
|
||||||
|
consul_agent_group: consul_agent
|
||||||
|
|
||||||
|
consul_config: []
|
||||||
|
consul_default_config:
|
||||||
|
server: "{{ true if inventory_hostname in groups[consul_server_group] else false }}"
|
||||||
|
ui_config:
|
||||||
|
enabled: "{{ true if inventory_hostname in groups[consul_server_group] else false }}"
|
||||||
|
log_level: info
|
||||||
|
retry_join: "{{ groups[consul_server_group] | default([])}}"
|
||||||
|
retry_interval: 30s
|
||||||
|
datacenter: "main"
|
||||||
|
bootstrap_expect: "{{ groups[consul_server_group]|length|int if inventory_hostname in groups[consul_server_group] else omit }}"
|
||||||
|
performance:
|
||||||
|
raft_multiplier: 1
|
||||||
|
acl:
|
||||||
|
enabled: false
|
||||||
|
default_policy: deny
|
||||||
|
down_policy: extend-cache
|
||||||
|
enable_token_persistence: true
|
||||||
|
|
||||||
|
is_virtualenv: "{{ lookup('env','VIRTUAL_ENV') | default('') }}"
|
8
handlers/main.yaml
Normal file
8
handlers/main.yaml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
- block:
|
||||||
|
- name: Restart consul
|
||||||
|
throttle: 1
|
||||||
|
ansible.builtin.systemd:
|
||||||
|
state: restarted
|
||||||
|
name: consul
|
||||||
|
daemon_reload: yes
|
||||||
|
when: not consul_setup.changed
|
0
meta/main.yaml
Normal file
0
meta/main.yaml
Normal file
45
tasks/Debian/main.yaml
Normal file
45
tasks/Debian/main.yaml
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
- name: Add gpg package
|
||||||
|
apt:
|
||||||
|
name: gpg
|
||||||
|
|
||||||
|
- name: Add gpg keys for consul
|
||||||
|
ansible.builtin.apt_key:
|
||||||
|
url: "{{ item.url }}"
|
||||||
|
keyring: "{{ item.keyring }}"
|
||||||
|
loop: "{{ consul_apt_key }}"
|
||||||
|
|
||||||
|
- name: Add Hashicorp repository
|
||||||
|
apt_repository:
|
||||||
|
repo: "{{ item.repo }}"
|
||||||
|
state: present
|
||||||
|
filename: "{{ item.filename }}"
|
||||||
|
update_cache: yes
|
||||||
|
loop: "{{ consul_apt_repository }}"
|
||||||
|
|
||||||
|
- name: Check if Consul is installed
|
||||||
|
ansible.builtin.shell: dpkg-query -l {{ consul_package_name }} 2>&1 | grep {{ consul_version }}
|
||||||
|
ignore_errors: True
|
||||||
|
register: is_consul
|
||||||
|
changed_when: is_consul.rc != 0
|
||||||
|
failed_when: False
|
||||||
|
|
||||||
|
- name: Mask Consul before install
|
||||||
|
ansible.builtin.systemd:
|
||||||
|
name: "{{ consul_package_name }}"
|
||||||
|
masked: yes
|
||||||
|
when: is_consul.rc != 0
|
||||||
|
|
||||||
|
- name: "Install {{ consul_package_name }}-{{ consul_version }}"
|
||||||
|
apt:
|
||||||
|
name: "{{ consul_package }}"
|
||||||
|
update_cache: yes
|
||||||
|
register: consul_setup
|
||||||
|
when: is_consul.rc != 0
|
||||||
|
|
||||||
|
- name: Fix "/etc/consul.d/consul.env"
|
||||||
|
copy:
|
||||||
|
content: ""
|
||||||
|
dest: /etc/consul.d/consul.env
|
||||||
|
owner: consul
|
||||||
|
group: consul
|
||||||
|
|
35
tasks/RedHat/main.yaml
Normal file
35
tasks/RedHat/main.yaml
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
- name: Add Hashicorp repository
|
||||||
|
yum_repository:
|
||||||
|
name: hashicorp
|
||||||
|
description: Hashicorp Stable - $basearch
|
||||||
|
file: hashicorp
|
||||||
|
baseurl: https://rpm.releases.hashicorp.com/RHEL/$releasever/$basearch/stable
|
||||||
|
enabled: no
|
||||||
|
gpgcheck: yes
|
||||||
|
gpgkey: https://rpm.releases.hashicorp.com/gpg
|
||||||
|
when: consul_install_repo
|
||||||
|
|
||||||
|
- name: "Install {{ consul_package_name }}-{{ consul_version }} from official repository"
|
||||||
|
dnf:
|
||||||
|
name: "{{ consul_package }}"
|
||||||
|
state: present
|
||||||
|
disable_gpg_check: yes
|
||||||
|
enablerepo: hashicorp
|
||||||
|
update_cache: yes
|
||||||
|
register: consul_setup
|
||||||
|
when: consul_install_repo
|
||||||
|
|
||||||
|
- name: "Install {{ consul_package_name }}-{{ consul_version }}"
|
||||||
|
dnf:
|
||||||
|
name: "{{ consul_package }}"
|
||||||
|
state: present
|
||||||
|
disable_gpg_check: yes
|
||||||
|
register: consul_setup
|
||||||
|
when: not consul_install_repo
|
||||||
|
|
||||||
|
- name: Fix "/etc/consul.d/consul.env"
|
||||||
|
copy:
|
||||||
|
content: ""
|
||||||
|
dest: /etc/consul.d/consul.env
|
||||||
|
owner: consul
|
||||||
|
group: consul
|
52
tasks/bootstrap.yaml
Normal file
52
tasks/bootstrap.yaml
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
- name: Bootstrap encrypt
|
||||||
|
block:
|
||||||
|
- name: Get gossip encryption key on previously boostrapped server
|
||||||
|
block:
|
||||||
|
- name: Check for gossip encryption key on previously boostrapped server
|
||||||
|
slurp:
|
||||||
|
src: "{{ consul_config_path }}/consul.json"
|
||||||
|
register: consul_config_b64
|
||||||
|
ignore_errors: true
|
||||||
|
|
||||||
|
- name: Deserialize existing configuration
|
||||||
|
set_fact:
|
||||||
|
consul_config_local: "{{ consul_config_b64.content | b64decode | from_json }}"
|
||||||
|
when: consul_config_b64.content is defined
|
||||||
|
|
||||||
|
- name: Save gossip encryption key from existing configuration
|
||||||
|
set_fact:
|
||||||
|
consul_raw_key: "{{ consul_config_local.encrypt }}"
|
||||||
|
delegate_to: "{{ item }}"
|
||||||
|
delegate_facts: true
|
||||||
|
run_once: true
|
||||||
|
loop: "{{ ansible_play_hosts_all }}"
|
||||||
|
when: consul_config_local.encrypt is defined and consul_config_local.encrypt | length != 0
|
||||||
|
|
||||||
|
no_log: false
|
||||||
|
when:
|
||||||
|
- consul_config.encrypt is not defined or consul_config.encrypt | length == 0
|
||||||
|
- cluster_node_list != 0
|
||||||
|
- hostvars[inventory_hostname]['ansible_host'] in cluster_node_list
|
||||||
|
|
||||||
|
- name: Generate new key if none was found
|
||||||
|
block:
|
||||||
|
- name: Generate gossip encryption key
|
||||||
|
shell: "consul keygen"
|
||||||
|
register: consul_keygen
|
||||||
|
when:
|
||||||
|
- consul_raw_key is not defined
|
||||||
|
|
||||||
|
- name: Save gossip encryption key as fact
|
||||||
|
set_fact:
|
||||||
|
consul_raw_key: "{{ consul_keygen.stdout }}"
|
||||||
|
delegate_to: "{{ item }}"
|
||||||
|
delegate_facts: true
|
||||||
|
loop: "{{ ansible_play_hosts_all }}"
|
||||||
|
when:
|
||||||
|
- hostvars[inventory_hostname]['consul_raw_key'] is not defined
|
||||||
|
no_log: false
|
||||||
|
run_once: true
|
||||||
|
when:
|
||||||
|
- consul_config.encrypt is not defined or consul_config.encrypt | length == 0
|
||||||
|
|
||||||
|
no_log: false
|
34
tasks/config.yaml
Normal file
34
tasks/config.yaml
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
---
|
||||||
|
- name: Merge encrypt key with config for Consul
|
||||||
|
set_fact:
|
||||||
|
consul_config: "{{ consul_config | combine(consul_config_encrypt, recursive=true) }}"
|
||||||
|
vars:
|
||||||
|
consul_config_encrypt:
|
||||||
|
encrypt: "{{ consul_raw_key }}"
|
||||||
|
when:
|
||||||
|
- consul_config.encrypt is not defined
|
||||||
|
|
||||||
|
- name: Merge config for Consul
|
||||||
|
set_fact:
|
||||||
|
consul_config_combined: "{{ consul_default_config | combine(consul_config, recursive=true) }}"
|
||||||
|
|
||||||
|
- name: Propagate consul config
|
||||||
|
copy:
|
||||||
|
content: "{{ consul_config_combined | to_nice_json }}"
|
||||||
|
dest: "{{ consul_config_path }}/consul.json"
|
||||||
|
owner: "{{ consul_user }}"
|
||||||
|
group: "{{ consul_group }}"
|
||||||
|
mode: 0644
|
||||||
|
register: consul_config_file
|
||||||
|
notify: Restart consul
|
||||||
|
|
||||||
|
- name: Remove old files
|
||||||
|
file:
|
||||||
|
path: "{{ item }}"
|
||||||
|
state: absent
|
||||||
|
loop:
|
||||||
|
- "{{ consul_config_path }}/config.json"
|
||||||
|
- "{{ consul_data_path }}/serf/local.keyring"
|
||||||
|
- "{{ consul_data_path }}/serf/remote.keyring"
|
||||||
|
- "{{ consul_data_path }}/serf/local.snapshot"
|
||||||
|
when: consul_config_file.changed
|
3
tasks/join.yaml
Normal file
3
tasks/join.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
---
|
||||||
|
- name: "Join new node to existing cluster"
|
||||||
|
command: "consul join {{ cluster_node_list | join(' ') }}"
|
42
tasks/main.yaml
Normal file
42
tasks/main.yaml
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
- name: Make sure handlers are flushed immediately
|
||||||
|
meta: flush_handlers
|
||||||
|
|
||||||
|
- name: Load a variable file based on the OS type
|
||||||
|
include_vars: "{{ lookup('first_found', params) }}"
|
||||||
|
vars:
|
||||||
|
params:
|
||||||
|
files:
|
||||||
|
- "{{ ansible_facts['distribution'] }}.yaml"
|
||||||
|
- "{{ ansible_facts['os_family'] }}.yaml"
|
||||||
|
paths:
|
||||||
|
- "vars"
|
||||||
|
|
||||||
|
- name: Consul cluster pre-check
|
||||||
|
include_tasks: pre_check.yaml
|
||||||
|
when: inventory_hostname in groups[consul_server_group]
|
||||||
|
|
||||||
|
- name: "Install Consul for {{ ansible_facts['os_family'] }}"
|
||||||
|
include_tasks: "{{ ansible_facts['os_family'] }}/main.yaml"
|
||||||
|
|
||||||
|
- name: Bootstrap Consul
|
||||||
|
include_tasks: bootstrap.yaml
|
||||||
|
when: inventory_hostname in groups[consul_server_group]
|
||||||
|
|
||||||
|
- name: Create Consul configuration
|
||||||
|
import_tasks: config.yaml
|
||||||
|
|
||||||
|
- name: Enable and start Consul
|
||||||
|
systemd:
|
||||||
|
daemon_reload: true
|
||||||
|
name: consul
|
||||||
|
enabled: true
|
||||||
|
state: started
|
||||||
|
masked: no
|
||||||
|
tags: consul, consul_start
|
||||||
|
|
||||||
|
- name: Join new server node to cluster
|
||||||
|
import_tasks: join.yaml
|
||||||
|
when:
|
||||||
|
- hostvars[inventory_hostname]['ansible_host'] not in cluster_node_list
|
||||||
|
- cluster_node_list | length != 0
|
||||||
|
- inventory_hostname in groups[consul_server_group]
|
33
tasks/pre_check.yaml
Normal file
33
tasks/pre_check.yaml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
- block:
|
||||||
|
- name: Set var for cluster nodes list
|
||||||
|
set_fact:
|
||||||
|
cluster_node_list: []
|
||||||
|
|
||||||
|
- name: Get cluster nodes
|
||||||
|
command: curl http://127.0.0.1:8500/v1/status/peers
|
||||||
|
environment:
|
||||||
|
no_proxy: 127.0.0.1
|
||||||
|
register: cluster_nodes
|
||||||
|
changed_when: false
|
||||||
|
no_log: true
|
||||||
|
|
||||||
|
- name: Print cluster nodes
|
||||||
|
debug:
|
||||||
|
msg: "{{ cluster_nodes.stdout }}"
|
||||||
|
|
||||||
|
- name: Print cluster nodes
|
||||||
|
debug:
|
||||||
|
msg: "{{ item }}"
|
||||||
|
loop: "{{ cluster_nodes.stdout | from_json }}"
|
||||||
|
|
||||||
|
- name: Merge cluster nodes list
|
||||||
|
set_fact:
|
||||||
|
cluster_node_list: "{{ cluster_node_list + [item|split(':')|first] }}"
|
||||||
|
loop: "{{ cluster_nodes.stdout | from_json }}"
|
||||||
|
|
||||||
|
- name: Print cluster nodes list
|
||||||
|
debug:
|
||||||
|
msg: "{{ cluster_node_list }}"
|
||||||
|
|
||||||
|
run_once: true
|
||||||
|
ignore_errors: yes
|
8
vars/Debian.yaml
Normal file
8
vars/Debian.yaml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
consul_package: "{{ consul_package_name }}={{ consul_version }}"
|
||||||
|
consul_apt_key:
|
||||||
|
- name: com.hashicorp.gpg
|
||||||
|
url: "https://apt.releases.hashicorp.com/gpg"
|
||||||
|
keyring: /etc/apt/trusted.gpg.d/com.hashicorp.gpg
|
||||||
|
consul_apt_repository:
|
||||||
|
- repo: deb [arch=amd64] https://apt.releases.hashicorp.com {{ ansible_distribution_release }} main
|
||||||
|
filename: hashicorp
|
1
vars/RedHat.yaml
Normal file
1
vars/RedHat.yaml
Normal file
@ -0,0 +1 @@
|
|||||||
|
consul_package: "{{ consul_package_name }}-{{ consul_version }}"
|
1
vars/main.yaml
Normal file
1
vars/main.yaml
Normal file
@ -0,0 +1 @@
|
|||||||
|
consul_package_name: consul
|
Loading…
x
Reference in New Issue
Block a user