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
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
|
name: openstack-three-node-installer
kind: cluster
description: |
This is a cluster morphology for deploying an installer for an x86_64
OpenStack system spread across three nodes.
This cluster creates disk images that may be `dd`'d onto install media to
produce an OpenStack cluster when instantiated.
Alternatively it may be used to install directly onto a physical disk by
running:
morph deploy clusters/openstack-three-node-installer.morph \
network-installer network-installer.location=/dev/vdb
Substituting network-installer for either compute-installer or
controller-installer will produce different configurations, and it is possible
to substitue /dev/vdb for a different path to a disk image to install to a
different disk image.
Substitute the values of HOSTNAME, NETWORK_CONFIG, EXTERNAL_INTERFACE,
MANAGEMENT_IP_ADDRESS, CONTROLLER_HOST_ADDRESS, RABBITMQ_HOST and HOSTS_* to
match your hardware and networking configuration.
Requirements to be able to run and test the system:
- DISK_SIZE should be bigger than 5G
- The system has to have available at least 4G of RAM, but once
you start instantiating VMs you will need more.
- The IP of the system can't change, and you need to know it beforehand,
that is, the system needs a static IP address.
This cluster is configurable, but with the following constraints:
- The hostname in RABBITMQ_HOST has to match CONTROLLER_HOST_ADDRESS,
and HOST_CONTROLLER.
- HOSTS_CONTROLLER is only needed if the hostname (see previous point)
is not a FQDN.
- The IP listed in MANAGEMENT_INTERFACE_IP_ADDRESS has to match the one
used in HOSTS_CONTROLLER.
- CINDER_DEVICE should be a path to a storage device ready to be
used/formated for cinder data.
- EXTERNAL_INTERFACE is required when the system has more than one network
interface.
You can also have a look at the following suggestions:
- NOVA_VIRT_TYPE can be either 'kvm' or 'qemu', depending on where the
system is being deployed to.
- We recommend changing all the PASSWORDs variables, also the
KEYSTONE_TEMPORARY_ADMIN_TOKEN, METADATA_PROXY_SHARED_SECRET and
METERING_SECRET.
- Setting NOVA_BAREMETAL_SCHEDULING with an YAML truth value will configure
Nova to schedule baremetal machines through the Ironic driver, instead of
sheduling virtual machines.
systems:
- morph: systems/installer-system-x86_64.morph
deploy:
network-installer: &installer
type: extensions/rawdisk
location: installer-openstack-network-x86_64.img
KERNEL_ARGS: init=/usr/lib/baserock-installer/installer
DISK_SIZE: 6G
HOSTNAME: installer-x86_64
INSTALLER_TARGET_STORAGE_DEVICE: /dev/sda
INSTALLER_ROOTFS_TO_INSTALL: /rootfs
INSTALLER_POST_INSTALL_COMMAND: sync; poweroff -f
INITRAMFS_PATH: boot/initramfs.gz
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
network-initramfs: &initramfs
type: extensions/initramfs
location: boot/initramfs.gz
- morph: systems/openstack-system-x86_64.morph
deploy:
network-to-install: &stack-node
type: extensions/sysroot
location: rootfs
INSTALL_FILES: install-files/openstack/manifest
INITRAMFS_PATH: boot/initramfs.gz
HOSTNAME: threenode-network
RABBITMQ_HOST: threenode-controller.os-mgmt
RABBITMQ_PORT: 5672
RABBITMQ_USER: rabbitmq
RABBITMQ_PASSWORD: veryinsecure
# This token needs to be unique and secret
KEYSTONE_ENABLE_SERVICE: false
KEYSTONE_TEMPORARY_ADMIN_TOKEN: 22f3aa1cf538e3f6d5e8
KEYSTONE_ADMIN_PASSWORD: veryinsecure
KEYSTONE_DB_USER: keystoneDB
KEYSTONE_DB_PASSWORD: veryinsecure
GLANCE_ENABLE_SERVICE: false
GLANCE_SERVICE_USER: glance
GLANCE_SERVICE_PASSWORD: veryinsecure
GLANCE_DB_USER: glanceDB
GLANCE_DB_PASSWORD: veryinsecure
NOVA_ENABLE_CONTROLLER: false
NOVA_ENABLE_COMPUTE: false
NOVA_SERVICE_USER: nova
NOVA_SERVICE_PASSWORD: veryinsecure
NOVA_DB_USER: novaDB
NOVA_DB_PASSWORD: veryinsecure
NOVA_VIRT_TYPE: kvm
NOVA_BAREMETAL_SCHEDULING: false
CINDER_ENABLE_CONTROLLER: false
CINDER_ENABLE_COMPUTE: false
CINDER_ENABLE_STORAGE: false
CINDER_SERVICE_USER: cinder
CINDER_SERVICE_PASSWORD: veryinsecure
CINDER_DB_USER: cinderDB
CINDER_DB_PASSWORD: veryinsecure
# Storage device to be used by Cinder
CINDER_DEVICE: /dev/sdb
NEUTRON_ENABLE_AGENT: false
NEUTRON_ENABLE_MANAGER: true
NEUTRON_ENABLE_CONTROLLER: false
NEUTRON_SERVICE_USER: neutron
NEUTRON_SERVICE_PASSWORD: veryinsecure
NEUTRON_DB_USER: neutronDB
NEUTRON_DB_PASSWORD: veryinsecure
METADATA_PROXY_SHARED_SECRET: novaneutronmetasecret
IRONIC_ENABLE_SERVICE: false
IRONIC_SERVICE_USER: ironic
IRONIC_SERVICE_PASSWORD: veryinsecure
IRONIC_DB_USER: ironicDB
IRONIC_DB_PASSWORD: veryinsecure
CEILOMETER_SERVICE_USER: ceilometer
CEILOMETER_SERVICE_PASSWORD: veryinsecure
CEILOMETER_DB_USER: ceilometerDB
CEILOMETER_DB_PASSWORD: veryinsecure
CEILOMETER_ENABLE_CONTROLLER: false
CEILOMETER_ENABLE_COMPUTE: false
METERING_SECRET: insecureceilometersecret
CONTROLLER_HOST_ADDRESS: threenode-controller.os-mgmt
MANAGEMENT_INTERFACE_IP_ADDRESS: 10.0.0.1
HOSTS_NETWORK: 10.0.0.1 threenode-network.os-mgmt
HOSTS_CONTROL: 10.0.0.2 threenode-controller.os-mgmt
HOSTS_COMPUTE: 10.0.0.3 threenode-compute.os-mgmt
EXTERNAL_INTERFACE: enp3s0
NETWORK_CONFIG: enp3s0:dhcp;enp2s0:static,address=10.0.0.1,netmask=255.255.255.0
SYNC_TIME_WITH_CONTROLLER: true
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
network-to-install-initramfs: *initramfs
- morph: systems/installer-system-x86_64.morph
deploy:
controller-installer:
<<: *installer
location: installer-openstack-controller-x86_64.img
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
controller-initramfs: *initramfs
- morph: systems/openstack-system-x86_64.morph
deploy:
controller-to-install:
<<: *stack-node
HOSTNAME: threenode-controller
KEYSTONE_ENABLE_SERVICE: true
GLANCE_ENABLE_SERVICE: true
NOVA_ENABLE_CONTROLLER: true
CINDER_ENABLE_CONTROLLER: true
CINDER_ENABLE_COMPUTE: false
CINDER_ENABLE_STORAGE: false
NEUTRON_ENABLE_AGENT: false
NEUTRON_ENABLE_MANAGER: false
NEUTRON_ENABLE_CONTROLLER: true
METADATA_PROXY_SHARED_SECRET: novaneutronmetasecret
IRONIC_ENABLE_SERVICE: true
CEILOMETER_ENABLE_CONTROLLER: true
CEILOMETER_ENABLE_COMPUTE: false
MANAGEMENT_INTERFACE_IP_ADDRESS: 10.0.0.2
EXTERNAL_INTERFACE: enp2s0
NETWORK_CONFIG: enp2s0:dhcp;enp0s26u1u2:static,address=10.0.0.2,netmask=255.255.255.0
SYNC_TIME_WITH_CONTROLLER: false
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
controller-to-install-initramfs: *initramfs
- morph: systems/installer-system-x86_64.morph
deploy:
compute-installer:
<<: *installer
location: installer-openstack-compute-x86_64.img
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
compute-initramfs: *initramfs
- morph: systems/openstack-system-x86_64.morph
deploy:
compute-to-install:
<<: *stack-node
HOSTNAME: threenode-compute
NOVA_ENABLE_COMPUTE: true
CINDER_ENABLE_CONTROLLER: false
CINDER_ENABLE_COMPUTE: true
CINDER_ENABLE_STORAGE: true
NEUTRON_ENABLE_AGENT: true
NEUTRON_ENABLE_MANAGER: false
NEUTRON_ENABLE_CONTROLLER: false
CEILOMETER_ENABLE_CONTROLLER: false
CEILOMETER_ENABLE_COMPUTE: true
MANAGEMENT_INTERFACE_IP_ADDRESS: 10.0.0.3
EXTERNAL_INTERFACE: eno1
NETWORK_CONFIG: eno1:dhcp;enp0s29u1u3:static,address=10.0.0.3,netmask=255.255.255.0
SYNC_TIME_WITH_CONTROLLER: true
subsystems:
- morph: systems/initramfs-x86_64.morph
deploy:
compute-to-install-initramfs: *initramfs
|