template-replicated.cfg.in 12.3 KB
Newer Older
1
{% macro replicate(namebase, nbbackup, typeexport, typeimport, heriteLeader='', heriteBackup='', slapparameter_dict={}, monitor_parameter_dict={}) %}
2 3

{% set sla_parameter_dict = {} -%}
4 5 6
{% set monitor_dict = monitor_parameter_dict.get('parameter', {}) -%}
{% set monitor_return = ' '.join(monitor_parameter_dict.get('return', [])) -%}
{% set monitor_url_list = [] -%}
7 8
# prepare sla-parameters
{% if slapparameter_dict is defined -%}
9
{%   for key in list(slapparameter_dict.keys()) -%}
10 11 12 13 14 15
{%     if key.startswith('-sla-') -%}
{%       do sla_parameter_dict.__setitem__(key, slapparameter_dict.pop(key)) -%}
{%     endif -%}
{%   endfor -%}
{% endif -%}

16

17 18 19 20
[resilient-directory]
recipe = slapos.cookbook:mkdirectory
home = ${buildout:directory}
etc = ${:home}/etc
21
bin = ${:home}/bin
22 23


24 25
## Tells the Backupable recipe that we want a backup
[resilient]
26
recipe = slapos.cookbook:request
27
config-namebase = {{namebase}}
28
software-url = ${slap-connection:software-release-url}
29 30 31 32 33 34 35

[request-{{namebase}}]
<= resilient
   slap-connection
   {{heriteLeader}}
software-type = {{typeexport}}
name = {{namebase}}0
36
return = ssh-public-key resilient-ssh-url notification-id ip {{ monitor_return }}
37

Marco Mariani's avatar
Marco Mariani committed
38
config-number = 0
39 40
config-authorized-key = {% for id in range(1,nbbackup|int) %} ${request-pbs-{{namebase}}-{{id}}:connection-ssh-key}{% endfor %}
config-notify = {% for id in range(1,nbbackup|int) %} ${request-pbs-{{namebase}}-{{id}}:connection-notification-url}{% endfor %}
41
config-name = {{namebase}}0
42
# Bubble up all the instance parameters to the requested export instance.
43
{% if slapparameter_dict is defined %}
44
{% for parameter_name, parameter_value in six.iteritems(slapparameter_dict) %}
45
config-{{ parameter_name }} = {{ dumps(parameter_value) }}
46
{% endfor %}
47
{% endif %}
48
{% for key, value in six.iteritems(monitor_dict) -%}
49 50
config-{{ key }} = {{ value }}
{% endfor -%}
51 52 53
{% if sla_parameter_dict == {} -%}
sla-mode = unique_by_network
{% else %}
54 55 56 57 58 59 60 61
{%   set sla_key_main = "-sla-%s%s-" % (namebase, 0) -%}
{%   set sla_key_secondary = "-sla-%s-" % (0) -%}
{%   set sla_key_main_length = sla_key_main | length -%}
{%   set sla_key_secondary_length = sla_key_secondary | length -%}
{%   set sla_dict = {} -%}
{%   for key in sla_parameter_dict.keys() -%}
{%     if key.startswith(sla_key_main) -%}
{%       do sla_dict.__setitem__(key[sla_key_main_length:], sla_parameter_dict.get(key)) -%}
62
{%     elif key.startswith(sla_key_secondary) and key[sla_key_secondary_length:] not in sla_dict -%}
63 64 65
{%         do sla_dict.__setitem__(key[sla_key_secondary_length:], sla_parameter_dict.get(key)) -%}
{%     endif -%}
{%   endfor -%}
66
{%   for key, value in six.iteritems(sla_dict) -%}
67
sla-{{ key }} = {{ value }}
68
{%   endfor -%}
69
{% endif -%}
70

71 72 73 74
{% if 'monitor-base-url' in monitor_return and not monitor_parameter_dict.get('set-monitor-url', False) -%}
{% do monitor_url_list.append('${request-' ~ namebase ~ ':connection-monitor-base-url}') -%}
{% endif -%}

75 76 77 78 79 80 81 82 83 84 85
{% for id in range(1,nbbackup|int) %}

[request-{{namebase}}-pseudo-replicating-{{id}}]
<= slap-connection
   resilient
   {{heriteBackup}}
