summaryrefslogtreecommitdiffstats
path: root/puppet/manifests/ringbuilder.pp
blob: 2d880d33cb409b7c8ac3ae20636fa742d9f99a94 (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
# Copyright 2015 Red Hat, Inc.
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.

include ::tripleo::packages

define add_devices(
  $swift_zones = '1'
){

  # NOTE(dprince): Swift zones is not yet properly wired into the Heat
  # templates. See: https://review.openstack.org/#/c/97758/3
  # For now our regex supports the r1z1-192.0.2.6:%PORT%/d1 syntax or the
  # newer r1z%<controller or SwiftStorage><N>%-192.0.2.6:%PORT%/d1 syntax.
  $server_num_or_device = regsubst($name,'^r1z%+[A-Za-z]*([0-9]+)%+-(.*)$','\1')
  if (is_integer($server_num_or_device)) {
    $server_num = $server_num_or_device
  } else {
    $server_num = '1'
  }
  # Function to place server in its zone.  Zone is calculated by
  # server number in heat template modulo the number of zones + 1.
  $zone = (($server_num%$swift_zones) + 1)

  # add the rings
  $base = regsubst($name,'^r1.*-(.*)$','\1')
  $object = regsubst($base, '%PORT%', '6000')
  ring_object_device { $object:
    zone   => '1',
    weight => 100,
  }
  $container = regsubst($base, '%PORT%', '6001')
  ring_container_device { $container:
    zone   => '1',
    weight => 100,
  }
  $account = regsubst($base, '%PORT%', '6002')
  ring_account_device { $account:
    zone   => '1',
    weight => 100,
  }
}

class tripleo::ringbuilder (
  $swift_zones     = '1',
  $devices         = '',
  $build_ring      = true,
  $part_power,
  $replicas,
  $min_part_hours,
) {

  validate_bool($build_ring)

  if $build_ring {

    $device_array = strip(split(rstrip($devices), ','))

    # create local rings
    swift::ringbuilder::create{ ['object', 'account', 'container']:
      part_power     => $part_power,
      replicas       => min(count($device_array), $replicas),
      min_part_hours => $min_part_hours,
    } ->

    # add all other devices
    add_devices {$device_array:
      swift_zones => $swift_zones,
    } ->

    # rebalance
    swift::ringbuilder::rebalance{ ['object', 'account', 'container']:
      seed => 999,
    }

    Ring_object_device<| |> ~> Exec['rebalance_object']
    Ring_object_device<| |> ~> Exec['rebalance_account']
    Ring_object_device<| |> ~> Exec['rebalance_container']

  }
}

include ::tripleo::ringbuilder

package_manifest{'/var/lib/tripleo/installed-packages/ringbuilder': ensure => present}