summaryrefslogtreecommitdiff
path: root/swift-build-rings.yml
diff options
context:
space:
mode:
authorRichard Ipsum <richard.ipsum@codethink.co.uk>2015-04-01 14:39:24 +0000
committerBaserock Gerrit <gerrit@baserock.org>2015-04-10 19:09:41 +0000
commit4171a9255bc913cff40a177daf7611c06d735754 (patch)
tree71aaa97e0d7d73e0f5cf5483d875e9625e941ebb /swift-build-rings.yml
parent54a2d1e21a65a4fada799a7d903c50d61c195e32 (diff)
downloaddefinitions-4171a9255bc913cff40a177daf7611c06d735754.tar.gz
Add configuration for swift storage nodes
Change-Id: Iad40b665edff7a3605b6600dafbcf67831e4290a
Diffstat (limited to 'swift-build-rings.yml')
-rw-r--r--swift-build-rings.yml34
1 files changed, 34 insertions, 0 deletions
diff --git a/swift-build-rings.yml b/swift-build-rings.yml
new file mode 100644
index 00000000..1ffe9c37
--- /dev/null
+++ b/swift-build-rings.yml
@@ -0,0 +1,34 @@
+---
+- hosts: localhost
+ vars:
+ - rings:
+ - { name: account, port: 6002 }
+ - { name: container, port: 6001 }
+ - { name: object, port: 6000 }
+ remote_user: root
+ tasks:
+ - file: path={{ ansible_env.ROOT }}/etc/swift owner=root group=root state=directory
+
+ - name: Create ring
+ shell: swift-ring-builder {{ item.name }}.builder create {{ ansible_env.SWIFT_PART_POWER }}
+ {{ ansible_env.SWIFT_REPLICAS }} {{ ansible_env.SWIFT_MIN_PART_HOURS }}
+ with_items: rings
+
+ - name: Add each storage node to the ring
+ shell: swift-ring-builder {{ item[0].name }}.builder
+ add r1z1-{{ item[1].ip }}:{{ item[0].port }}/{{ item[1].device }} {{ item[1].weight }}
+ with_nested:
+ - rings
+ - ansible_env.SWIFT_STORAGE_DEVICES
+
+ - name: Rebalance the ring
+ shell: swift-ring-builder {{ item.name }}.builder rebalance {{ ansible_env.SWIFT_REBALANCE_SEED }}
+ with_items: rings
+
+ - name: Copy ring configuration files into place
+ copy: src={{ item.name }}.ring.gz dest={{ ansible_env.ROOT }}/etc/swift
+ with_items: rings
+
+ - name: Copy ring builder files into place
+ copy: src={{ item.name }}.builder dest={{ ansible_env.ROOT }}/etc/swift
+ with_items: rings