recipe = slapos.cookbook:request
name = {{namebase}}{{id}}

software-url = ${slap-connection:software-release-url}
software-type = {{typeimport}}
86
return = ssh-public-key resilient-ssh-url notification-url ip takeover-url takeover-password  {{ monitor_return }}
87

88
pbs-notification-id = ${slap-connection:computer-id}-${slap-connection:partition-id}-{{namebase}}-{{id}}-push
89

90 91 92
{% for extra_parameter_for_pseudo_replicating_instance in ["software-root", "buildout-shared-folder"] %}
{% if slapparameter_dict.get(extra_parameter_for_pseudo_replicating_instance) %}
config-{{ extra_parameter_for_pseudo_replicating_instance }} = {{ slapparameter_dict.get(extra_parameter_for_pseudo_replicating_instance) }}
93
{% endif %}
94
{% endfor %}
95

Marco Mariani's avatar
Marco Mariani committed
96
config-number = {{id}}
97
config-name = {{namebase}}{{id}}
98 99
config-authorized-key = ${request-pbs-{{namebase}}-{{id}}:connection-ssh-key}
config-on-notification = ${request-pbs-{{namebase}}-{{id}}:connection-feeds-url}${:pbs-notification-id}
100
{% for key, value in six.iteritems(monitor_dict) -%}
101 102
config-{{ key }} = {{ value }}
{% endfor -%}
103 104 105
{% if sla_parameter_dict == {} -%}
sla-mode = unique_by_network
{% else %}
106 107 108 109 110 111 112 113
{%   set sla_key_main = "-sla-%s%s-" % (namebase, id) -%}
{%   set sla_key_secondary = "-sla-%s-" % (id) -%}
{%   set sla_key_main_length = sla_key_main | length -%}
{%   set sla_key_secondary_length = sla_key_secondary | length -%}
{%   set sla_dict = {} -%}
{%   for key in sla_parameter_dict.keys() -%}
{%     if key.startswith(sla_key_main) -%}
{%       do sla_dict.__setitem__(key[sla_key_main_length:], sla_parameter_dict.get(key)) -%}
114
{%     elif key.startswith(sla_key_secondary) and key[sla_key_secondary_length:] not in sla_dict -%}
115 116 117
{%         do sla_dict.__setitem__(key[sla_key_secondary_length:], sla_parameter_dict.get(key)) -%}
{%     endif -%}
{%   endfor -%}
118
{%   for key, value in six.iteritems(sla_dict) -%}
119
sla-{{ key }} = {{ value }}
120
{%   endfor -%}
121
{% endif %}
122

123
[publish-connection-information]
124
feed-url-{{namebase}}-{{id}}-push = ${request-pbs-{{namebase}}-{{id}}:connection-feeds-url}${request-{{namebase}}-pseudo-replicating-{{id}}:pbs-notification-id}
125 126
takeover-{{namebase}}-{{id}}-url = ${request-{{namebase}}-pseudo-replicating-{{id}}:connection-takeover-url}
takeover-{{namebase}}-{{id}}-password = ${request-{{namebase}}-pseudo-replicating-{{id}}:connection-takeover-password}
127

128 129 130 131
{% if 'monitor-base-url' in monitor_return -%}
{% do monitor_url_list.append('${request-' ~ namebase ~ '-pseudo-replicating-' ~ id ~ ':connection-monitor-base-url}') -%}
{% endif -%}

132
{% endfor -%}
133

134

135

136
[resilient-request-{{namebase}}-public-key-promise-bin]
137 138 139 140
# Check that public-key-value parameter exists and is not empty
# XXX: maybe we should consider empty values to be non-nexistent.
recipe = collective.recipe.template
# XXX: don't use system executable
141 142
input = inline:#!/bin/bash
  PUBLIC_KEY_CONTENT="${request-{{namebase}}:connection-ssh-public-key}"
143
  if [[ ! -n "$PUBLIC_KEY_CONTENT" || "$PUBLIC_KEY_CONTENT" == *None* ]]; then
144 145
    exit 1
  fi
146
output = ${resilient-directory:bin}/resilient-request-{{namebase}}-public-key
147 148
mode = 700

