Merge "Convert vars in files to host_vars"
This commit is contained in:
commit
850c763a19
@ -148,8 +148,8 @@ To rekick all VMs, the following command can be used on the host machine to cycl
|
||||
|
||||
for VM_NAME in $(virsh list --all | awk '/running/ || /shut/ {print $2}'); do
|
||||
virsh destroy "${VM_NAME}"
|
||||
lvremove "/dev/mapper/vg01--${VM_NAME}"
|
||||
lvcreate -L 60G vg01 -n "${VM_NAME}"
|
||||
echo y | lvremove "/dev/mapper/vg01-${VM_NAME}"
|
||||
lvcreate -L 92160M vg01 -n "${VM_NAME}"
|
||||
virsh start "${VM_NAME}"
|
||||
done
|
||||
|
||||
|
@ -66,7 +66,5 @@
|
||||
state: restarted
|
||||
with_items: "{{ mnaio_dhcp_distro_packages }}"
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-dhcpd
|
||||
|
@ -13,102 +13,6 @@
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
|
||||
- name: Setup cinder host volume
|
||||
hosts: cinder_hosts:swift_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: un-mount deleteme mount
|
||||
mount:
|
||||
name: "/var/lib/lxc"
|
||||
state: unmounted
|
||||
|
||||
- name: remote deleteme mount
|
||||
mount:
|
||||
name: "/var/lib/lxc"
|
||||
state: absent
|
||||
|
||||
- name: Remove deleteme lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: lxc00
|
||||
force: true
|
||||
state: absent
|
||||
|
||||
- name: Setup cinder host volume
|
||||
hosts: cinder_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Create cinder-volumes lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: cinder-volumes00
|
||||
size: 100%FREE
|
||||
shrink: false
|
||||
|
||||
- name: Create data cinder-volumes group
|
||||
lvg:
|
||||
vg: cinder-volumes
|
||||
pvs: "/dev/vg00/cinder-volumes00"
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-osa
|
||||
|
||||
|
||||
- name: Setup swift host volume
|
||||
hosts: swift_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Remove deleteme lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: "{{ item }}"
|
||||
size: 4G
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Format swift drives
|
||||
filesystem:
|
||||
fstype: xfs
|
||||
dev: "/dev/vg00/{{ item }}"
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Create drive directories
|
||||
file:
|
||||
path: "/srv/{{ item }}"
|
||||
state: directory
|
||||
owner: "root"
|
||||
group: "root"
|
||||
mode: "0755"
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Mount swift drives
|
||||
mount:
|
||||
name: "/srv/{{ item }}"
|
||||
src: "/dev/mapper/vg00-{{ item }}"
|
||||
fstype: xfs
|
||||
state: mounted
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-osa
|
||||
|
||||
|
||||
- name: Setup deploy host
|
||||
hosts: deploy_hosts
|
||||
gather_facts: "{{ gather_facts | default(true) }}"
|
||||
@ -226,7 +130,5 @@
|
||||
when:
|
||||
- run_osa | default(true) | bool
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-osa
|
||||
|
@ -187,35 +187,46 @@
|
||||
group: root
|
||||
with_items:
|
||||
- src: basic-interface.cfg
|
||||
dest: basic-interface.cfg
|
||||
dest: "basic-{{ ansible_os_family | lower }}-interface.cfg"
|
||||
dir: networking
|
||||
- src: vm-post-install-script.sh.j2
|
||||
dest: "vm-post-install-{{ ansible_os_family | lower }}-script.sh"
|
||||
dir: scripts
|
||||
|
||||
- name: network scripts for an MNAIO
|
||||
template:
|
||||
src: "mnaio/{{ ansible_os_family | lower }}/{{ item.src }}"
|
||||
dest: /var/www/pxe/{{ item.dir }}/{{ item.dest }}
|
||||
mode: "0644"
|
||||
owner: root
|
||||
group: root
|
||||
when:
|
||||
- groups['mnaio_hosts'] | default([]) | length > 0
|
||||
with_items:
|
||||
- src: mnaio-bridges.cfg.j2
|
||||
dest: mnaio-bridges.cfg
|
||||
dir: networking
|
||||
- src: mnaio-post-install-script.sh.j2
|
||||
dest: mnaio-post-install-script.sh
|
||||
dir: scripts
|
||||
- src: vm-post-install-script.sh.j2
|
||||
dest: vm-post-install-script.sh
|
||||
dir: scripts
|
||||
|
||||
- name: network scripts for servers
|
||||
template:
|
||||
src: "pxe/{{ ansible_os_family | lower }}/vm-bridges.cfg.j2"
|
||||
dest: /var/www/pxe/networking/{{ item.server_hostname }}-bridges.cfg
|
||||
dest: /var/www/pxe/networking/{{ hostvars[item]['server_hostname'] }}-bridges.cfg
|
||||
mode: "0644"
|
||||
owner: root
|
||||
group: root
|
||||
with_items: "{{ servers }}"
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: tftp configs for servers
|
||||
template:
|
||||
src: "pxe/tftp/pxelinux.cfg.macaddr.j2"
|
||||
dest: "/var/lib/tftpboot/pxelinux.cfg/01-{{ item.server_mac_address | replace(':', '-') }}"
|
||||
dest: "/var/lib/tftpboot/pxelinux.cfg/01-{{ hostvars[item]['server_mac_address'] | replace(':', '-') }}"
|
||||
mode: "0644"
|
||||
owner: root
|
||||
group: root
|
||||
with_items: "{{ servers }}"
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: Preseeds for pxe mnaio
|
||||
template:
|
||||
@ -290,7 +301,5 @@
|
||||
state: restarted
|
||||
enabled: yes
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-pxe
|
||||
|
@ -32,36 +32,44 @@
|
||||
- name: Create VM LV
|
||||
lvol:
|
||||
vg: vg01
|
||||
lv: "{{ item.server_hostname }}"
|
||||
lv: "{{ hostvars[item]['server_hostname'] }}"
|
||||
size: "{{ default_vm_storage }}"
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: Create the VM template
|
||||
template:
|
||||
src: kvm/kvm-vm.xml
|
||||
dest: "/etc/libvirt/qemu/{{ item.server_hostname }}.xml"
|
||||
dest: "/etc/libvirt/qemu/{{ hostvars[item]['server_hostname'] }}.xml"
|
||||
mode: 0644
|
||||
owner: root
|
||||
group: root
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: Define the VM
|
||||
command: "virsh define /etc/libvirt/qemu/{{ item.server_hostname }}.xml"
|
||||
command: "virsh define /etc/libvirt/qemu/{{ hostvars[item]['server_hostname'] }}.xml"
|
||||
failed_when: false
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: Create the VM
|
||||
command: "virsh create /etc/libvirt/qemu/{{ item.server_hostname }}.xml"
|
||||
command: "virsh create /etc/libvirt/qemu/{{ hostvars[item]['server_hostname'] }}.xml"
|
||||
failed_when: false
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
- name: Start the VM
|
||||
command: "virsh start {{ item.server_hostname }}"
|
||||
command: "virsh start {{ hostvars[item]['server_hostname'] }}"
|
||||
failed_when: false
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-vms
|
||||
|
||||
@ -70,14 +78,14 @@
|
||||
hosts: localhost
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Servers group
|
||||
- name: VM Servers group
|
||||
add_host:
|
||||
name: "{{ item.server_vm_fixed_addr }}"
|
||||
name: "{{ hostvars[item]['server_vm_fixed_addr'] }}"
|
||||
groups: vm_servers
|
||||
with_items: "{{ servers }}"
|
||||
when:
|
||||
- hostvars[item]['server_vm'] | default(false) | bool
|
||||
with_items: "{{ groups['pxe_servers'] }}"
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-vms
|
||||
|
||||
@ -86,11 +94,16 @@
|
||||
hosts: vm_servers
|
||||
gather_facts: false
|
||||
pre_tasks:
|
||||
- name: Wait for container connectivity
|
||||
wait_for_connection:
|
||||
- name: Wait for connectivity 1
|
||||
local_action:
|
||||
module: wait_for
|
||||
host: "{{ ansible_host }}"
|
||||
connect_timeout: 5
|
||||
port: 22
|
||||
sleep: 10
|
||||
timeout: 1200
|
||||
state: started
|
||||
search_regex: OpenSSH
|
||||
tasks:
|
||||
- name: copy host keys
|
||||
copy:
|
||||
@ -103,7 +116,100 @@
|
||||
- src: /root/.ssh/id_rsa.pub
|
||||
dest: /root/.ssh/id_rsa.pub
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- deploy-vms
|
||||
- deploy-vms
|
||||
|
||||
|
||||
- name: Setup cinder host volume
|
||||
hosts: cinder_hosts:swift_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: un-mount deleteme mount
|
||||
mount:
|
||||
name: "/var/lib/lxc"
|
||||
state: unmounted
|
||||
|
||||
- name: remote deleteme mount
|
||||
mount:
|
||||
name: "/var/lib/lxc"
|
||||
state: absent
|
||||
|
||||
- name: Remove deleteme lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: lxc00
|
||||
force: true
|
||||
state: absent
|
||||
|
||||
tags:
|
||||
- deploy-vms
|
||||
|
||||
|
||||
- name: Setup cinder host volume
|
||||
hosts: cinder_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Create cinder-volumes lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: cinder-volumes00
|
||||
size: "100%FREE"
|
||||
shrink: false
|
||||
|
||||
- name: Create data cinder-volumes group
|
||||
lvg:
|
||||
vg: cinder-volumes
|
||||
pvs: "/dev/vg00/cinder-volumes00"
|
||||
|
||||
tags:
|
||||
- deploy-vms
|
||||
|
||||
|
||||
- name: Setup swift host volume
|
||||
hosts: swift_hosts
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Remove deleteme lv
|
||||
lvol:
|
||||
vg: vg00
|
||||
lv: "{{ item }}"
|
||||
size: 4G
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Format swift drives
|
||||
filesystem:
|
||||
fstype: xfs
|
||||
dev: "/dev/vg00/{{ item }}"
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Create drive directories
|
||||
file:
|
||||
path: "/srv/{{ item }}"
|
||||
state: directory
|
||||
owner: "root"
|
||||
group: "root"
|
||||
mode: "0755"
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
- name: Mount swift drives
|
||||
mount:
|
||||
name: "/srv/{{ item }}"
|
||||
src: "/dev/mapper/vg00-{{ item }}"
|
||||
fstype: xfs
|
||||
state: mounted
|
||||
with_items:
|
||||
- disk1
|
||||
- disk2
|
||||
- disk3
|
||||
|
||||
tags:
|
||||
- deploy-vms
|
||||
|
@ -37,11 +37,11 @@ shared-network all-networks {
|
||||
{% endfor %}
|
||||
|
||||
group {
|
||||
{% for item in servers %}
|
||||
host {{ item.server_hostname }} {
|
||||
hardware ethernet {{ item.server_mac_address }};
|
||||
fixed-address {{ item.server_vm_fixed_addr }};
|
||||
option host-name "{{ item.server_hostname }}";
|
||||
{% for item in groups['pxe_servers'] %}
|
||||
host {{ hostvars[item]['server_hostname'] }} {
|
||||
hardware ethernet {{ hostvars[item]['server_mac_address'] }};
|
||||
fixed-address {{ hostvars[item]['server_vm_fixed_addr'] }};
|
||||
option host-name "{{ hostvars[item]['server_hostname'] }}";
|
||||
}
|
||||
{% endfor %}
|
||||
|
||||
|
66
multi-node-aio/playbooks/group_vars/all.yml
Normal file
66
multi-node-aio/playbooks/group_vars/all.yml
Normal file
@ -0,0 +1,66 @@
|
||||
---
|
||||
# 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.
|
||||
|
||||
default_interface: "{{ default_network | default('eth0') }}"
|
||||
default_vm_image: "{{ default_image | default('ubuntu-16.04-amd64') }}"
|
||||
default_vm_storage: "{{ vm_disk_size | default(92160) }}"
|
||||
|
||||
default_os_families:
|
||||
ubuntu-16.04-amd64: debian
|
||||
ubuntu-14.04-amd64: debian
|
||||
|
||||
default_ubuntu_mirror_proxy: 'http://10.0.2.1:3142/'
|
||||
default_ubuntu_mirror_hostname: archive.ubuntu.com
|
||||
default_ubuntu_mirror_directory: /ubuntu
|
||||
|
||||
# IP address, or domain name of the TFTP server
|
||||
tftp_server: "{{ ansible_host }}"
|
||||
# tftp_ssh_key: '' # user defined ssh key, used to access the host
|
||||
tftp_port: 69
|
||||
|
||||
# Default ISO images
|
||||
images:
|
||||
ubuntu-16.04-amd64:
|
||||
image_type: debian
|
||||
image_iso_url: "http://releases.ubuntu.com/16.04.2/ubuntu-16.04.2-server-amd64.iso"
|
||||
image_name: "ubuntu-16.04.2-server-amd64.iso"
|
||||
image_short_name: "ubuntu-16.04.2-server-amd64"
|
||||
image_default_boot: "ubuntu-16.04.2-server-amd64/amd64/boot-screens/menu.cfg"
|
||||
image_kernel_options: "biosdevname=0 net.ifnames=0 auto=true priority=critical vga=789"
|
||||
image_kernel: "ubuntu-16.04.2-server-amd64/amd64/linux"
|
||||
image_initrd: "ubuntu-16.04.2-server-amd64/amd64/initrd.gz"
|
||||
image_netboot: "ubuntu-16.04.2-server-amd64/install/netboot/ubuntu-installer"
|
||||
image_preseeds:
|
||||
mnaio:
|
||||
url: "tftp://{{ tftp_server }}/preseed/mnaio.preseed"
|
||||
template_name: "mnaio.preseed"
|
||||
vm:
|
||||
url: "tftp://{{ tftp_server }}/preseed/vm.preseed"
|
||||
template_name: "vm.preseed"
|
||||
ubuntu-14.04-amd64:
|
||||
image_type: debian
|
||||
image_iso_url: "http://releases.ubuntu.com/14.04.5/ubuntu-14.04.5-server-amd64.iso"
|
||||
image_name: "ubuntu-14.04.5-server-amd64.iso"
|
||||
image_short_name: "ubuntu-14.04.5-server-amd64"
|
||||
image_default_boot: "ubuntu-14.04.5-server-amd64/amd64/boot-screens/menu.cfg"
|
||||
image_kernel_options: "biosdevname=0 net.ifnames=0 auto=true priority=critical vga=789"
|
||||
image_kernel: "ubuntu-14.04.5-server-amd64/amd64/linux"
|
||||
image_initrd: "ubuntu-14.04.5-server-amd64/amd64/initrd.gz"
|
||||
image_netboot: "ubuntu-14.04.5-server-amd64/install/netboot/ubuntu-installer"
|
||||
image_preseeds:
|
||||
mnaio:
|
||||
url: "tftp://{{ tftp_server }}/preseed/mnaio.preseed"
|
||||
template_name: "mnaio.preseed"
|
||||
vm:
|
||||
url: "tftp://{{ tftp_server }}/preseed/vm.preseed"
|
||||
template_name: "vm.preseed"
|
28
multi-node-aio/playbooks/group_vars/dhcp_hosts.yml
Normal file
28
multi-node-aio/playbooks/group_vars/dhcp_hosts.yml
Normal file
@ -0,0 +1,28 @@
|
||||
---
|
||||
# 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.
|
||||
|
||||
dhcp_default_lease_time: 21600 # Default lease time
|
||||
dhcp_max_lease_time: 43200 # Max lease time
|
||||
tftp_boot_path: /pxelinux.0 # Path of where to boot from first
|
||||
|
||||
# - List of DHCP Subnets - These are iterated though and each will be created
|
||||
dhcp_list:
|
||||
- netmask: 255.255.255.0 # Netmask
|
||||
gateway: 10.0.2.1 # Gateway
|
||||
dns: 8.8.8.8 # DNS
|
||||
subnet: 10.0.2.0 # Subnet mask
|
||||
default_lease_time: 21600 # Subnet Default lease time - The default is used if this is not defined
|
||||
max_lease_time: 43200 # Subnet Max lease time - The default is used if this is not defined
|
||||
tftp_boot_path: /pxelinux.0 # Path for tftp of where to boot from first - The default is used if this is not defined
|
||||
tftp_server: "{{ tftp_server }}" # The server hosting the TFTP server - The default is used if this is not defined
|
||||
dhcp_default_domain_name: openstackci.local
|
83
multi-node-aio/playbooks/group_vars/mnaio_hosts.yml
Normal file
83
multi-node-aio/playbooks/group_vars/mnaio_hosts.yml
Normal file
@ -0,0 +1,83 @@
|
||||
---
|
||||
# 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.
|
||||
|
||||
# mnaio_data_disk: 'sdc' # str - not required, set this to define a given data disk if no data disk
|
||||
# is defined the largest unpartitioned disk will be used.
|
||||
mnaio_host_networks:
|
||||
dhcp:
|
||||
iface: 'vm-br-dhcp' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.2.1/22' # str - not required, must be in CIDR format
|
||||
iface_port: none # str - required, physical port used within a host bridge
|
||||
mgmt:
|
||||
iface: 'vm-br-eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.1/22'
|
||||
iface_port: none
|
||||
flat:
|
||||
iface: 'vm-br-eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.1/22'
|
||||
iface_port: none
|
||||
vlan:
|
||||
iface: 'vm-br-eth3'
|
||||
inet_type: 'manual'
|
||||
iface_port: none
|
||||
vxlan:
|
||||
iface: 'vm-br-eth4'
|
||||
inet_type: 'manual'
|
||||
address: '10.0.240.1/22'
|
||||
iface_port: none
|
||||
storage:
|
||||
iface: 'vm-br-eth5'
|
||||
inet_type: 'manual'
|
||||
address: '10.0.244.1/22'
|
||||
iface_port: none
|
||||
|
||||
mnaio_host_iptables_rules:
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: tcp
|
||||
match: tcp
|
||||
destination_port: 67
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 67
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 53
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 53
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: FORWARD
|
||||
in_interface: vm-br-dhcp
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: FORWARD
|
||||
out_interface: vm-br-dhcp
|
||||
jump: ACCEPT
|
||||
- table: nat
|
||||
chain: POSTROUTING
|
||||
out_interface: "{{ masquerade_interface | default(default_interface) }}"
|
||||
jump: MASQUERADE
|
16
multi-node-aio/playbooks/group_vars/pxe_hosts.yml
Normal file
16
multi-node-aio/playbooks/group_vars/pxe_hosts.yml
Normal file
@ -0,0 +1,16 @@
|
||||
---
|
||||
# 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.
|
||||
|
||||
pxelinux_url: "https://www.kernel.org/pub/linux/utils/boot/syslinux/syslinux-6.03.tar.gz"
|
||||
pxelinux_name: "syslinux-6.03.tar.gz"
|
||||
pxelinux_short_name: "syslinux-6.03"
|
58
multi-node-aio/playbooks/host_vars/cinder1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/cinder1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'cinder1'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.130'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:07'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.107/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.107/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.107/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.107/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/cinder2.yml
Normal file
58
multi-node-aio/playbooks/host_vars/cinder2.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'cinder2'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.131'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:08'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.108/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.108/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.108/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.108/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/compute1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/compute1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'compute1'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.120'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:05'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.105/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.105/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.105/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.105/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/compute2.yml
Normal file
58
multi-node-aio/playbooks/host_vars/compute2.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'compute2'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.121'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:06'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.106/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.106/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.106/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.106/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/example-host1.yml.example
Normal file
58
multi-node-aio/playbooks/host_vars/example-host1.yml.example
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}" # str - Set the ansible os family
|
||||
|
||||
server_hostname: 'example-host1' # str - required, hostname of server
|
||||
server_vm: true # bool - not required, used to specify a host is to become a VM
|
||||
server_vm_ram: 8192 # int - not required, used to specify ram when provisioning a VM
|
||||
server_vm_vcpus: 4 # int - not required, used to specify vcpus when provisioning a VM
|
||||
server_vm_fixed_addr: '10.0.2.200' # str - not required, used to specify fixed address when using internal DHCPD
|
||||
server_vm_primary_network: 'dhcp' # str - not required, primary network used to kick the VM
|
||||
server_image: "{{ default_vm_image }}" # str - required, image name
|
||||
server_default_interface: 'eth0' # str - required, default interface
|
||||
server_mac_address: '52:54:00:bd:80:20' # str - required, mac address of default interface
|
||||
server_preseed_ks: 'vm' # str - required, name of preseed/kickstart file
|
||||
server_extra_options: '' # str - not required, added kernel options
|
||||
|
||||
server_networks: # dict - required, hash of networks, can be empty, key is used to name the networks.
|
||||
dhcp:
|
||||
iface: 'eth0' # str - required, interface name
|
||||
inet_type: 'dhcp' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-dhcp # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
mgmt:
|
||||
iface: 'eth1' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.236.200/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth1 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
flat:
|
||||
iface: 'eth2' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.248.200/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth2 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vlan:
|
||||
iface: 'eth3' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-eth3 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vxlan:
|
||||
iface: 'eth4' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.240.200/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth4 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
storage:
|
||||
iface: 'eth5' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.244.200/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth5 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
58
multi-node-aio/playbooks/host_vars/infra1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/infra1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'infra1' # str - required, hostname of server
|
||||
server_vm: true # bool - not required, used to specify a host is to become a VM
|
||||
server_vm_ram: 8192 # int - not required, used to specify ram when provisioning a VM
|
||||
server_vm_vcpus: 4 # int - not required, used to specify vcpus when provisioning a VM
|
||||
server_vm_fixed_addr: '10.0.2.100' # str - not required, used to specify fixed address when using internal DHCPD
|
||||
server_vm_primary_network: 'dhcp' # str - not required, primary network used to kick the VM
|
||||
server_image: "{{ default_vm_image }}" # str - required, image name
|
||||
server_default_interface: 'eth0' # str - required, default interface
|
||||
server_mac_address: '52:54:00:bd:80:00' # str - required, mac address of default interface
|
||||
server_preseed_ks: 'vm' # str - required, name of preseed/kickstart file
|
||||
server_extra_options: '' # str - not required, added kernel options
|
||||
|
||||
server_networks: # dict - required, hash of networks, can be empty, key is used to name the networks.
|
||||
dhcp:
|
||||
iface: 'eth0' # str - required, interface name
|
||||
inet_type: 'dhcp' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-dhcp # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
mgmt:
|
||||
iface: 'eth1' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.236.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth1 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
flat:
|
||||
iface: 'eth2' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.248.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth2 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vlan:
|
||||
iface: 'eth3' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-eth3 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vxlan:
|
||||
iface: 'eth4' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.240.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth4 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
storage:
|
||||
iface: 'eth5' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.244.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth5 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
58
multi-node-aio/playbooks/host_vars/infra2.yml
Normal file
58
multi-node-aio/playbooks/host_vars/infra2.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'infra2'
|
||||
server_vm: true
|
||||
server_vm_ram: 8192
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.101'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:01'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.101/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.101/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.101/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.101/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/infra3.yml
Normal file
58
multi-node-aio/playbooks/host_vars/infra3.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'infra3'
|
||||
server_vm: true
|
||||
server_vm_ram: 8192
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.102'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:02'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.102/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.102/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.102/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.102/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/loadbalancer1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/loadbalancer1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'loadbalancer1'
|
||||
server_vm: true
|
||||
server_vm_ram: 1024
|
||||
server_vm_vcpus: 1
|
||||
server_vm_fixed_addr: '10.0.2.142'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:12'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.112/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.112/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.112/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.112/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/logging1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/logging1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'logging1'
|
||||
server_vm: true
|
||||
server_vm_ram: 1024
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.110'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:03'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.103/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.103/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.103/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.103/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/swift1.yml
Normal file
58
multi-node-aio/playbooks/host_vars/swift1.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'swift1'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.140'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:09'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.109/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.109/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.109/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.109/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/swift2.yml
Normal file
58
multi-node-aio/playbooks/host_vars/swift2.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'swift2'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.140'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:10'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.110/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.110/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.110/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.110/22'
|
||||
vm_int_iface: vm-br-eth5
|
58
multi-node-aio/playbooks/host_vars/swift3.yml
Normal file
58
multi-node-aio/playbooks/host_vars/swift3.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
# Copyright 2017, Rackspace US, Inc.
|
||||
#
|
||||
# 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 witing, 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.
|
||||
|
||||
ansible_os_family: "{{ images[default_vm_image]['image_type'] }}"
|
||||
|
||||
server_hostname: 'swift3'
|
||||
server_vm: true
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.141'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:11'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.111/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.111/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.111/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.111/22'
|
||||
vm_int_iface: vm-br-eth5
|
@ -1,50 +1,84 @@
|
||||
################################## ALL HOSTS ##################################
|
||||
[all]
|
||||
localhost ansible_connection=local
|
||||
mnaio1 ansible_host=10.0.2.1
|
||||
# Local host
|
||||
localhost ansible_connection=local
|
||||
|
||||
infra1 ansible_host=10.0.236.100
|
||||
infra2 ansible_host=10.0.236.101
|
||||
infra3 ansible_host=10.0.236.102
|
||||
log1 ansible_host=10.0.236.103
|
||||
compute1 ansible_host=10.0.236.105
|
||||
compute2 ansible_host=10.0.236.106
|
||||
cinder1 ansible_host=10.0.236.107
|
||||
cinder2 ansible_host=10.0.236.108
|
||||
swift1 ansible_host=10.0.236.109
|
||||
swift2 ansible_host=10.0.236.110
|
||||
swift3 ansible_host=10.0.236.111
|
||||
loadbalancer1 ansible_host=10.0.236.112
|
||||
# MNAIO host
|
||||
mnaio1 ansible_host=10.0.2.1 ansible_connection=local
|
||||
|
||||
[pxe_hosts]
|
||||
mnaio1
|
||||
# MNAIO VMs
|
||||
infra1 ansible_host=10.0.236.100
|
||||
infra2 ansible_host=10.0.236.101
|
||||
infra3 ansible_host=10.0.236.102
|
||||
cinder2 ansible_host=10.0.236.108
|
||||
logging1 ansible_host=10.0.236.103
|
||||
compute1 ansible_host=10.0.236.105
|
||||
compute2 ansible_host=10.0.236.106
|
||||
cinder1 ansible_host=10.0.236.107
|
||||
swift1 ansible_host=10.0.236.109
|
||||
swift2 ansible_host=10.0.236.110
|
||||
swift3 ansible_host=10.0.236.111
|
||||
loadbalancer1 ansible_host=10.0.236.112
|
||||
|
||||
[dhcp_hosts]
|
||||
mnaio1
|
||||
################################# MNAIO HOSTS #################################
|
||||
|
||||
# The group "vm_hosts" is used to define all host machines that will be running
|
||||
# traditional virtualization using KVM.
|
||||
[vm_hosts]
|
||||
mnaio1
|
||||
|
||||
################################## PXE HOSTS ##################################
|
||||
|
||||
# The group "mnaio_hosts" is used to define all host machines that will serve
|
||||
# the purpose of running an MNAIO test environment.
|
||||
[mnaio_hosts]
|
||||
mnaio1
|
||||
|
||||
# The group "pxe_hosts" is used to setup all systems that will be responsible
|
||||
# for PXE boot. This will install all of the needed capabilities to TFTP serve
|
||||
# system images.
|
||||
[pxe_hosts]
|
||||
mnaio1
|
||||
|
||||
# The group "dhcp_hosts" is used to setup all systems that will be responsible
|
||||
# for DHCP. This is not required as external DHCP could be used.
|
||||
[dhcp_hosts]
|
||||
mnaio1
|
||||
|
||||
# The group "pxe_servers" is used to create PXE specific configurations for
|
||||
# each host machines.
|
||||
[pxe_servers]
|
||||
cinder1
|
||||
cinder2
|
||||
compute1
|
||||
compute2
|
||||
infra1
|
||||
infra2
|
||||
infra3
|
||||
loadbalancer1
|
||||
logging1
|
||||
swift1
|
||||
swift2
|
||||
swift3
|
||||
|
||||
################################## OSA HOSTS ##################################
|
||||
|
||||
# The group "deploy_hosts" is used to define where an OSA deployment will
|
||||
# originate from.
|
||||
[deploy_hosts]
|
||||
infra1
|
||||
|
||||
############################### OSA MNAIO HOSTS ###############################
|
||||
|
||||
# The group "swift_hosts" is used in the MNAIO setup to create the basic drive
|
||||
# setup needed for a swift deployment.
|
||||
[swift_hosts]
|
||||
swift1
|
||||
swift2
|
||||
swift3
|
||||
|
||||
# The group "cinder_hosts" is used in the MNAIO setup to create the basic drive
|
||||
# setup needed for a cinder LVM deployment.
|
||||
[cinder_hosts]
|
||||
cinder1
|
||||
cinder2
|
||||
|
||||
[openstack_hosts]
|
||||
infra1
|
||||
infra2
|
||||
infra3
|
||||
log1
|
||||
compute1
|
||||
compute2
|
||||
cinder2
|
||||
cinder1
|
||||
swift1
|
||||
swift2
|
||||
swift3
|
||||
|
@ -1,10 +1,10 @@
|
||||
<domain type='kvm'>
|
||||
<name>{{ item.server_hostname }}</name>
|
||||
<memory unit='MiB'>{{ item.server_vm_ram }}</memory>
|
||||
<currentMemory unit='MiB'>{{ item.server_vm_ram }}</currentMemory>
|
||||
{% set _vcpus_threads = ((item.server_vm_vcpus | int) // 2) %}
|
||||
<name>{{ hostvars[item]['server_hostname'] }}</name>
|
||||
<memory unit='MiB'>{{ hostvars[item]['server_vm_ram'] }}</memory>
|
||||
<currentMemory unit='MiB'>{{ hostvars[item]['server_vm_ram'] }}</currentMemory>
|
||||
{% set _vcpus_threads = ((hostvars[item]['server_vm_vcpus'] | int) // 2) %}
|
||||
{% set vcpus_threads = (_vcpus_threads | int) == 0 | ternary('1', _vcpus_threads) %}
|
||||
{% set vcpus = (item.server_vm_vcpus | int) * (vcpus_threads | int) %}
|
||||
{% set vcpus = (hostvars[item]['server_vm_vcpus'] | int) * (vcpus_threads | int) %}
|
||||
<vcpu placement='static' current='{{ vcpus | int }}'>{{ vcpus | int }}</vcpu>
|
||||
<resource>
|
||||
<partition>/machine</partition>
|
||||
@ -18,7 +18,7 @@
|
||||
<apic/>
|
||||
</features>
|
||||
<cpu mode='host-model'>
|
||||
<topology sockets='1' cores='{{ item.server_vm_vcpus | int }}' threads='{{ vcpus_threads | int }}'/>
|
||||
<topology sockets='1' cores='{{ hostvars[item]["server_vm_vcpus"] | int }}' threads='{{ vcpus_threads | int }}'/>
|
||||
</cpu>
|
||||
<clock offset='utc'>
|
||||
<timer name='rtc' tickpolicy='catchup'/>
|
||||
@ -36,7 +36,7 @@
|
||||
<emulator>/usr/bin/kvm-spice</emulator>
|
||||
<disk type='block' device='disk'>
|
||||
<driver name='qemu' type='raw' cache='none' io='native'/>
|
||||
<source dev='/dev/vg01/{{ item.server_hostname }}'/>
|
||||
<source dev='/dev/vg01/{{ hostvars[item]["server_hostname"] }}'/>
|
||||
<target dev='vda' bus='virtio'/>
|
||||
<address type='pci' domain='0x0000' bus='0x00' slot='0x09' function='0x0'/>
|
||||
<boot order='1'/>
|
||||
@ -49,10 +49,10 @@
|
||||
<address type='pci' domain='0x0000' bus='0x00' slot='0x0a' function='0x0'/>
|
||||
</controller>
|
||||
|
||||
{% for _key, _value in item.server_networks.items()|sort(attribute='1.iface') %}
|
||||
{% for _key, _value in hostvars[item]['server_networks'].items()|sort(attribute='1.iface') %}
|
||||
<interface type='network'>
|
||||
{% if _key == item.server_vm_primary_network %}
|
||||
<mac address='{{ item.server_mac_address }}'/>
|
||||
{% if _key == hostvars[item]['server_vm_primary_network'] %}
|
||||
<mac address='{{ hostvars[item]["server_mac_address"] }}'/>
|
||||
<boot order='2'/>
|
||||
{% endif %}
|
||||
<source network='{{ _value.vm_int_iface }}'/>
|
||||
@ -98,4 +98,4 @@
|
||||
</rng>
|
||||
|
||||
</devices>
|
||||
</domain>
|
||||
</domain>
|
||||
|
@ -12,4 +12,4 @@ chmod 0700 /root/.ssh
|
||||
echo "{{ tftp_ssh_key }}" >> /root/.ssh/authorized_keys
|
||||
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/mnaio-bridges.cfg -O /etc/network/interfaces.d/mnaio-bridges.cfg
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/basic-interface.cfg -O /etc/network/interfaces
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/basic-debian-interface.cfg -O /etc/network/interfaces
|
@ -87,7 +87,7 @@ global_overrides:
|
||||
### Anchors
|
||||
###
|
||||
log_block: &log_block
|
||||
log1:
|
||||
logging1:
|
||||
ip: 10.0.236.103
|
||||
|
||||
infra_block: &infra_block
|
||||
|
@ -4,4 +4,4 @@
|
||||
auto lo
|
||||
iface lo inet loopback
|
||||
|
||||
source /etc/network/interfaces.d/*.cfg
|
||||
source /etc/network/interfaces.d/*.cfg
|
||||
|
@ -1,6 +1,7 @@
|
||||
# Physical interface, could be bond. This only needs to be set once
|
||||
{% set server_networks = hostvars[item]['server_networks'] %}
|
||||
|
||||
{% for key, value in item.server_networks.items()|sort(attribute='1.iface') %}
|
||||
{% for key, value in server_networks.items()|sort(attribute='1.iface') %}
|
||||
{% if value.iface is defined %}
|
||||
auto {{ value.iface }}
|
||||
iface {{ value.iface }} inet manual
|
||||
@ -8,7 +9,7 @@ iface {{ value.iface }} inet manual
|
||||
|
||||
{% endfor %}
|
||||
|
||||
{% for key, value in item.server_networks.items()|sort(attribute='1.iface') %}
|
||||
{% for key, value in server_networks.items()|sort(attribute='1.iface') %}
|
||||
auto br-{{ key }}
|
||||
iface br-{{ key }} inet {{ value.inet_type }}
|
||||
bridge_stp off
|
||||
|
@ -12,7 +12,7 @@ chmod 0700 /root/.ssh
|
||||
echo "{{ tftp_ssh_key }}" >> /root/.ssh/authorized_keys
|
||||
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/$(cat /etc/hostname)-bridges.cfg -O /etc/network/interfaces.d/vm-bridges.cfg
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/basic-interface.cfg -O /etc/network/interfaces
|
||||
wget --no-proxy http://{{ tftp_server }}/networking/basic-debian-interface.cfg -O /etc/network/interfaces
|
||||
|
||||
cat > /etc/network/if-up.d/post-up-rules <<EOF
|
||||
#!/usr/bin/env bash
|
||||
|
@ -219,7 +219,7 @@ d-i grub-installer/only_debian boolean true
|
||||
# Post Install
|
||||
|
||||
d-i preseed/late_command string \
|
||||
in-target bash -c "wget --no-proxy http://{{ tftp_server }}/scripts/vm-post-install-script.sh -O /opt/vm-post-install-script.sh"; \
|
||||
in-target bash -c "wget --no-proxy http://{{ tftp_server }}/scripts/vm-post-install-debian-script.sh -O /opt/vm-post-install-script.sh"; \
|
||||
in-target bash -c 'chmod +x /opt/vm-post-install-script.sh'; \
|
||||
in-target bash -c '/opt/vm-post-install-script.sh'
|
||||
# Finish
|
||||
|
@ -1,9 +1,11 @@
|
||||
{% set image_properties = images[item.server_image] %}
|
||||
{% set server_vars = hostvars[item] %}
|
||||
{% set image_properties = images[server_vars['server_image']] %}
|
||||
|
||||
default linux
|
||||
prompt 0
|
||||
timeout 1
|
||||
label linux
|
||||
kernel {{ image_properties['image_kernel'] }}
|
||||
{% if image_properties['image_type'] == 'debian' %}
|
||||
append hostname={{ item.server_hostname }} {{ image_properties['image_kernel_options'] }} initrd={{ image_properties['image_initrd'] }} preseed/url={{ image_properties['image_preseeds'][item.server_preseed_ks]['url'] }} preseed/interactive=false netcfg/choose_interface={{ item.server_default_interface }} {{ item.server_extra_options | default('') }}
|
||||
append hostname={{ server_vars['server_hostname'] }} {{ image_properties['image_kernel_options'] }} initrd={{ image_properties['image_initrd'] }} preseed/url={{ image_properties['image_preseeds'][server_vars['server_preseed_ks']]['url'] }} preseed/interactive=false netcfg/choose_interface={{ server_vars['server_default_interface'] }} {{ server_vars['server_extra_options'] | default('') }}
|
||||
{% endif %}
|
||||
|
@ -14,7 +14,7 @@
|
||||
# limitations under the License.
|
||||
|
||||
- name: Gather facts
|
||||
hosts: localhost
|
||||
hosts: mnaio_hosts
|
||||
gather_facts: "{{ gather_facts | default(true) }}"
|
||||
pre_tasks:
|
||||
- name: Gather variables for each operating system
|
||||
@ -121,7 +121,7 @@
|
||||
|
||||
- name: Drop host network interfaces
|
||||
template:
|
||||
src: "pxe/{{ ansible_os_family | lower }}/mnaio-bridges.cfg.j2"
|
||||
src: "mnaio/{{ ansible_os_family | lower }}/mnaio-bridges.cfg.j2"
|
||||
dest: /etc/network/interfaces.d/mnaio-bridges.cfg
|
||||
mode: "0644"
|
||||
owner: root
|
||||
@ -277,7 +277,5 @@
|
||||
state: restarted
|
||||
enabled: yes
|
||||
|
||||
vars_files:
|
||||
- vars/main.yml
|
||||
tags:
|
||||
- setup-host
|
||||
|
@ -1,631 +0,0 @@
|
||||
---
|
||||
############### DEFAULTS ###############
|
||||
default_interface: "{{ default_network | default('eth0') }}"
|
||||
default_vm_image: "{{ default_image | default('ubuntu-16.04-amd64') }}"
|
||||
default_vm_storage: "{{ vm_disk_size | default(92160) }}"
|
||||
|
||||
default_ubuntu_mirror_proxy: 'http://10.0.2.1:3142/'
|
||||
default_ubuntu_mirror_hostname: archive.ubuntu.com
|
||||
default_ubuntu_mirror_directory: /ubuntu
|
||||
############### DEFAULTS ###############
|
||||
|
||||
|
||||
############### MNAIO ###############
|
||||
# mnaio_data_disk: 'sdc' # str - not required, set this to define a given data disk if no data disk
|
||||
# is defined the largest unpartitioned disk will be used.
|
||||
|
||||
mnaio_host_networks:
|
||||
dhcp:
|
||||
iface: 'vm-br-dhcp' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.2.1/22' # str - not required, must be in CIDR format
|
||||
iface_port: none # str - required, physical port used within a host bridge
|
||||
mgmt:
|
||||
iface: 'vm-br-eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.1/22'
|
||||
iface_port: none
|
||||
flat:
|
||||
iface: 'vm-br-eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.1/22'
|
||||
iface_port: none
|
||||
vlan:
|
||||
iface: 'vm-br-eth3'
|
||||
inet_type: 'manual'
|
||||
iface_port: none
|
||||
vxlan:
|
||||
iface: 'vm-br-eth4'
|
||||
inet_type: 'manual'
|
||||
address: '10.0.240.1/22'
|
||||
iface_port: none
|
||||
storage:
|
||||
iface: 'vm-br-eth5'
|
||||
inet_type: 'manual'
|
||||
address: '10.0.244.1/22'
|
||||
iface_port: none
|
||||
|
||||
mnaio_host_iptables_rules:
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: tcp
|
||||
match: tcp
|
||||
destination_port: 67
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 67
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 53
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: INPUT
|
||||
protocol: udp
|
||||
match: udp
|
||||
destination_port: 53
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: FORWARD
|
||||
in_interface: vm-br-dhcp
|
||||
jump: ACCEPT
|
||||
- table: filter
|
||||
chain: FORWARD
|
||||
out_interface: vm-br-dhcp
|
||||
jump: ACCEPT
|
||||
- table: nat
|
||||
chain: POSTROUTING
|
||||
out_interface: "{{ masquerade_interface | default(default_interface) }}"
|
||||
jump: MASQUERADE
|
||||
############### MNAIO ###############
|
||||
|
||||
|
||||
############### PXE ###############
|
||||
tftp_port: 69
|
||||
tftp_boot_dir: "/var/lib/tftpboot"
|
||||
tftp_server: "{{ ansible_host }}" # IP address, or domain name of the TFTP server
|
||||
# tftp_ssh_key: '' # user defined ssh key, used to access the host
|
||||
|
||||
# Default ISO images
|
||||
images:
|
||||
ubuntu-16.04-amd64:
|
||||
image_type: debian
|
||||
image_iso_url: "http://releases.ubuntu.com/16.04.2/ubuntu-16.04.2-server-amd64.iso"
|
||||
image_name: "ubuntu-16.04.2-server-amd64.iso"
|
||||
image_short_name: "ubuntu-16.04.2-server-amd64"
|
||||
image_default_boot: "ubuntu-16.04.2-server-amd64/amd64/boot-screens/menu.cfg"
|
||||
image_kernel_options: "biosdevname=0 net.ifnames=0 auto=true priority=critical vga=789"
|
||||
image_kernel: "ubuntu-16.04.2-server-amd64/amd64/linux"
|
||||
image_initrd: "ubuntu-16.04.2-server-amd64/amd64/initrd.gz"
|
||||
image_netboot: "ubuntu-16.04.2-server-amd64/install/netboot/ubuntu-installer"
|
||||
image_preseeds:
|
||||
mnaio:
|
||||
url: "tftp://{{ tftp_server }}/preseed/mnaio.preseed"
|
||||
template_name: "mnaio.preseed"
|
||||
vm:
|
||||
url: "tftp://{{ tftp_server }}/preseed/vm.preseed"
|
||||
template_name: "vm.preseed"
|
||||
ubuntu-14.04-amd64:
|
||||
image_type: debian
|
||||
image_iso_url: "http://releases.ubuntu.com/14.04.5/ubuntu-14.04.5-server-amd64.iso"
|
||||
image_name: "ubuntu-14.04.5-server-amd64.iso"
|
||||
image_short_name: "ubuntu-14.04.5-server-amd64"
|
||||
image_default_boot: "ubuntu-14.04.5-server-amd64/amd64/boot-screens/menu.cfg"
|
||||
image_kernel_options: "biosdevname=0 net.ifnames=0 auto=true priority=critical vga=789"
|
||||
image_kernel: "ubuntu-14.04.5-server-amd64/amd64/linux"
|
||||
image_initrd: "ubuntu-14.04.5-server-amd64/amd64/initrd.gz"
|
||||
image_netboot: "ubuntu-14.04.5-server-amd64/install/netboot/ubuntu-installer"
|
||||
image_preseeds:
|
||||
mnaio:
|
||||
url: "tftp://{{ tftp_server }}/preseed/mnaio.preseed"
|
||||
template_name: "mnaio.preseed"
|
||||
vm:
|
||||
url: "tftp://{{ tftp_server }}/preseed/vm.preseed"
|
||||
template_name: "vm.preseed"
|
||||
|
||||
pxelinux_url: "https://www.kernel.org/pub/linux/utils/boot/syslinux/syslinux-6.03.tar.gz"
|
||||
pxelinux_name: "syslinux-6.03.tar.gz"
|
||||
pxelinux_short_name: "syslinux-6.03"
|
||||
############### PXE ###############
|
||||
|
||||
|
||||
############### SERVERS ###############
|
||||
# List of servers to create specific mac address bound boot entries.
|
||||
servers:
|
||||
- server_hostname: 'infra1' # str - required, hostname of server
|
||||
server_vm_ram: 8192 # int - not required, used to specify ram when provisioning a VM
|
||||
server_vm_vcpus: 4 # int - not required, used to specify vcpus when provisioning a VM
|
||||
server_vm_fixed_addr: '10.0.2.100' # str - not required, used to specify fixed address when using internal DHCPD
|
||||
server_vm_primary_network: 'dhcp' # str - not required, primary network used to kick the VM
|
||||
server_image: "{{ default_vm_image }}" # str - required, image name
|
||||
server_default_interface: 'eth0' # str - required, default interface
|
||||
server_mac_address: '52:54:00:bd:80:00' # str - required, mac address of default interface
|
||||
server_preseed_ks: 'vm' # str - required, name of preseed/kickstart file
|
||||
server_extra_options: '' # str - not required, added kernel options
|
||||
server_networks: # dict - required, hash of networks, can be empty, key is used to name the networks.
|
||||
dhcp:
|
||||
iface: 'eth0' # str - required, interface name
|
||||
inet_type: 'dhcp' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-dhcp # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
mgmt:
|
||||
iface: 'eth1' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.236.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth1 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
flat:
|
||||
iface: 'eth2' # str - required, interface name
|
||||
inet_type: 'static' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.248.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth2 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vlan:
|
||||
iface: 'eth3' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
vm_int_iface: vm-br-eth3 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
vxlan:
|
||||
iface: 'eth4' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.240.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth4 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
storage:
|
||||
iface: 'eth5' # str - required, interface name
|
||||
inet_type: 'manual' # str - required, iface type [static, dhcp, manual]
|
||||
address: '10.0.244.100/22' # str - not required, must be in CIDR format
|
||||
vm_int_iface: vm-br-eth5 # str - not Required, used to specify an integration networks interface when provisioning a VM
|
||||
- server_hostname: 'infra2'
|
||||
server_vm_ram: 8192
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.101'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:01'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.101/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.101/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.101/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.101/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'infra3'
|
||||
server_vm_ram: 8192
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.102'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:02'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.102/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.102/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.102/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.102/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'logging1'
|
||||
server_vm_ram: 1024
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.110'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:03'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.103/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.103/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.103/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.103/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'compute1'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.120'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:05'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.105/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.105/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.105/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.105/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'compute2'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 4
|
||||
server_vm_fixed_addr: '10.0.2.121'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:06'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.106/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.106/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.106/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.106/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'cinder1'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.130'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:07'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.107/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.107/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.107/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.107/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'cinder2'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.131'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:08'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.108/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.108/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.108/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.108/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'swift1'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.140'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:09'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.109/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.109/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.109/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.109/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'swift2'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.140'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:10'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.110/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.110/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.110/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.110/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'swift3'
|
||||
server_vm_ram: 2048
|
||||
server_vm_vcpus: 2
|
||||
server_vm_fixed_addr: '10.0.2.141'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:11'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.111/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.111/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.111/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.111/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
- server_hostname: 'loadbalancer1'
|
||||
server_vm_ram: 1024
|
||||
server_vm_vcpus: 1
|
||||
server_vm_fixed_addr: '10.0.2.142'
|
||||
server_vm_primary_network: 'dhcp'
|
||||
server_image: "{{ default_vm_image }}"
|
||||
server_default_interface: 'eth0'
|
||||
server_mac_address: '52:54:00:bd:80:12'
|
||||
server_preseed_ks: 'vm'
|
||||
server_extra_options: ''
|
||||
server_networks:
|
||||
dhcp:
|
||||
iface: 'eth0'
|
||||
inet_type: 'dhcp'
|
||||
vm_int_iface: vm-br-dhcp
|
||||
mgmt:
|
||||
iface: 'eth1'
|
||||
inet_type: 'static'
|
||||
address: '10.0.236.112/22'
|
||||
vm_int_iface: vm-br-eth1
|
||||
flat:
|
||||
iface: 'eth2'
|
||||
inet_type: 'static'
|
||||
address: '10.0.248.112/22'
|
||||
vm_int_iface: vm-br-eth2
|
||||
vlan:
|
||||
iface: 'eth3'
|
||||
inet_type: 'manual'
|
||||
vm_int_iface: vm-br-eth3
|
||||
vxlan:
|
||||
iface: 'eth4'
|
||||
inet_type: 'static'
|
||||
address: '10.0.240.112/22'
|
||||
vm_int_iface: vm-br-eth4
|
||||
storage:
|
||||
iface: 'eth5'
|
||||
inet_type: 'static'
|
||||
address: '10.0.244.112/22'
|
||||
vm_int_iface: vm-br-eth5
|
||||
############### SERVERS ###############
|
||||
|
||||
|
||||
############### DHCP ###############
|
||||
dhcp_default_lease_time: 21600 # Default lease time
|
||||
dhcp_max_lease_time: 43200 # Max lease time
|
||||
tftp_boot_path: /pxelinux.0 # Path of where to boot from first
|
||||
|
||||
# - List of DHCP Subnets - These are iterated though and each will be created
|
||||
dhcp_list:
|
||||
- netmask: 255.255.255.0 # Netmask
|
||||
gateway: 10.0.2.1 # Gateway
|
||||
dns: 8.8.8.8 # DNS
|
||||
subnet: 10.0.2.0 # Subnet mask
|
||||
default_lease_time: 21600 # Subnet Default lease time - The default is used if this is not defined
|
||||
max_lease_time: 43200 # Subnet Max lease time - The default is used if this is not defined
|
||||
tftp_boot_path: /pxelinux.0 # Path for tftp of where to boot from first - The default is used if this is not defined
|
||||
tftp_server: "{{ tftp_server }}" # The server hosting the TFTP server - The default is used if this is not defined
|
||||
dhcp_default_domain_name: openstackci.local
|
||||
############### DHCP ###############
|
||||
|
||||
|
||||
############### KVM ###############
|
||||
############### KVM ###############
|
Loading…
x
Reference in New Issue
Block a user