-
Notifications
You must be signed in to change notification settings - Fork 0
/
add_virbr2_vlan_network.yml
217 lines (208 loc) · 9.52 KB
/
add_virbr2_vlan_network.yml
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
---
- name: |
Add virbr2 vlan network for dns virtual machine
Add host okd clusters network following documentation available here https://jamielinux.com/docs/libvirt-networking-handbook/custom-nat-based-network.html
By default libvirt handle iptable rules automatically. However the iptable is not saved after libvirt modification.
if the service iptables is restarted all the changed previously done by libvirt is lost. You need to send a SIGUP to the libvert pid to regenerate iptable rules.
Moreover, I've got an issue - due to iptable rules - regarding the intra communication between guests. One is able to ping the other, and the other is not allowed to ping one :(
So I decided to provide my own custom setup following the previous documentation.
vars:
default_network_name: default
bridge_name: "virbr2"
bridge_mac: "52:54:00:00:06:01"
bridge_ip: "10.0.6.1"
dns_mac: "52:54:00:00:06:10"
dns_ip: "10.0.6.10"
dhcp_range_start: "10.0.6.10"
dhcp_range_end: "10.0.6.254"
block:
- name: Get network defined
virt_net:
command: list_nets
register: networks
- name: Destroy default network
virt_net:
autostart: false
command: destroy
name: "{{ default_network_name }}"
when: default_network_name|string in networks.list_nets
- name: Undefine default network
virt_net:
command: undefine
name: "{{ default_network_name }}"
when: default_network_name|string in networks.list_nets
- name: Add {{ bridge_name }} virtual lan bridge
copy:
dest: /etc/sysconfig/network-scripts/ifcfg-{{ bridge_name }}
content: |
DEVICE="{{ bridge_name }}"
BOOTPROTO="static"
IPADDR="{{ bridge_ip }}"
MACADDR="{{ bridge_mac }}"
NETMASK="255.255.255.0"
ONBOOT="yes"
TYPE="Bridge"
NM_CONTROLLED="no"
- name: Restart service network
systemd:
state: restarted
name: network
- name: Do not bind {{ bridge_name }} into Host system dnsmasq
block:
- name: Create system dnsmaq exclusion for {{ bridge_name }}
copy:
dest: /etc/dnsmasq.d/{{ bridge_name }}.conf
content: |
except-interface={{ bridge_name }}
- name: Restart dnsmasq
systemd:
state: restarted
name: dnsmasq
- name: Forward {{ bridge_name }} connection
block:
- name: Enable IP forwarding / masquerading
block:
- name: Enable on the fly IP forwarding / masquerading
shell: sysctl -w net.ipv4.ip_forward=1
- name: Persist IP forwarding / masquerading
copy:
dest: /etc/sysctl.d/99-openshift.conf
content: |
net.ipv4.ip_forward=1
mode: u=rw,g=r,o=r
owner: root
group: root
- name: Reboot sysctl
shell: sysctl -p
- name: Add firewall rules to allow ip forwarding / masquerading
block:
- name: Setup iptables rules on Host to allow SSH to connect on the fly instead of hanging ...
block:
- name: |
Remove all previous forward rules regarding {{ bridge_name }}
https://stackoverflow.com/questions/25055121/can-i-remove-multiple-matching-rules-with-the-iptables-delete-command
shell: "iptables -S FORWARD | grep {{ bridge_name }} | cut -d ' ' -f 2- | xargs -rL1 iptables -D"
- name: Forward all input in interface {{ bridge_name }}
shell: "iptables -I FORWARD 1 --in-interface {{ bridge_name }} -j ACCEPT"
- name: Forward all output out interface {{ bridge_name }}
shell: "iptables -I FORWARD 1 --out-interface {{ bridge_name }} -j ACCEPT"
- name: Allow all virtual machine connected to bridge {{ bridge_name }} to access to internet using nat from Host
block:
- name: Retrieve interface connected to internet
shell: ip route | grep default | cut -d " " -f 5
register: interface_connected_to_internet
- debug:
msg: "{{ interface_connected_to_internet.stdout }}"
- name: Bind interface {{ bridge_name }} with {{ interface_connected_to_internet.stdout }}
shell: "iptables -t nat -I POSTROUTING -o {{ interface_connected_to_internet.stdout }} -j MASQUERADE"
- name: Save iptable rules
shell: "service iptables save"
# - name: Should {{ bridge_name }} be forwarded HOW TO TEST ???
- name: Setup Host {{ bridge_name }} dnsmasq used for dhcp configuration
block:
- name: Create {{ bridge_name }} directory
file:
path: "{{ item }}"
state: directory
mode: u=rwx,g=rx,o=rx
owner: "root"
group: "root"
with_items:
- "/var/lib/dnsmasq"
- "/var/lib/dnsmasq/{{ bridge_name }}"
- name:
Create {{ bridge_name }} specific resolv.conf.
If a nameserver is defined to my dns.okd.local ip and defined to /etc/resolv.conf and this one is not started, making ssh request on dns.okd.local ip will hang.
Example nameserver = 10.0.6.10 ... ssh [email protected] will do a lot of lookup on an unresponsive dns server. And it will be hard to connect and make my requests failing.
I could get default nameserver but I prefer to rely to 8.8.8.8 google one !
copy:
dest: /var/lib/dnsmasq/{{ bridge_name }}/resolv.conf
content: |
nameserver 8.8.8.8
mode: u=rw,g=r,o=r
owner: root
group: root
- name: Create {{ bridge_name }} dnsmasq.conf
copy:
dest: /var/lib/dnsmasq/{{ bridge_name }}/dnsmasq.conf
content: |
# Only bind to the virtual bridge. This avoids conflicts with other running
# dnsmasq instances.
except-interface=lo
interface={{ bridge_name }}
bind-dynamic
resolv-file=/var/lib/dnsmasq/{{ bridge_name }}/resolv.conf
# If using dnsmasq 2.62 or older, remove "bind-dynamic" and "interface" lines
# and uncomment these lines instead:
#bind-interfaces
#listen-address=192.168.100.1
# IPv4 addresses to offer to VMs. This should match the chosen subnet.
dhcp-range={{ dhcp_range_start }},{{ dhcp_range_end }}
# Set this to at least the total number of addresses in DHCP-enabled subnets.
dhcp-lease-max=1000
# File to write DHCP lease information to.
dhcp-leasefile=/var/lib/dnsmasq/{{ bridge_name }}/leases
# File to read DHCP host information from.
dhcp-hostsfile=/var/lib/dnsmasq/{{ bridge_name }}/hostsfile
# Avoid problems with old or broken clients.
dhcp-no-override
# https://www.redhat.com/archives/libvir-list/2010-March/msg00038.html
strict-order
# expose dns to use by the dns VM.
# /!\ Not working I do not why... I fix it in dns virtual machine cloud-init
dhcp-option=6,{{ dns_ip }},{{ bridge_ip }}
cache-size=10000
log-dhcp
log-queries=extra
log-facility=/var/log/dnsmasq-{{ bridge_name }}.log
mode: u=rw,g=r,o=r
owner: root
group: root
- name: Create {{ bridge_name }} hostsfile
copy:
dest: /var/lib/dnsmasq/{{ bridge_name }}/hostsfile
content: |
{{ dns_mac }},{{ dns_ip }}
mode: u=rw,g=r,o=r
owner: root
group: root
- name: Create {{ bridge_name }} leases
copy:
dest: /var/lib/dnsmasq/{{ bridge_name }}/leases
content: |
mode: u=rw,g=r,o=r
owner: root
group: root
- name: Create persistente execution of {{ bridge_name }} dnsmasq service
block:
- name: Create {{ bridge_name }} dnsmasq service
copy:
dest: /etc/systemd/system/[email protected]
content: |
# '%i' becomes 'virbr10' when running `systemctl start [email protected]`
# Remember to run `systemctl daemon-reload` after creating or editing this file.
[Unit]
Description=DHCP and DNS caching server for %i.
After=network.target
[Service]
ExecStart=/usr/sbin/dnsmasq -k --conf-file=/var/lib/dnsmasq/%i/dnsmasq.conf
ExecReload=/bin/kill -HUP $MAINPID
Restart=on-failure
RestartSec=5
[Install]
WantedBy=multi-user.target
mode: u=rwx,g=rx,o=rx
owner: root
group: root
- name: Enable {{ bridge_name }} dnsmasq service
shell: systemctl enable dnsmasq@{{ bridge_name }}.service
- name: Start {{ bridge_name }} dnsmasq service
shell: systemctl start dnsmasq@{{ bridge_name }}.service
- name: Should defined dnsmasq be reachable
wait_for:
host: "{{ bridge_ip }}"
port: 53
state: drained
delay: 10
become: true
become_user: root