149 150
[resilient-request-{{namebase}}-public-key-promise]
<= monitor-promise-base
151
promise = check_command_execute
152 153 154 155
name = resilient-request-{{namebase}}-public-key.py
config-command = ${resilient-request-{{namebase}}-public-key-promise-bin:output}


156
{% for id in range(1,nbbackup|int) %}
157

158
[resilient-request-{{namebase}}-pseudo-replicating-{{id}}-public-key-promise-bin]
159 160 161 162
# Check that public-key-value parameter exists and is not empty
# XXX: maybe we should consider empty values to be non-nexistent.
recipe = collective.recipe.template
# XXX: don't use system executable
163 164
input = inline:#!/bin/bash
  PUBLIC_KEY_CONTENT="${request-{{namebase}}-pseudo-replicating-{{id}}:connection-ssh-public-key}"
165
  if [[ ! -n "$PUBLIC_KEY_CONTENT" || "$PUBLIC_KEY_CONTENT" == *None* ]]; then
166 167
    exit 1
  fi
168
output = ${resilient-directory:bin}/resilient-request-{{namebase}}-pseudo-replicating-{{id}}-public-key
169 170
mode = 700

171 172
[resilient-request-{{namebase}}-pseudo-replicating-{{id}}-public-key-promise]
<= monitor-promise-base
173
promise = check_command_execute
174 175 176
name = resilient-request-{{namebase}}-pseudo-replicating-{{id}}-public-key.py
config-command = ${resilient-request-{{namebase}}-pseudo-replicating-{{id}}-public-key-promise-bin:output}

177 178 179 180
{% endfor %}



181
## The PBS and their push / pull shared instances
182 183 184
## Adding a PBS provides resiliency
## Adding a backup server provides availability

Cédric de Saint Martin's avatar
Cédric de Saint Martin committed
185
## Having 3 backups pulling from the same PBS provides
186 187
##only availability, not resiliency

188
[request-pbs-common]
189 190 191 192
<= slap-connection
recipe = slapos.cookbook:request
software-url = ${slap-connection:software-release-url}
software-type = pull-backup
193 194 195 196 197 198

{% for id in range(1,nbbackup|int) %}

[request-pbs-{{namebase}}-{{id}}]
<= request-pbs-common
name = PBS ({{namebase}} / {{id}})
199
config-monitor-title = PBS ${slap-connection:computer-id}-{{namebase}}-{{id}}
200
{% for key, value in six.iteritems(monitor_dict) -%}
201 202 203
config-{{ key }} = {{ value }}
{% endfor -%}
return = ssh-key notification-url feeds-url  {{ monitor_return }}
204
shared = false
205 206 207
{% if sla_parameter_dict == {} -%}
sla-mode = unique_by_network
{% else %}
208 209 210 211 212 213 214 215
{%   set sla_key_main = "-sla-%s%s-" % ("pbs", id) -%}
{%   set sla_key_secondary = "-sla-%s-" % (id) -%}
{%   set sla_key_main_length = sla_key_main | length -%}
{%   set sla_key_secondary_length = sla_key_secondary | length -%}
{%   set sla_dict = {} -%}
{%   for key in sla_parameter_dict.keys() -%}
{%     if key.startswith(sla_key_main) -%}
{%       do sla_dict.__setitem__(key[sla_key_main_length:], sla_parameter_dict.get(key)) -%}
216
{%     elif key.startswith(sla_key_secondary) and key[sla_key_secondary_length:] not in sla_dict -%}
217 218 219
{%         do sla_dict.__setitem__(key[sla_key_secondary_length:], sla_parameter_dict.get(key)) -%}
{%     endif -%}
{%   endfor -%}
220
{%   for key, value in six.iteritems(sla_dict) -%}
221
sla-{{ key }} = {{ value }}
222
{%   endfor %}
223 224
{% endif %}

225
[resilient-request-pbs-{{namebase}}-{{id}}-public-key-promise-bin]
226 227 228 229
# Check that public-key-value parameter exists and is not empty
# XXX: maybe we should consider empty values to be non-nexistent.
recipe = collective.recipe.template
# XXX: don't use system executable
230 231
input = inline:#!/bin/bash
  PUBLIC_KEY_CONTENT="${request-pbs-{{namebase}}-{{id}}:connection-ssh-key}"
