From ce3a9cfae533d1ea49df13d2b8e75b62b6fd8093 Mon Sep 17 00:00:00 2001 From: Felix Fontein Date: Fri, 16 Nov 2018 07:20:32 +0100 Subject: [PATCH] Only pass ipam parameter to create_network() if needed. (#48735) --- .../modules/cloud/docker/docker_network.py | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/lib/ansible/modules/cloud/docker/docker_network.py b/lib/ansible/modules/cloud/docker/docker_network.py index f64654bbd2..e8eef59109 100644 --- a/lib/ansible/modules/cloud/docker/docker_network.py +++ b/lib/ansible/modules/cloud/docker/docker_network.py @@ -424,12 +424,17 @@ class DockerNetworkManager(object): else: ipam_pools.append(utils.create_ipam_pool(**ipam_pool)) - if HAS_DOCKER_PY_2 or HAS_DOCKER_PY_3: - params['ipam'] = IPAMConfig(driver=self.parameters.ipam_driver, - pool_configs=ipam_pools) - else: - params['ipam'] = utils.create_ipam_config(driver=self.parameters.ipam_driver, - pool_configs=ipam_pools) + if self.parameters.ipam_driver or ipam_pools: + # Only add ipam parameter if a driver was specified or if IPAM parameters + # were specified. Leaving this parameter away can significantly speed up + # creation; on my machine creation with this option needs ~15 seconds, + # and without just a few seconds. + if HAS_DOCKER_PY_2 or HAS_DOCKER_PY_3: + params['ipam'] = IPAMConfig(driver=self.parameters.ipam_driver, + pool_configs=ipam_pools) + else: + params['ipam'] = utils.create_ipam_config(driver=self.parameters.ipam_driver, + pool_configs=ipam_pools) if self.parameters.enable_ipv6 is not None: params['enable_ipv6'] = self.parameters.enable_ipv6