4745e709f6
This commit removes the use of the net-cache flushing from all $service plays which ensures that the cache is not overly flushed which could impact performance of services like neutron. The role lxc-container-destroy role was removed because its not used and if it were ever used it its use would result in the same situation covered by this issue. Additionally it was noted that on container restarts, the mac addresses of the container interfaces change. If *no* flushing is done at all, this results in long run times whilst the arp entry for the container IP times out. Hence, we add in here a configuration option that causes a gratuitous arp whenever an interface has it's mac set, and/or the link comes up. Because of the way the container veths work, we can't rely on that happening on a linkm up event. So we forcefully set the mac address in the post-up hook for the interface to force the issue of the gratuitous arp. Co-Authored-By: Evan Callicoat <diopter@gmail.com> Co-Authored-By: Darren Birkett <darren.birkett@gmail.com> Change-Id: I96800b2390ffbacb8341e5538545a3c3a4308cf3 Closes-Bug: 1497433 |
||
---|---|---|
.. | ||
defaults | ||
handlers | ||
meta | ||
tasks | ||
templates | ||
CONTRIBUTING.rst | ||
LICENSE | ||
README.rst |
OpenStack LXC container create
- tags
-
openstack, lxc, container, cloud, ansible
- category
-
*nix
Role for creating LXC containers. This role has been setup for use in OpenStack. This role will create several directories on the LXC host for use in bind mounted storage within the container.
- Example Play:
-
- name: Create container(s) hosts: all_containers gather_facts: false user: root roles: - { role: "lxc_container_create", tags: [ "lxc-container-create" ] }
- Example Inventory:
-
{ "all_containers": { "children": [ "group_of_containers" ], "hosts": [] }, "lxc_hosts": { "children": [], "hosts": [ "infra1" ] }, "group_of_containers": { "children": [], "hosts": [ "container1" ] }, "_meta": { "hostvars": { "infra1": { "ansible_ssh_host": "192.168.0.1", "container_address": "192.168.0.1", "container_name": "infra1", "container_networks": { "management_address": { "bridge": "br-mgmt", "interface": "eth1", "netmask": "255.255.252.0", "type": "veth" } }, "properties": { "container_release": "trusty", "is_metal": true } }, "container1": { "ansible_ssh_host": "10.0.0.1", "container_address": "10.0.0.1", "container_name": "container1", "container_networks": { "management_address": { "address": "10.0.0.1", "bridge": "br-mgmt", "interface": "eth1", "netmask": "255.255.252.0", "type": "veth" } }, "physical_host": "infra1", "physical_host_group": "lxc_hosts", "properties": { "container_release": "trusty", } } } } }