blob: f4e08259da77b775c8a2e4d5fc5af0cd1a8848c3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
|
---
# file: roles/consul/tasks/main.yaml
- name: Inst - Update Package Cache (APT)
apt:
update_cache: true
cache_valid_time: 3600
when:
- ansible_distribution|lower == 'ubuntu'
tags:
- consul-inst-prerequisites
- name: Inst - Prerequisites
package:
name: "{{ packages | flatten(levels=1) }}"
state: latest
tags:
- consul-inst-prerequisites
- name: Conf - Add Consul Group
group:
name: "{{ consul_group }}"
state: "{{ consul_group_state }}"
tags:
- consul-conf-user
- name: Conf - Add Consul user
user:
name: "{{ consul_user }}"
group: "{{ consul_group }}"
state: "{{ consul_user_state }}"
system: true
tags:
- consul-conf-user
- name: Inst - Clean Consul
file:
path: "{{ consul_inst_dir }}/consul"
state: "absent"
tags:
- consul-inst-package
- name: Inst - Download Consul
get_url:
url: "{{ consul_zip_url }}"
dest: "{{ consul_inst_dir }}/{{ consul_pkg }}"
tags:
- consul-inst-package
- name: Inst - Unarchive Consul
unarchive:
src: "{{ consul_inst_dir }}/{{ consul_pkg }}"
dest: "{{ consul_inst_dir }}/"
creates: "{{ consul_inst_dir }}/consul"
remote_src: true
tags:
- consul-inst-package
- name: Inst - Consul
copy:
src: "{{ consul_inst_dir }}/consul"
dest: "{{ consul_bin_dir }}"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
force: true
mode: 0755
remote_src: true
tags:
- consul-inst-package
- name: Conf - Create Directories "{{ consul_data_dir }}"
file:
dest: "{{ consul_data_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
tags:
- consul-conf
- name: Conf - Create Directories "{{ consul_ssl_dir }}"
file:
dest: "{{ consul_ssl_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
tags:
- consul-conf
- name: Conf - Create Config Directory
file:
dest: "{{ consul_config_dir }}"
state: directory
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0755
tags:
- consul-conf
- name: Conf - Base Configuration
template:
src: base.hcl.j2
dest: "{{ consul_config_dir }}/base.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Ports Configuration
template:
src: ports.hcl.j2
dest: "{{ consul_config_dir }}/ports.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Telemetry Configuration
template:
src: telemetry.hcl.j2
dest: "{{ consul_config_dir }}/telemetry.hcl"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
tags:
- consul-conf
- name: Conf - Services Configuration
template:
src: services.json.j2
dest: "{{ consul_config_dir }}/services.json"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0644
when:
- consul_services
tags:
- consul-conf
- name: Conf - Copy Certificates And Keys
copy:
content: "{{ item.src }}"
dest: "{{ item.dest }}"
owner: "{{ consul_user }}"
group: "{{ consul_group }}"
mode: 0600
no_log: true
loop: "{{ consul_certificates | flatten(levels=1) }}"
tags:
- consul-conf
- name: Conf - Stop Systemd-resolved
systemd:
daemon_reload: true
enabled: false
name: "systemd-resolved"
state: "{{ systemd_resolved_state }}"
tags:
- consul-conf
- name: Conf - System.d Script
template:
src: "consul_systemd.service.j2"
dest: "/lib/systemd/system/consul.service"
owner: "root"
group: "root"
mode: 0644
notify:
- "Restart Consul"
- "Restart Nomad"
tags:
- consul-conf
- meta: flush_handlers
|