232
  if [[ ! -n "$PUBLIC_KEY_CONTENT" || "$PUBLIC_KEY_CONTENT" == *None* ]]; then
233 234
    exit 1
  fi
235
output = ${resilient-directory:bin}/resilient-request-pbs-{{namebase}}-{{id}}-public-key
236 237
mode = 700

238 239
[resilient-request-pbs-{{namebase}}-{{id}}-public-key-promise]
<= monitor-promise-base
240
promise = check_command_execute
241
name = resilient-request-pbs-{{namebase}}-{{id}}-public-key.py
242
config-command = ${resilient-request-pbs-{{namebase}}-{{id}}-public-key-promise-bin:output}
243 244

[request-pull-backup-server-{{namebase}}-{{id}}]
245
<= request-pbs-common
246
name = PBS {{id}} pulling from ${request-{{namebase}}:name}
247
config-url = ${request-{{namebase}}:connection-resilient-ssh-url}
248 249 250 251 252
config-type = pull
config-server-key = ${request-{{namebase}}:connection-ssh-public-key}
config-on-notification = ${request-{{namebase}}:connection-notification-id}
config-notify = ${request-pbs-{{namebase}}-{{id}}:connection-notification-url}
config-notification-id = ${slap-connection:computer-id}-${slap-connection:partition-id}-{{namebase}}-{{id}}-pull
253
config-name = ${slap-connection:computer-id}-${slap-connection:partition-id}-{{namebase}}-{{id}}
254
config-title = Pulling from {{namebase}}
255
config-remove-backup-older-than = {{ slapparameter_dict.get('remove-backup-older-than', '2W') }}
256
shared = true
257
sla-instance_guid = ${request-pbs-{{namebase}}-{{id}}:instance_guid}
258

259
[publish-connection-information]
260 261
feed-url-{{namebase}}-{{id}}-pull = ${request-pbs-{{namebase}}-{{id}}:connection-feeds-url}${request-pull-backup-server-{{namebase}}-{{id}}:config-notification-id}

262 263 264 265 266 267 268 269 270 271 272
{% if 'monitor-base-url' in monitor_return -%}
{% do monitor_url_list.append('${request-pbs-' ~ namebase ~ '-' ~ id ~ ':connection-monitor-base-url}') -%}
{% endif -%}

{% if monitor_parameter_dict.get('set-monitor-url', False) -%}
[request-{{namebase}}]
config-monitor-url-list = {{ monitor_url_list | join(' ') }}
{% else -%}
[monitor-conf-parameters]
monitor-url-list = {{ monitor_url_list | join(' ') }}
{% endif -%}
273

274
[request-pull-backup-server-{{namebase}}-backup-{{id}}]
275
<= request-pbs-common
276
name = PBS pushing on ${request-{{namebase}}-pseudo-replicating-{{id}}:name}
277
config-url = ${request-{{namebase}}-pseudo-replicating-{{id}}:connection-resilient-ssh-url}
278 279 280 281 282
config-type = push
config-server-key = ${request-{{namebase}}-pseudo-replicating-{{id}}:connection-ssh-public-key}
config-on-notification = ${request-pbs-{{namebase}}-{{id}}:connection-feeds-url}${request-pull-backup-server-{{namebase}}-{{id}}:config-notification-id}
config-notify = ${request-{{namebase}}-pseudo-replicating-{{id}}:connection-notification-url}
config-notification-id = ${request-{{namebase}}-pseudo-replicating-{{id}}:pbs-notification-id}
283
config-name = ${slap-connection:computer-id}-${slap-connection:partition-id}-{{namebase}}-{{id}}
284
config-title = Pushing to {{namebase}} backup {{id}}
285
shared = true
286
sla-instance_guid = ${request-pbs-{{namebase}}-{{id}}:instance_guid}
287 288
{% endfor %}

289 290 291 292 293 294 295 296
[slap-parameter]
# Default parameters for distributed deployment
# I.e state "backup1 of maria should go there, ..."
{% for id in range(1,nbbackup|int) %}
{{namebase}}{{id}}-computer-guid =
pbs-{{namebase}}{{id}}-computer-guid =
{% endfor %}

297
{% endmacro %}