-
Notifications
You must be signed in to change notification settings - Fork 2
/
provision.yml
82 lines (76 loc) · 2.48 KB
/
provision.yml
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
---
# create gluster server and client instances
- name: create gluster instances
hosts: localhost
vars_files:
- group_vars/gluster/vars
- group_vars/gluster/secret_vars
vars:
count: '{{ cluster_size - 1 }}'
tasks:
- name: creating gluster servers
linode.cloud.instance:
label: '{{ instance_prefix }}{{ item | int + 1 }}-{{ uuid }}'
api_token: '{{ token }}'
type: '{{ type }}'
region: '{{ region }}'
image: '{{ image }}'
root_pass: '{{ root_pass }}'
authorized_keys: '{{ ssh_keys }}'
private_ip: true
stackscript_id: 1350790
ua_prefix: 'marketplace-glusterfs-occ'
tags: '{{ linode_tags }}'
state: present
with_sequence: count='{{ count }}'
- name: get info about the instances
linode.cloud.instance_info:
api_token: '{{ token }}'
label: '{{ instance_prefix }}{{ item }}-{{ uuid }}'
register: info
with_sequence: count='{{ cluster_size }}'
- name: update group_vars
blockinfile:
path: ./group_vars/gluster/vars
marker: "# {mark} INSTANCE VARS"
block: |
#jinja2: trim_blocks:False
gluster_data:
server:
{%- for count in range(cluster_size) %}
- gluster{{ count + 1 }}:
instance:
hostname: gluster{{ count + 1 }}
ip_pub1: {{ info.results[count].instance.ipv4[0] }}
ip_priv1: {{ info.results[count].instance.ipv4[1] }}
{%- endfor %}
{% if client_ips is defined %}
client:
{% set count = namespace(value=0) %}
{%- for ip in client_ips %}
- client{{ count.value | int + 1 }}:
instance:
hostname: client{{ count.value | int + 1 }}
ip_pub1: {{ ip }}
{%- set count.value = count.value + 1 %}
{%- endfor %}
{% endif %}
- name: add gluster nodes to inventory
blockinfile:
path: ./hosts
marker: "# {mark} GLUSTER INSTANCES"
block: |
#jinja2: trim_blocks:False
[gluster_servers]
localhost ansible_connection=local user=root
{%- for count in range(cluster_size - 1) %}
{{ info.results[count + 1].instance.ipv4[0] }}
{%- endfor %}
- name: wait for port 22 to become open
wait_for:
port: 22
host: '{{ item.instance.ipv4[0] }}'
search_regex: OpenSSH
delay: 10
connection: local
with_items: "{{ info.results }}"