Started by upstream project "pipeline-templates" build number 452 originally caused by: Triggered by Gerrit: https://gerrit.opensdn.io/c/opensdn-io/tf-dev-env/+/1087 Running as SYSTEM [EnvInject] - Loading node environment variables. Building remotely on slave-openstack-gz1_1 (openstack) in workspace /home/jenkins/workspace/deploy-tf-ansible-os [WS-CLEANUP] Deleting project workspace... [WS-CLEANUP] Deferred wipeout is disabled by the job configuration... [WS-CLEANUP] Done The recommended git tool is: git No credentials specified Wiping out workspace first. Cloning the remote Git repository Cloning repository https://github.com/opensdn-io/tf-jenkins.git > git init /home/jenkins/workspace/deploy-tf-ansible-os/src/opensdn-io/tf-jenkins # timeout=10 Fetching upstream changes from https://github.com/opensdn-io/tf-jenkins.git > git --version # timeout=10 > git --version # 'git version 2.25.1' > git fetch --tags --force --progress -- https://github.com/opensdn-io/tf-jenkins.git +refs/heads/*:refs/remotes/origin/* # timeout=10 > git config remote.origin.url https://github.com/opensdn-io/tf-jenkins.git # timeout=10 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 Avoid second fetch > git rev-parse refs/remotes/origin/master^{commit} # timeout=10 Checking out Revision d123cf296746e4d7c49b1db909bcef43ae30e239 (refs/remotes/origin/master) > git config core.sparsecheckout # timeout=10 > git checkout -f d123cf296746e4d7c49b1db909bcef43ae30e239 # timeout=10 Commit message: "use r24.1 tag for deployer image in ansible case" > git rev-list --no-walk d123cf296746e4d7c49b1db909bcef43ae30e239 # timeout=10 The recommended git tool is: NONE No credentials specified Wiping out workspace first. Cloning the remote Git repository Cloning repository https://github.com/opensdn-io/tf-devstack.git > git init /home/jenkins/workspace/deploy-tf-ansible-os/src/opensdn-io/tf-devstack # timeout=10 Fetching upstream changes from https://github.com/opensdn-io/tf-devstack.git > git --version # timeout=10 > git --version # 'git version 2.25.1' > git fetch --tags --force --progress -- https://github.com/opensdn-io/tf-devstack.git +refs/heads/*:refs/remotes/origin/* # timeout=10 > git config remote.origin.url https://github.com/opensdn-io/tf-devstack.git # timeout=10 > git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/* # timeout=10 Avoid second fetch > git rev-parse refs/remotes/origin/master^{commit} # timeout=10 Checking out Revision 2f03a1e26e811ba39d6f10fd1924476f08a26fcf (refs/remotes/origin/master) > git config core.sparsecheckout # timeout=10 > git checkout -f 2f03a1e26e811ba39d6f10fd1924476f08a26fcf # timeout=10 Commit message: "fix k8s_manifests" > git rev-list --no-walk 2f03a1e26e811ba39d6f10fd1924476f08a26fcf # timeout=10 Copied 3 artifacts from "pipeline-templates" build number 452 [deploy-tf-ansible-os] $ /bin/bash -xe /tmp/jenkins13240174877173742610.sh + source /home/jenkins/workspace/deploy-tf-ansible-os/global.env ++ export PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ export SLAVE=openstack ++ SLAVE=openstack ++ export SLAVE_REGION=gz1 ++ SLAVE_REGION=gz1 ++ export LOGS_HOST=nexus.gz1.opensdn.io ++ LOGS_HOST=nexus.gz1.opensdn.io ++ export LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ export CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export GERRIT_PIPELINE=templates ++ GERRIT_PIPELINE=templates ++ export GERRIT_URL=https://gerrit.opensdn.io/ ++ GERRIT_URL=https://gerrit.opensdn.io/ ++ export GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ export GERRIT_BRANCH=master ++ GERRIT_BRANCH=master ++ export GERRIT_PROJECT=opensdn-io/tf-dev-env ++ GERRIT_PROJECT=opensdn-io/tf-dev-env ++ export REPOS_CHANNEL=latest ++ REPOS_CHANNEL=latest + desc='Pipeline: pipeline-templates-452 Random: 10849 Stream: ansible-os-rocky9' + desc+='
Job logs: http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9' + echo 'DESCRIPTION Pipeline: pipeline-templates-452 Random: 10849 Stream: ansible-os-rocky9
Job logs: http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9' DESCRIPTION Pipeline: pipeline-templates-452 Random: 10849 Stream: ansible-os-rocky9
Job logs: http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9 [description-setter] Description set: Pipeline: pipeline-templates-452 Random: 10849 Stream: ansible-os-rocky9
Job logs: http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9' [deploy-tf-ansible-os] $ /bin/bash -xe /tmp/jenkins8268471629161452711.sh + set -eo pipefail + source /home/jenkins/workspace/deploy-tf-ansible-os/global.env ++ export PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ export SLAVE=openstack ++ SLAVE=openstack ++ export SLAVE_REGION=gz1 ++ SLAVE_REGION=gz1 ++ export LOGS_HOST=nexus.gz1.opensdn.io ++ LOGS_HOST=nexus.gz1.opensdn.io ++ export LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ export CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export GERRIT_PIPELINE=templates ++ GERRIT_PIPELINE=templates ++ export GERRIT_URL=https://gerrit.opensdn.io/ ++ GERRIT_URL=https://gerrit.opensdn.io/ ++ export GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ export GERRIT_BRANCH=master ++ GERRIT_BRANCH=master ++ export GERRIT_PROJECT=opensdn-io/tf-dev-env ++ GERRIT_PROJECT=opensdn-io/tf-dev-env ++ export REPOS_CHANNEL=latest ++ REPOS_CHANNEL=latest + ./src/opensdn-io/tf-jenkins/infra/gerrit/apply_patchsets.sh ./src opensdn-io/tf-jenkins ./patchsets-info.json + ./src/opensdn-io/tf-jenkins/infra/gerrit/apply_patchsets.sh ./src opensdn-io/tf-devstack ./patchsets-info.json [deploy-tf-ansible-os] $ /bin/bash -xe /tmp/jenkins6090180856505892539.sh + set -eo pipefail + source /home/jenkins/workspace/deploy-tf-ansible-os/global.env ++ export PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ PIPELINE_BUILD_TAG=jenkins-pipeline-templates-452 ++ export SLAVE=openstack ++ SLAVE=openstack ++ export SLAVE_REGION=gz1 ++ SLAVE_REGION=gz1 ++ export LOGS_HOST=nexus.gz1.opensdn.io ++ LOGS_HOST=nexus.gz1.opensdn.io ++ export LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ LOGS_URL=http://nexus.gz1.opensdn.io:8082/jenkins_logs/gerrit/87/1087/70/templates_452 ++ export SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ SITE_MIRROR=http://nexus.gz1.opensdn.io/repository ++ export CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 ++ export CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ DEPLOYER_CONTAINER_REGISTRY_ORIGINAL=nexus.gz1.opensdn.io:5101 ++ export CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ CONTRAIL_DEPLOYER_CONTAINER_TAG_ORIGINAL=master-1_0_8_7-7_0 ++ export GERRIT_PIPELINE=templates ++ GERRIT_PIPELINE=templates ++ export GERRIT_URL=https://gerrit.opensdn.io/ ++ GERRIT_URL=https://gerrit.opensdn.io/ ++ export GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ GERRIT_CHANGE_ID=Ia289594db44a05f440b740738a5dd8dac0500583 ++ export GERRIT_BRANCH=master ++ GERRIT_BRANCH=master ++ export GERRIT_PROJECT=opensdn-io/tf-dev-env ++ GERRIT_PROJECT=opensdn-io/tf-dev-env ++ export REPOS_CHANNEL=latest ++ REPOS_CHANNEL=latest + source ./src/opensdn-io/tf-jenkins/infra/openstack/definitions ++ export PROVIDER=openstack ++ PROVIDER=openstack ++ export OS_NETWORK=management ++ OS_NETWORK=management ++ export OS_DATA_NETWORK=data ++ OS_DATA_NETWORK=data ++ export OS_SG=default ++ OS_SG=default ++ export RESERVED_INSTANCES_COUNT=3 ++ RESERVED_INSTANCES_COUNT=3 ++ export RESERVED_CORES_COUNT=16 ++ RESERVED_CORES_COUNT=16 ++ export VM_BOOT_RETRIES=120 ++ VM_BOOT_RETRIES=120 ++ export VM_BOOT_DELAY=60 ++ VM_BOOT_DELAY=60 ++ export VOLUME_TYPE=ceph-ssd ++ VOLUME_TYPE=ceph-ssd ++ ENVIRONMENT_OS=rocky9 ++ VM_TYPES=(['xsmall']='STD3-1-4' ['small']='STD3-2-8' ['medium']='STD3-4-16' ['large']='STD3-8-32') ++ declare -A VM_TYPES ++ VOLUME_SIZE=(['xsmall']='50' ['small']='50' ['medium']='80' ['large']='80') ++ declare -A VOLUME_SIZE ++ OS_IMAGES=(['CENTOS7']='prepared-centos7' ['CENTOS8']='prepared-centos8' ['UBUNTU20']='prepared-ubuntu20' ['UBUNTU22']='prepared-ubuntu22' ['UBUNTU24']='prepared-ubuntu24' ['ROCKY9']='prepared-rocky92') ++ declare -A OS_IMAGES ++ OS_IMAGE_USERS=(['CENTOS7']='centos' ['CENTOS8']='centos' ['UBUNTU20']='ubuntu' ['UBUNTU22']='ubuntu' ['UBUNTU24']='ubuntu' ['ROCKY9']='rocky' ['ROCKY92']='rocky') ++ declare -A OS_IMAGE_USERS ++ OS_IMAGES_UP=(['CENTOS7']='centos' ['CENTOS8']='centos' ['UBUNTU20']='ubuntu' ['UBUNTU22']='ubuntu' ['UBUNTU24']='ubuntu' ['ROCKY9']='rocky' ['ROCKY92']='rocky') ++ declare -A OS_IMAGES_UP ++ OS_IMAGES_DOWN=(['CENTOS7']='' ['CENTOS8']='' ['UBUNTU20']='' ['UBUNTU22']='' ['UBUNTU24']='' ['ROCKY9']='' ['ROCKY92']='') ++ declare -A OS_IMAGES_DOWN ++ SSH_OPTIONS='-T -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o PasswordAuthentication=no' + source /home/jenkins/workspace/deploy-tf-ansible-os/deps.deploy-tf-ansible-os.10849.env ++ export PROVIDER=openstack ++ PROVIDER=openstack ++ export ENVIRONMENT_OS=ubuntu22 ++ ENVIRONMENT_OS=ubuntu22 ++ export IMAGE=4744ca8a-852c-4f31-8cf0-48b97ea797c5 ++ IMAGE=4744ca8a-852c-4f31-8cf0-48b97ea797c5 ++ export IMAGE_SSH_USER=ubuntu ++ IMAGE_SSH_USER=ubuntu ++ export INSTANCE_IDS=c6f25d69-c059-452f-9c31-84165aeca870, ++ INSTANCE_IDS=c6f25d69-c059-452f-9c31-84165aeca870, ++ export instance_ip=10.0.0.254 ++ instance_ip=10.0.0.254 ++ export CONTROLLER_NODES=10.0.0.254, ++ CONTROLLER_NODES=10.0.0.254, ++ export ORCHESTRATOR=openstack ++ ORCHESTRATOR=openstack ++ export DEPLOYER=ansible ++ DEPLOYER=ansible ++ export JOB_LOGS_PATH=ansible-os-rocky9 ++ JOB_LOGS_PATH=ansible-os-rocky9 + source /home/jenkins/workspace/deploy-tf-ansible-os/vars.deploy-tf-ansible-os.10849.env /tmp/jenkins6090180856505892539.sh: line 6: /home/jenkins/workspace/deploy-tf-ansible-os/vars.deploy-tf-ansible-os.10849.env: No such file or directory + /bin/true + export FULL_LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9 + FULL_LOGS_PATH=/var/www/logs/jenkins_logs/gerrit/87/1087/70/templates_452/ansible-os-rocky9 + ./src/opensdn-io/tf-jenkins/jobs/devstack/ansible/deploy_tf.sh INFO: Deploy ansible/ (deploy-tf-ansible-os) Warning: Permanently added '10.0.0.254' (ECDSA) to the list of known hosts. Warning: Permanently added '10.0.0.254' (ECDSA) to the list of known hosts. INFO: =================== Wed Apr 30 11:44:15 UTC 2025 =================== [there is no tf devenv configuration to load] INFO: Applying stages machines k8s openstack tf wait INFO: Running stage machines at Wed Apr 30 11:44:15 UTC 2025 Skipping stage machines because it's finished INFO: Stage machines was run successfully Wed Apr 30 11:44:15 UTC 2025 INFO: Running stage k8s at Wed Apr 30 11:44:15 UTC 2025 Skipping stage k8s because it's finished INFO: Stage k8s was run successfully Wed Apr 30 11:44:15 UTC 2025 INFO: Running stage openstack at Wed Apr 30 11:44:15 UTC 2025 Skipping stage openstack because it's finished INFO: Stage openstack was run successfully Wed Apr 30 11:44:15 UTC 2025 INFO: Running stage tf at Wed Apr 30 11:44:15 UTC 2025 [WARNING]: log file at /var/log/ansible.log is not writeable and we cannot create it, aborting Using /home/ubuntu/tf-ansible-deployer/ansible.cfg as config file [WARNING]: No inventory was parsed, only implicit localhost is available [WARNING]: provided hosts list is empty, only localhost is available. Note that the implicit localhost does not match 'all' PLAY [Create container host group and evaluate variables for opensdn] ********** TASK [Gathering Facts] ********************************************************* ok: [localhost] TASK [Expose instances] ******************************************************** ok: [localhost] => {"ansible_facts": {"instances": {"node_10_0_0_254": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}}, "changed": false} TASK [Expose global configuration] ********************************************* ok: [localhost] => {"ansible_facts": {"global_configuration": {"CONTAINER_REGISTRY": "nexus.gz1.opensdn.io:5101", "ENABLE_DESTROY": false, "K8S_YUM_REPO_URL": "http://tf-mirrors.gz1.opensdn.io/repos/yum7/latest/k8s/", "REGISTRY_PRIVATE_INSECURE": true}}, "changed": false} TASK [Expose remote_locations configuration] *********************************** ok: [localhost] => {"ansible_facts": {"remote_locations": {}}, "changed": false} TASK [Expose provider config] ************************************************** ok: [localhost] => {"ansible_facts": {"provider_config": {"bms": {"domainsuffix": "", "ssh_private_key": "/home/ubuntu/.ssh/id_rsa", "ssh_pwd": null, "ssh_user": "ubuntu"}}}, "changed": false} TASK [opensdn_deployer : create container host group] ************************** included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/create_container_host_group.yml for localhost TASK [opensdn_deployer : add bms container hosts] ****************************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"add_host": {"groups": ["container_hosts"], "host_name": "10.0.0.254", "host_vars": {"ansible_become": true, "ansible_ssh_pass": "", "ansible_user": "ubuntu", "instance_name": "node_10_0_0_254", "private_ip": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : add bms container hosts] ****************************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"add_host": {"groups": ["container_hosts"], "host_name": "10.0.0.254", "host_vars": {"ansible_become": true, "ansible_ssh_private_key_file": "/home/ubuntu/.ssh/id_rsa", "ansible_user": "ubuntu", "instance_name": "node_10_0_0_254", "private_ip": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : build node lists] ************************************* included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/build_node_lists.yml for localhost TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"config_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add config nodes to the list] ************************* ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"config_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"control_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add control nodes to the list] ************************ ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"control_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"configdb_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add configdb nodes to the list] *********************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"configdb_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"analytics_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add analytics nodes to the list] ********************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"analytics_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"analytics_snmp_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add analytics snmp nodes to the list] ***************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"analytics_snmp_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"analytics_alarm_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add analytics alarm nodes to the list] **************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"analytics_alarm_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"analyticsdb_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add analyticsdb nodes to the list] ******************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"analyticsdb_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"webui_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add webui nodes to the list] ************************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"webui_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"k8s_master_nodes_list": []}, "changed": false} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"k8s_node_nodes_list": []}, "changed": false} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"kubemanager_nodes_list": []}, "changed": false} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"openstack_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add openstack nodes to the list] ********************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"openstack_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"vrouter_nodes_list": []}, "changed": false} TASK [opensdn_deployer : add Vrouter Nodes to the list] ************************ ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"vrouter_nodes_list": ["10.0.0.254"]}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"tsn_nodes_list": []}, "changed": false} TASK [opensdn_deployer : set global variables] ********************************* included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/set_global_variables.yml for localhost TASK [opensdn_deployer : set container tag contrail version if defined] ******** ok: [localhost] => {"ansible_facts": {"contrail_version_tag": "latest"}, "changed": false} TASK [opensdn_deployer : add specific contrail version tag if defined] ********* ok: [localhost] => {"ansible_facts": {"contrail_version_tag": "master-1_0_8_7-7_0"}, "changed": false} TASK [opensdn_deployer : set registry if defined] ****************************** ok: [localhost] => {"ansible_facts": {"container_registry": "nexus.gz1.opensdn.io:5101"}, "changed": false} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"roles": {}}, "changed": false} TASK [opensdn_deployer : add roles if defined] ********************************* ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"roles": {"node_10_0_0_254": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set vars for vanilla openstack deploy] **************** ok: [localhost] => {"ansible_facts": {"analytics_api_port": 8081, "config_api_port": 8082, "keystone_auth_proto": "http", "keystone_auth_public_port": 5000, "opencontrail_api_server_ip": "10.0.0.254", "opencontrail_collector_ip": "10.0.0.254"}, "changed": false} TASK [opensdn_deployer : set default variables] ******************************** included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/set_default_variables.yml for localhost TASK [opensdn_deployer : set orchestrator param] ******************************* ok: [localhost] => {"ansible_facts": {"default_configuration": {"VXLAN_VN_ID_MODE": "automatic"}}, "changed": false} TASK [opensdn_deployer : set contrail variables] ******************************* included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/set_contrail_variables.yml for localhost TASK [opensdn_deployer : set stdin_open to true if it's not defined] *********** ok: [localhost] => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "VROUTER_ENCRYPTION": false}}, "changed": false} TASK [opensdn_deployer : set tty to true if it's not defined] ****************** ok: [localhost] => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "changed": false} TASK [opensdn_deployer : add nodes to contrail_configuration] ****************** ok: [localhost] => (item={'name': 'CONFIG_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "CONFIG_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'CONTROLLER_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "CONTROLLER_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'CONFIGDB_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "CONFIGDB_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'ANALYTICS_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "ANALYTICS_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'ANALYTICS_SNMP_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "ANALYTICS_SNMP_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'ANALYTICS_ALARM_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "ANALYTICS_ALARM_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'ANALYTICSDB_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "ANALYTICSDB_NODES", "nodes": ["10.0.0.254"]}} ok: [localhost] => (item={'name': 'WEBUI_NODES', 'nodes': ['10.0.0.254']}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": "true", "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"name": "WEBUI_NODES", "nodes": ["10.0.0.254"]}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": false, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "changed": false} TASK [opensdn_deployer : check analyticsdb presence] *************************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": true, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": "true", "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": true, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": false, "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "changed": false} TASK [opensdn_deployer : check analytics alarm presence] *********************** ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": true, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": true, "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": "true", "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": true, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": true, "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": false, "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "changed": false} TASK [opensdn_deployer : check analytics snmp presence] ************************ ok: [localhost] => (item={'key': 'node_10_0_0_254', 'value': {'ip': '10.0.0.254', 'provider': 'bms', 'roles': {'analytics': None, 'analytics_snmp': None, 'analytics_alarm': None, 'analytics_database': None, 'config': None, 'config_database': None, 'control': None, 'webui': None, 'openstack': None, 'vrouter': None, 'openstack_compute': None}}}) => {"ansible_facts": {"contrail_configuration": {"AAA_MODE": "rbac", "ANALYTICSDB_ENABLE": true, "ANALYTICSDB_NODES": "10.0.0.254", "ANALYTICS_ALARM_ENABLE": true, "ANALYTICS_ALARM_NODES": "10.0.0.254", "ANALYTICS_NODES": "10.0.0.254", "ANALYTICS_SNMP_ENABLE": true, "ANALYTICS_SNMP_NODES": "10.0.0.254", "AUTH_MODE": "keystone", "CASSANDRA_SSL_ENABLE": "false", "CLOUD_ORCHESTRATOR": "openstack", "CONFIGDB_NODES": "10.0.0.254", "CONFIG_DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "CONFIG_NODES": "10.0.0.254", "CONTRAIL_CONTAINER_TAG": "master-1_0_8_7-7_0", "CONTROLLER_NODES": "10.0.0.254", "CONTROL_NODES": "10.0.0.254", "DATABASE_NODEMGR__DEFAULTS__minimum_diskGB": "2", "HUGE_PAGES_2MB": "256", "JVM_EXTRA_OPTS": "-Xms1g -Xmx2g", "KEYSTONE_AUTH_URL_VERSION": "/v3", "KOLLA_MODE": "patched", "LOG_LEVEL": "SYS_DEBUG", "OPENSTACK_VERSION": "yoga", "RABBITMQ_USE_SSL": "false", "SSL_ENABLE": "false", "STDIN_OPEN": true, "TTY": true, "VROUTER_ENCRYPTION": false, "WEBUI_NODES": "10.0.0.254"}}, "ansible_loop_var": "item", "changed": false, "item": {"key": "node_10_0_0_254", "value": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}} TASK [opensdn_deployer : explicitly set OpenStack variables for Contrail] ****** ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} TASK [opensdn_deployer : get the internal VIP from openstack node if haproxy is disabled] *** ok: [localhost] => {"ansible_facts": {"openstack_internal_vip": "10.0.0.254"}, "changed": false} TASK [opensdn_deployer : set OpenStack endpoints from kolla_config.kolla_globals] *** ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} ok: [localhost] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} TASK [opensdn_deployer : combine contrail configuration defaults with contrail configuration] *** ok: [localhost] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false} TASK [opensdn_deployer : build cluster node role lists] ************************ included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn_deployer/tasks/cluster_node_role_lists.yml for localhost TASK [opensdn_deployer : set_fact] ********************************************* ok: [localhost] => {"ansible_facts": {"cluster_roles_dict": {}}, "changed": false} TASK [opensdn_deployer : Calculate Existing Roles] ***************************** ok: [localhost] => {"ansible_facts": {"cluster_roles_dict": {"api_server_ip": null, "deleted_nodes_dict": {}, "node_roles_dict": {}}}, "changed": false} TASK [opensdn_deployer : Calculate node roles Dict] **************************** ok: [localhost] => {"ansible_facts": {"node_roles_dict": {}}, "changed": false} TASK [opensdn_deployer : Calculate deleted role Dict] ************************** ok: [localhost] => {"ansible_facts": {"deleted_nodes_dict": {}}, "changed": false} TASK [opensdn_deployer : set api_server as validated active API server] ******** ok: [localhost] => {"ansible_facts": {"api_server": ""}, "changed": false} TASK [k8s_deployer : init master_ip list] ************************************** ok: [localhost] => {"ansible_facts": {"k8s_master_ip_list": []}, "changed": false} TASK [k8s_deployer : init master_name list] ************************************ ok: [localhost] => {"ansible_facts": {"k8s_master_name_list": []}, "changed": false} TASK [k8s_deployer : show master_ip list] ************************************** ok: [localhost] => { "msg": [] } TASK [k8s_deployer : show master_name list] ************************************ ok: [localhost] => { "msg": [] } PLAY [Remove opensdn from Deleted Nodes ( Deregister )] ************************ TASK [Gathering Facts] ********************************************************* ok: [10.0.0.254] PLAY [Remove opensdn from Deleted Nodes ( Cleanup )] *************************** skipping: no hosts matched [WARNING]: Found variable using reserved name: roles PLAY [Install opensdn] ********************************************************* TASK [Gathering Facts] ********************************************************* ok: [10.0.0.254] TASK [opensdn : set instance data] ********************************************* ok: [10.0.0.254] => {"ansible_facts": {"instance_data": {"ip": "10.0.0.254", "provider": "bms", "roles": {"analytics": null, "analytics_alarm": null, "analytics_database": null, "analytics_snmp": null, "config": null, "config_database": null, "control": null, "openstack": null, "openstack_compute": null, "vrouter": null, "webui": null}}}, "changed": false} TASK [opensdn : set instance name] ********************************************* ok: [10.0.0.254] => {"ansible_facts": {"instance_name": "node_10_0_0_254"}, "changed": false} TASK [opensdn : run common tasks] ********************************************** included: /home/ubuntu/tf-ansible-deployer/playbooks/roles/opensdn/tasks/common_Linux.yml for 10.0.0.254 TASK [opensdn : create /var/log/contrail] ************************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/var/log/contrail", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn : create /etc/contrail/compose] ********************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/compose", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn : populate common.env] ******************************************* changed: [10.0.0.254] => {"changed": true, "checksum": "17ab8a5ced32faa024a2c4e2d760115ac8d7414c", "dest": "/etc/contrail/common.env", "gid": 0, "group": "root", "md5sum": "5f70587db2ede1e80175aa3b17fd7485", "mode": "0640", "owner": "root", "size": 1037, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013474.4907374-55756-268597681369834/source", "state": "file", "uid": 0} TASK [opensdn : populate defaults.env] ***************************************** changed: [10.0.0.254] => {"changed": true, "checksum": "d0ec2d02b27484bcf9f59ef41e7b993311d55516", "dest": "/etc/contrail/defaults.env", "gid": 0, "group": "root", "md5sum": "4a16eb30253a69c955c1d715f6fef5a6", "mode": "0644", "owner": "root", "size": 27, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013475.4549406-55832-62158116923642/source", "state": "file", "uid": 0} TASK [create redis] ************************************************************ [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_redis : update contrail redis image] ***************************** changed: [10.0.0.254] => (item=opensdn-external-redis) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0", "delta": "0:00:01.343587", "end": "2025-04-30 11:44:38.042337", "item": "opensdn-external-redis", "msg": "", "rc": 0, "start": "2025-04-30 11:44:36.698750", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-redis\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\n015db326ab64: Pulling fs layer\n4fa8d8280ca5: Pulling fs layer\neec1d6dc05bb: Pulling fs layer\n4f4fb700ef54: Pulling fs layer\n4f4fb700ef54: Waiting\neec1d6dc05bb: Verifying Checksum\neec1d6dc05bb: Download complete\n015db326ab64: Verifying Checksum\n015db326ab64: Download complete\n4f4fb700ef54: Download complete\n015db326ab64: Pull complete\n4fa8d8280ca5: Verifying Checksum\n4fa8d8280ca5: Download complete\n4fa8d8280ca5: Pull complete\neec1d6dc05bb: Pull complete\n4f4fb700ef54: Pull complete\nDigest: sha256:9dbabfec9750d495afcad90f4dd16519998e97040e5682ccae4b0bdd1e06f993\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-redis", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "015db326ab64: Pulling fs layer", "4fa8d8280ca5: Pulling fs layer", "eec1d6dc05bb: Pulling fs layer", "4f4fb700ef54: Pulling fs layer", "4f4fb700ef54: Waiting", "eec1d6dc05bb: Verifying Checksum", "eec1d6dc05bb: Download complete", "015db326ab64: Verifying Checksum", "015db326ab64: Download complete", "4f4fb700ef54: Download complete", "015db326ab64: Pull complete", "4fa8d8280ca5: Verifying Checksum", "4fa8d8280ca5: Download complete", "4fa8d8280ca5: Pull complete", "eec1d6dc05bb: Pull complete", "4f4fb700ef54: Pull complete", "Digest: sha256:9dbabfec9750d495afcad90f4dd16519998e97040e5682ccae4b0bdd1e06f993", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-stunnel) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-1_0_8_7-7_0", "delta": "0:00:01.226859", "end": "2025-04-30 11:44:39.769337", "item": "opensdn-external-stunnel", "msg": "", "rc": 0, "start": "2025-04-30 11:44:38.542478", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-stunnel\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nfa8df4c7fd85: Pulling fs layer\n208ee2b74381: Pulling fs layer\nfa8df4c7fd85: Verifying Checksum\nfa8df4c7fd85: Download complete\nfa8df4c7fd85: Pull complete\n208ee2b74381: Verifying Checksum\n208ee2b74381: Download complete\n208ee2b74381: Pull complete\nDigest: sha256:f6455c8dfcef29b87d1b3b4fe40f58aaedcc5b0a24c161df12535931943f456e\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-stunnel", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "fa8df4c7fd85: Pulling fs layer", "208ee2b74381: Pulling fs layer", "fa8df4c7fd85: Verifying Checksum", "fa8df4c7fd85: Download complete", "fa8df4c7fd85: Pull complete", "208ee2b74381: Verifying Checksum", "208ee2b74381: Download complete", "208ee2b74381: Pull complete", "Digest: sha256:f6455c8dfcef29b87d1b3b4fe40f58aaedcc5b0a24c161df12535931943f456e", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-1_0_8_7-7_0"]} TASK [opensdn_redis : create /etc/contrail/redis] ****************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/redis", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_redis : Set variables for Stunnel] ******************************* ok: [10.0.0.254] => {"ansible_facts": {"redis_ssl_enable": false}, "changed": false} TASK [opensdn_redis : create redis compose file] ******************************* changed: [10.0.0.254] => {"changed": true, "checksum": "44054239753149742680f9e01192a7ac36732d85", "dest": "/etc/contrail/redis/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "418fda4e63bec8ba8ed4fb53607a4edc", "mode": "0644", "owner": "root", "size": 200, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013480.8868976-56455-64437795522425/source", "state": "file", "uid": 0} TASK [opensdn_redis : start redis] ********************************************* changed: [10.0.0.254] => {"changed": true, "services": {"redis": {"redis_redis_1": {"cmd": ["redis-server"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "b4341c58c7331b35a105badacd0d664c721933116638c77e49d5100427eb5b0e", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "redis", "com.docker.compose.project.config_files": "/etc/contrail/redis/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/redis", "com.docker.compose.service": "redis", "com.docker.compose.version": "1.29.2", "description": "Contrail Redis server supports query engine.", "io.opensdn.container.name": "opensdn-external-redis", "io.opensdn.service": "redis", "name": "opensdn-external-redis", "release": "5.1.0", "summary": "Contrail Redis", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail config database] ***************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_config_database : update contrail config_database image] ********* changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:03.736933", "end": "2025-04-30 11:44:47.209477", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:44:43.472544", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc8851dd303ab: Pulling fs layer\n1f5174f589ad: Pulling fs layer\n5eb5ef1a9c13: Pulling fs layer\n5eb5ef1a9c13: Download complete\n1f5174f589ad: Verifying Checksum\n1f5174f589ad: Download complete\nc8851dd303ab: Verifying Checksum\nc8851dd303ab: Download complete\nc8851dd303ab: Pull complete\n1f5174f589ad: Pull complete\n5eb5ef1a9c13: Pull complete\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c8851dd303ab: Pulling fs layer", "1f5174f589ad: Pulling fs layer", "5eb5ef1a9c13: Pulling fs layer", "5eb5ef1a9c13: Download complete", "1f5174f589ad: Verifying Checksum", "1f5174f589ad: Download complete", "c8851dd303ab: Verifying Checksum", "c8851dd303ab: Download complete", "c8851dd303ab: Pull complete", "1f5174f589ad: Pull complete", "5eb5ef1a9c13: Pull complete", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:02.230638", "end": "2025-04-30 11:44:49.890197", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:44:47.659559", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc8851dd303ab: Already exists\n1f5174f589ad: Already exists\n9d64e320a5e3: Pulling fs layer\ndcdf8d7478f3: Pulling fs layer\ndcdf8d7478f3: Download complete\n9d64e320a5e3: Verifying Checksum\n9d64e320a5e3: Download complete\n9d64e320a5e3: Pull complete\ndcdf8d7478f3: Pull complete\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c8851dd303ab: Already exists", "1f5174f589ad: Already exists", "9d64e320a5e3: Pulling fs layer", "dcdf8d7478f3: Pulling fs layer", "dcdf8d7478f3: Download complete", "9d64e320a5e3: Verifying Checksum", "9d64e320a5e3: Download complete", "9d64e320a5e3: Pull complete", "dcdf8d7478f3: Pull complete", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-cassandra) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "delta": "0:00:05.527694", "end": "2025-04-30 11:44:55.870838", "item": "opensdn-external-cassandra", "msg": "", "rc": 0, "start": "2025-04-30 11:44:50.343144", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-cassandra\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nadaed188e778: Pulling fs layer\nbee4fd9a2395: Pulling fs layer\nadaed188e778: Verifying Checksum\nadaed188e778: Download complete\nadaed188e778: Pull complete\nbee4fd9a2395: Verifying Checksum\nbee4fd9a2395: Download complete\nbee4fd9a2395: Pull complete\nDigest: sha256:9ca671347a2514c7f6631f30adc632035eeb4a4b806f5792641ab2cb2e20029a\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-cassandra", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "adaed188e778: Pulling fs layer", "bee4fd9a2395: Pulling fs layer", "adaed188e778: Verifying Checksum", "adaed188e778: Download complete", "adaed188e778: Pull complete", "bee4fd9a2395: Verifying Checksum", "bee4fd9a2395: Download complete", "bee4fd9a2395: Pull complete", "Digest: sha256:9ca671347a2514c7f6631f30adc632035eeb4a4b806f5792641ab2cb2e20029a", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-zookeeper) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0", "delta": "0:00:04.909710", "end": "2025-04-30 11:45:01.219095", "item": "opensdn-external-zookeeper", "msg": "", "rc": 0, "start": "2025-04-30 11:44:56.309385", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-zookeeper\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\n24e69ac90fe5: Pulling fs layer\nd2b7e4b5fbf6: Pulling fs layer\n4f4fb700ef54: Pulling fs layer\n24e69ac90fe5: Download complete\n4f4fb700ef54: Download complete\n24e69ac90fe5: Pull complete\nd2b7e4b5fbf6: Verifying Checksum\nd2b7e4b5fbf6: Download complete\nd2b7e4b5fbf6: Pull complete\n4f4fb700ef54: Pull complete\nDigest: sha256:75378247c00fbaa8cf067f5a2ab21e984d0b2e50e6d45eb6ce7ebdf2eee2c3e2\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-zookeeper", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "24e69ac90fe5: Pulling fs layer", "d2b7e4b5fbf6: Pulling fs layer", "4f4fb700ef54: Pulling fs layer", "24e69ac90fe5: Download complete", "4f4fb700ef54: Download complete", "24e69ac90fe5: Pull complete", "d2b7e4b5fbf6: Verifying Checksum", "d2b7e4b5fbf6: Download complete", "d2b7e4b5fbf6: Pull complete", "4f4fb700ef54: Pull complete", "Digest: sha256:75378247c00fbaa8cf067f5a2ab21e984d0b2e50e6d45eb6ce7ebdf2eee2c3e2", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-rabbitmq) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0", "delta": "0:00:03.032092", "end": "2025-04-30 11:45:04.730770", "item": "opensdn-external-rabbitmq", "msg": "", "rc": 0, "start": "2025-04-30 11:45:01.698678", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-rabbitmq\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\n8441bc35c732: Pulling fs layer\nf95577e5793c: Pulling fs layer\n8441bc35c732: Verifying Checksum\n8441bc35c732: Download complete\n8441bc35c732: Pull complete\nf95577e5793c: Verifying Checksum\nf95577e5793c: Download complete\nf95577e5793c: Pull complete\nDigest: sha256:70472aea421e9f119809d9e93e01a3ada2b59523b487dbb8d69188585fbe1b39\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-rabbitmq", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "8441bc35c732: Pulling fs layer", "f95577e5793c: Pulling fs layer", "8441bc35c732: Verifying Checksum", "8441bc35c732: Download complete", "8441bc35c732: Pull complete", "f95577e5793c: Verifying Checksum", "f95577e5793c: Download complete", "f95577e5793c: Pull complete", "Digest: sha256:70472aea421e9f119809d9e93e01a3ada2b59523b487dbb8d69188585fbe1b39", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.292462", "end": "2025-04-30 11:45:05.473960", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:45:05.181498", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc8851dd303ab: Already exists\n1f5174f589ad: Already exists\n778b1bb016b3: Pulling fs layer\n778b1bb016b3: Verifying Checksum\n778b1bb016b3: Download complete\n778b1bb016b3: Pull complete\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c8851dd303ab: Already exists", "1f5174f589ad: Already exists", "778b1bb016b3: Pulling fs layer", "778b1bb016b3: Verifying Checksum", "778b1bb016b3: Download complete", "778b1bb016b3: Pull complete", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_config_database : create /etc/contrail/config_database] ********** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/config_database", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_config_database : set cassandra seeds to CONFIGDB_NODES if defined] *** ok: [10.0.0.254] => {"ansible_facts": {"cassandra_seeds": "10.0.0.254"}, "changed": false} TASK [opensdn_config_database : set zookeeper nodes to CONFIGDB_NODES if defined] *** ok: [10.0.0.254] => {"ansible_facts": {"zookeeper_nodes": "10.0.0.254"}, "changed": false} TASK [opensdn_config_database : set rabbit nodes to CONFIGDB_NODES if defined] *** ok: [10.0.0.254] => {"ansible_facts": {"rabbitmq_nodes": "10.0.0.254"}, "changed": false} TASK [opensdn_config_database : Set variables for reaper tool] ***************** ok: [10.0.0.254] => {"ansible_facts": {"reaper_enabled": "contrail_configuration.CASSANDRA_REAPER_ENABLED | default(true)"}, "changed": false} TASK [opensdn_config_database : get /etc/contrail/common_config_database.env stat] *** ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_config_database : create /etc/contrail/common_config_database.env] *** changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_config_database.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_config_database : populate global common_config_database.env] **** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_config_database : populate pod specific common_config_database.env] *** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_config_database : create contrail config database compose file] *** changed: [10.0.0.254] => {"changed": true, "checksum": "ef44ea7eb31feb4545684f7e7270dfbf20f6ee0e", "dest": "/etc/contrail/config_database/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "c6c1eb1584f9510306611e2bbaaf4351", "mode": "0644", "owner": "root", "size": 4036, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013525.4503188-59260-108676185449701/source", "state": "file", "uid": 0} TASK [opensdn_config_database : start contrail config database] **************** changed: [10.0.0.254] => {"changed": true, "services": {"cassandra": {"config_database_cassandra_1": {"cmd": ["cassandra", "-f"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "1d436187c3d746ab163ab925f0d07a5084644529eb7cab85d18d1a87d4686ed6", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "cassandra", "com.docker.compose.version": "1.29.2", "description": "Configuration database for Contrail Controller.", "io.opensdn.container.name": "opensdn-external-cassandra", "io.opensdn.service": "cassandra", "name": "opensdn-external-cassandra", "release": "5.1.0", "summary": "Contrail Cassandra DB", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"config_database_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"config_database_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "ecb65994ace0a96e3f59e55bd5bc87f5afd3d0507dbf14424936412dd0cc3b79", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"config_database_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "83f9cd04d697345f76ab98e85c8aeaeda77dd643712e726d60972259cd357f85", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "rabbitmq": {"config_database_rabbitmq_1": {"cmd": ["rabbitmq-server"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "103c7a231c5b4f6244927c0e86a9bae7c7388770c67447efef6b1b045ba3ccab", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "rabbitmq", "com.docker.compose.version": "1.29.2", "description": "Contrail Rabbitmq is the message bus that different Contrail processes subscribe to.", "io.opensdn.container.name": "opensdn-external-rabbitmq", "io.opensdn.service": "rabbitmq", "name": "opensdn-external-rabbitmq", "release": "5.1.0", "summary": "Contrail RabbitMQ", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "zookeeper": {"config_database_zookeeper_1": {"cmd": ["zkServer.sh", "start-foreground"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "f5ed9c3ee2f975777b04dd80da1b144c045a6f5edb7150424113742cf415e89c", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config_database", "com.docker.compose.project.config_files": "/etc/contrail/config_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config_database", "com.docker.compose.service": "zookeeper", "com.docker.compose.version": "1.29.2", "description": "Contrail uses the Apache ZooKeeper process to maintain synchronization of Contrail configuration, analytics and database running on the different instances of controllers.", "io.opensdn.container.name": "opensdn-external-zookeeper", "io.opensdn.service": "zookeeper", "name": "opensdn-external-zookeeper", "release": "5.1.0", "summary": "Contrail Zookeeper", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail config] ************************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_config : update contrail config image] *************************** changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.110585", "end": "2025-04-30 11:45:30.537422", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:45:30.426837", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.119545", "end": "2025-04-30 11:45:31.134469", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:45:31.014924", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-config-api) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0", "delta": "0:00:08.952083", "end": "2025-04-30 11:45:40.560888", "item": "opensdn-controller-config-api", "msg": "", "rc": 0, "start": "2025-04-30 11:45:31.608805", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-config-api\n446f83f14b23: Already exists\nf2eaa67e8674: Pulling fs layer\nde64a881df05: Pulling fs layer\n02275d3048eb: Pulling fs layer\n5ba73c705052: Pulling fs layer\nfa68789187c1: Pulling fs layer\nb774710f9e82: Pulling fs layer\ne8e0575a1565: Pulling fs layer\naed38ff48549: Pulling fs layer\nf6fb879da52c: Pulling fs layer\n2ae27a08c3c0: Pulling fs layer\n5ba73c705052: Waiting\nfa68789187c1: Waiting\nb774710f9e82: Waiting\ne8e0575a1565: Waiting\naed38ff48549: Waiting\nf6fb879da52c: Waiting\n2ae27a08c3c0: Waiting\nde64a881df05: Verifying Checksum\nde64a881df05: Download complete\n02275d3048eb: Verifying Checksum\n02275d3048eb: Download complete\nf2eaa67e8674: Verifying Checksum\nf2eaa67e8674: Download complete\n5ba73c705052: Verifying Checksum\n5ba73c705052: Download complete\nfa68789187c1: Download complete\nf2eaa67e8674: Pull complete\naed38ff48549: Download complete\nde64a881df05: Pull complete\nf6fb879da52c: Verifying Checksum\nf6fb879da52c: Download complete\n02275d3048eb: Pull complete\n5ba73c705052: Pull complete\nfa68789187c1: Pull complete\n2ae27a08c3c0: Verifying Checksum\n2ae27a08c3c0: Download complete\nb774710f9e82: Verifying Checksum\nb774710f9e82: Download complete\ne8e0575a1565: Verifying Checksum\ne8e0575a1565: Download complete\nb774710f9e82: Pull complete\ne8e0575a1565: Pull complete\naed38ff48549: Pull complete\nf6fb879da52c: Pull complete\n2ae27a08c3c0: Pull complete\nDigest: sha256:0c74245efaa8873a22d853278c389fb145e33c69a4fe87f650bc8a553cdb54ad\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-config-api", "446f83f14b23: Already exists", "f2eaa67e8674: Pulling fs layer", "de64a881df05: Pulling fs layer", "02275d3048eb: Pulling fs layer", "5ba73c705052: Pulling fs layer", "fa68789187c1: Pulling fs layer", "b774710f9e82: Pulling fs layer", "e8e0575a1565: Pulling fs layer", "aed38ff48549: Pulling fs layer", "f6fb879da52c: Pulling fs layer", "2ae27a08c3c0: Pulling fs layer", "5ba73c705052: Waiting", "fa68789187c1: Waiting", "b774710f9e82: Waiting", "e8e0575a1565: Waiting", "aed38ff48549: Waiting", "f6fb879da52c: Waiting", "2ae27a08c3c0: Waiting", "de64a881df05: Verifying Checksum", "de64a881df05: Download complete", "02275d3048eb: Verifying Checksum", "02275d3048eb: Download complete", "f2eaa67e8674: Verifying Checksum", "f2eaa67e8674: Download complete", "5ba73c705052: Verifying Checksum", "5ba73c705052: Download complete", "fa68789187c1: Download complete", "f2eaa67e8674: Pull complete", "aed38ff48549: Download complete", "de64a881df05: Pull complete", "f6fb879da52c: Verifying Checksum", "f6fb879da52c: Download complete", "02275d3048eb: Pull complete", "5ba73c705052: Pull complete", "fa68789187c1: Pull complete", "2ae27a08c3c0: Verifying Checksum", "2ae27a08c3c0: Download complete", "b774710f9e82: Verifying Checksum", "b774710f9e82: Download complete", "e8e0575a1565: Verifying Checksum", "e8e0575a1565: Download complete", "b774710f9e82: Pull complete", "e8e0575a1565: Pull complete", "aed38ff48549: Pull complete", "f6fb879da52c: Pull complete", "2ae27a08c3c0: Pull complete", "Digest: sha256:0c74245efaa8873a22d853278c389fb145e33c69a4fe87f650bc8a553cdb54ad", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-config-svcmonitor) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0", "delta": "0:00:00.512671", "end": "2025-04-30 11:45:41.525733", "item": "opensdn-controller-config-svcmonitor", "msg": "", "rc": 0, "start": "2025-04-30 11:45:41.013062", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-config-svcmonitor\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\nf59f775e3c45: Pulling fs layer\n2c1dcbc7a25d: Pulling fs layer\nf59f775e3c45: Download complete\nf59f775e3c45: Pull complete\n2c1dcbc7a25d: Verifying Checksum\n2c1dcbc7a25d: Download complete\n2c1dcbc7a25d: Pull complete\nDigest: sha256:2cf2f483d6bb870e3852f2b2117dcc8de1d748e5c736083c912eb95186de4ec9\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-config-svcmonitor", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "f59f775e3c45: Pulling fs layer", "2c1dcbc7a25d: Pulling fs layer", "f59f775e3c45: Download complete", "f59f775e3c45: Pull complete", "2c1dcbc7a25d: Verifying Checksum", "2c1dcbc7a25d: Download complete", "2c1dcbc7a25d: Pull complete", "Digest: sha256:2cf2f483d6bb870e3852f2b2117dcc8de1d748e5c736083c912eb95186de4ec9", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-config-schema) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0", "delta": "0:00:00.330253", "end": "2025-04-30 11:45:42.327179", "item": "opensdn-controller-config-schema", "msg": "", "rc": 0, "start": "2025-04-30 11:45:41.996926", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-config-schema\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\n7b971451c04e: Pulling fs layer\n73031e5b2493: Pulling fs layer\n7b971451c04e: Download complete\n73031e5b2493: Download complete\n7b971451c04e: Pull complete\n73031e5b2493: Pull complete\nDigest: sha256:4ea9aa946ff04cd4f3bce764c877b58c79176c6e996dbeb94d193f4ea620c75a\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-config-schema", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "7b971451c04e: Pulling fs layer", "73031e5b2493: Pulling fs layer", "7b971451c04e: Download complete", "73031e5b2493: Download complete", "7b971451c04e: Pull complete", "73031e5b2493: Pull complete", "Digest: sha256:4ea9aa946ff04cd4f3bce764c877b58c79176c6e996dbeb94d193f4ea620c75a", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-config-devicemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0", "delta": "0:00:07.490790", "end": "2025-04-30 11:45:50.285434", "item": "opensdn-controller-config-devicemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:45:42.794644", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-config-devicemgr\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\n48b14d94ca47: Pulling fs layer\nca1b12e815dc: Pulling fs layer\nca1b12e815dc: Verifying Checksum\nca1b12e815dc: Download complete\n48b14d94ca47: Verifying Checksum\n48b14d94ca47: Download complete\n48b14d94ca47: Pull complete\nca1b12e815dc: Pull complete\nDigest: sha256:6dad19e20ed499e136d027979037378f838e4fef4b831cc0e37f9274b885b5bc\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-config-devicemgr", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "48b14d94ca47: Pulling fs layer", "ca1b12e815dc: Pulling fs layer", "ca1b12e815dc: Verifying Checksum", "ca1b12e815dc: Download complete", "48b14d94ca47: Verifying Checksum", "48b14d94ca47: Download complete", "48b14d94ca47: Pull complete", "ca1b12e815dc: Pull complete", "Digest: sha256:6dad19e20ed499e136d027979037378f838e4fef4b831cc0e37f9274b885b5bc", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-config-dnsmasq) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0", "delta": "0:00:00.535615", "end": "2025-04-30 11:45:51.274226", "item": "opensdn-controller-config-dnsmasq", "msg": "", "rc": 0, "start": "2025-04-30 11:45:50.738611", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-config-dnsmasq\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc8851dd303ab: Already exists\n1f5174f589ad: Already exists\n888570a14274: Pulling fs layer\n638c149c752f: Pulling fs layer\n8c49e1b2f0b3: Pulling fs layer\n685fad062eb7: Pulling fs layer\n685fad062eb7: Waiting\n888570a14274: Download complete\n638c149c752f: Download complete\n8c49e1b2f0b3: Download complete\n888570a14274: Pull complete\n638c149c752f: Pull complete\n685fad062eb7: Verifying Checksum\n685fad062eb7: Download complete\n8c49e1b2f0b3: Pull complete\n685fad062eb7: Pull complete\nDigest: sha256:a43320ba717f6f8f56c7160ad8b158d6b22231ee5e3d5047685dfa03afd650cf\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-config-dnsmasq", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c8851dd303ab: Already exists", "1f5174f589ad: Already exists", "888570a14274: Pulling fs layer", "638c149c752f: Pulling fs layer", "8c49e1b2f0b3: Pulling fs layer", "685fad062eb7: Pulling fs layer", "685fad062eb7: Waiting", "888570a14274: Download complete", "638c149c752f: Download complete", "8c49e1b2f0b3: Download complete", "888570a14274: Pull complete", "638c149c752f: Pull complete", "685fad062eb7: Verifying Checksum", "685fad062eb7: Download complete", "8c49e1b2f0b3: Pull complete", "685fad062eb7: Pull complete", "Digest: sha256:a43320ba717f6f8f56c7160ad8b158d6b22231ee5e3d5047685dfa03afd650cf", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.104789", "end": "2025-04-30 11:45:51.823208", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:45:51.718419", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_config : create /etc/contrail/config] **************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/config", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_config : get /etc/contrail/common_config.env stat] *************** ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_config : create /etc/contrail/common_config.env] ***************** changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_config.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_config : populate global common_config.env] ********************** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_config : populate pod specific common_config.env] **************** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_config : initialize use_external_tftp variable] ****************** ok: [10.0.0.254] => {"ansible_facts": {"use_external_tftp": false}, "changed": false} TASK [opensdn_config : check if ironic_pxe is deployed on node] **************** fatal: [10.0.0.254]: FAILED! => {"changed": true, "cmd": "docker inspect ironic_pxe", "delta": "0:00:00.024816", "end": "2025-04-30 11:46:10.443745", "msg": "non-zero return code", "rc": 1, "start": "2025-04-30 11:46:10.418929", "stderr": "Error: No such object: ironic_pxe", "stderr_lines": ["Error: No such object: ironic_pxe"], "stdout": "[]", "stdout_lines": ["[]"]} ...ignoring TASK [opensdn_config : create contrail config compose file] ******************** changed: [10.0.0.254] => {"changed": true, "checksum": "06e3aa7430690faa7d0303176cc13d20ad95134f", "dest": "/etc/contrail/config/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "d7df227a2f45dcc7ce6b056624ea09af", "mode": "0644", "owner": "root", "size": 3950, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013570.8027358-64301-47744549892717/source", "state": "file", "uid": 0} TASK [opensdn_config : start contrail config] ********************************** changed: [10.0.0.254] => {"changed": true, "services": {"api": {"config_api_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "0e74bfd38a88f7acdbe5af8ef4e9d321cc2077f479b4f75d175aaabceddfc1e3", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "api", "com.docker.compose.version": "1.29.2", "description": "Controller Configuration API provides a REST API to an orchestration system.", "io.opensdn.container.name": "opensdn-controller-config-api", "io.opensdn.pod": "config", "io.opensdn.service": "api", "name": "opensdn-controller-config-api", "release": "5.1.0", "summary": "Contrail Controller Configuration API", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "devicemgr": {"config_devicemgr_1": {"cmd": ["/usr/local/bin/contrail-device-manager", "--conf_file", "/etc/contrail/contrail-device-manager.conf", "--conf_file", "/etc/contrail/contrail-keystone-auth.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "ab6e29b01d0bb66ab65a1e218ec37d33dda35dc14f145ccf85686201e2317694", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "devicemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Device Manager is used to manage network devices in the Contrail system.", "io.opensdn.container.name": "opensdn-controller-config-devicemgr", "io.opensdn.pod": "config", "io.opensdn.service": "device-manager", "name": "opensdn-controller-config-devicemgr", "release": "5.1.0", "summary": "Contrail Device Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "dnsmasq": {"config_dnsmasq_1": {"cmd": ["dnsmasq", "-k", "-p0"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "6f42490d9b2b00f11e93f8bf2fb9eaa1024d243730783241ccf8c3946bb0f371", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "dnsmasq", "com.docker.compose.version": "1.29.2", "description": "Contrail Dnsmasq provides network infrastructure: DNS, DHCP, router advertisement and network boot.", "io.opensdn.container.name": "opensdn-controller-config-dnsmasq", "io.opensdn.pod": "config", "io.opensdn.service": "dnsmasq", "name": "opensdn-controller-config-dnsmasq", "release": "5.1.0", "summary": "Contrail Dnsmasq", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"config_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"config_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "5bd341bc516c7e9daefc4ee3484cd381b0dfed38542b7ca8383322aeb8f13aa5", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"config_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "9689e90e64532af237d9f901689b84152d48460bd34f1d618992a20b23d40ce4", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "schema": {"config_schema_1": {"cmd": ["/usr/local/bin/contrail-schema", "--conf_file", "/etc/contrail/contrail-schema.conf", "--conf_file", "/etc/contrail/contrail-keystone-auth.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "f81b3f391fb399c0f9dab3bc5afba5f9770fe3d18e542f535c1c73d1c91aa189", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "schema", "com.docker.compose.version": "1.29.2", "description": "Contrail Schema Transformer compiles the high level, intent based data model into a low level configuration data model.", "io.opensdn.container.name": "opensdn-controller-config-schema", "io.opensdn.pod": "config", "io.opensdn.service": "schema", "name": "opensdn-controller-config-schema", "release": "5.1.0", "summary": "Contrail VNC Configuration Schema Transformer", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "svcmonitor": {"config_svcmonitor_1": {"cmd": ["/usr/local/bin/contrail-svc-monitor", "--conf_file", "/etc/contrail/contrail-svc-monitor.conf", "--conf_file", "/etc/contrail/contrail-keystone-auth.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "0ae31f7f2a7fe8f93bde44aab39c621a1d9616137c1c3b24475a4de843f311e2", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "config", "com.docker.compose.project.config_files": "/etc/contrail/config/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/config", "com.docker.compose.service": "svcmonitor", "com.docker.compose.version": "1.29.2", "description": "Contrail Service Monitor brings up and monitors any service instance that are spawned.", "io.opensdn.container.name": "opensdn-controller-config-svcmonitor", "io.opensdn.pod": "config", "io.opensdn.service": "svc-monitor", "name": "opensdn-controller-config-svcmonitor", "release": "5.1.0", "summary": "Contrail Service Monitor", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail webui] *************************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_webui : update contrail webui image] ***************************** changed: [10.0.0.254] => (item=opensdn-controller-webui-web) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0", "delta": "0:00:07.801279", "end": "2025-04-30 11:46:23.036780", "item": "opensdn-controller-webui-web", "msg": "", "rc": 0, "start": "2025-04-30 11:46:15.235501", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-webui-web\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc25b8bbd80fb: Pulling fs layer\nd6824e55acd4: Pulling fs layer\na44ce212f03c: Pulling fs layer\n4c08b1b34aee: Pulling fs layer\n675069718cf0: Pulling fs layer\n4f4fb700ef54: Pulling fs layer\n4c08b1b34aee: Waiting\n675069718cf0: Waiting\n4f4fb700ef54: Waiting\nd6824e55acd4: Download complete\na44ce212f03c: Download complete\n4c08b1b34aee: Download complete\n675069718cf0: Verifying Checksum\n675069718cf0: Download complete\n4f4fb700ef54: Verifying Checksum\n4f4fb700ef54: Download complete\nc25b8bbd80fb: Verifying Checksum\nc25b8bbd80fb: Download complete\nc25b8bbd80fb: Pull complete\nd6824e55acd4: Pull complete\na44ce212f03c: Pull complete\n4c08b1b34aee: Pull complete\n675069718cf0: Pull complete\n4f4fb700ef54: Pull complete\nDigest: sha256:ea30457af8cdd9242834580f33ae6b46c58be57fed9f8b5984cb074731099cd9\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-webui-web", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c25b8bbd80fb: Pulling fs layer", "d6824e55acd4: Pulling fs layer", "a44ce212f03c: Pulling fs layer", "4c08b1b34aee: Pulling fs layer", "675069718cf0: Pulling fs layer", "4f4fb700ef54: Pulling fs layer", "4c08b1b34aee: Waiting", "675069718cf0: Waiting", "4f4fb700ef54: Waiting", "d6824e55acd4: Download complete", "a44ce212f03c: Download complete", "4c08b1b34aee: Download complete", "675069718cf0: Verifying Checksum", "675069718cf0: Download complete", "4f4fb700ef54: Verifying Checksum", "4f4fb700ef54: Download complete", "c25b8bbd80fb: Verifying Checksum", "c25b8bbd80fb: Download complete", "c25b8bbd80fb: Pull complete", "d6824e55acd4: Pull complete", "a44ce212f03c: Pull complete", "4c08b1b34aee: Pull complete", "675069718cf0: Pull complete", "4f4fb700ef54: Pull complete", "Digest: sha256:ea30457af8cdd9242834580f33ae6b46c58be57fed9f8b5984cb074731099cd9", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-webui-job) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0", "delta": "0:00:00.263860", "end": "2025-04-30 11:46:23.771703", "item": "opensdn-controller-webui-job", "msg": "", "rc": 0, "start": "2025-04-30 11:46:23.507843", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-webui-job\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\nc25b8bbd80fb: Already exists\nd6824e55acd4: Already exists\na44ce212f03c: Already exists\n4c08b1b34aee: Already exists\n675069718cf0: Already exists\n4f4fb700ef54: Already exists\nDigest: sha256:02505c6200620a7a14273a38c91bab8a376280d385529808faa2a11ccd5fb671\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-webui-job", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "c25b8bbd80fb: Already exists", "d6824e55acd4: Already exists", "a44ce212f03c: Already exists", "4c08b1b34aee: Already exists", "675069718cf0: Already exists", "4f4fb700ef54: Already exists", "Digest: sha256:02505c6200620a7a14273a38c91bab8a376280d385529808faa2a11ccd5fb671", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0"]} TASK [opensdn_webui : create /etc/contrail/webui] ****************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/webui", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_webui : get /etc/contrail/common_webui.env stat] ***************** ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_webui : create /etc/contrail/common_webui.env] ******************* changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_webui.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_webui : populate cluster wide common_webui.env] ****************** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_webui : populate pod specific common_webui.env] ****************** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_webui : create contrail webui compose file] ********************** changed: [10.0.0.254] => {"changed": true, "checksum": "8e190f003711b3610fe39d7b44aa56ab6fc34cbd", "dest": "/etc/contrail/webui/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "59a659bc9b1872a99cf908a8d8dca84e", "mode": "0644", "owner": "root", "size": 1398, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013602.7942495-68474-169383673823188/source", "state": "file", "uid": 0} TASK [opensdn_webui : start contrail webui] ************************************ changed: [10.0.0.254] => {"changed": true, "services": {"job": {"webui_job_1": {"cmd": ["/usr/bin/node", "jobServerStart.js"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "be49009c983b44ed0484a6e2a1e19ebb2700e5d287e8bfc25e887433b04f93b6", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "webui", "com.docker.compose.project.config_files": "/etc/contrail/webui/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/webui", "com.docker.compose.service": "job", "com.docker.compose.version": "1.29.2", "description": "Contrail WEB UI Job middleware handles jobs from the WebUI service and contacts other Contrail services to execute them.", "io.opensdn.container.name": "opensdn-controller-webui-job", "io.opensdn.pod": "webui", "io.opensdn.service": "job", "name": "opensdn-controller-webui-job", "release": "5.1.0", "summary": "Contrail WEB UI Job", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"webui_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "webui", "com.docker.compose.project.config_files": "/etc/contrail/webui/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/webui", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "web": {"webui_web_1": {"cmd": ["/usr/bin/node", "webServerStart.js"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "9d156901bc34fcbf0005fa0aa71e04bfd310d6fd8a37416b8ee7625c90987f1b", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "webui", "com.docker.compose.project.config_files": "/etc/contrail/webui/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/webui", "com.docker.compose.service": "web", "com.docker.compose.version": "1.29.2", "description": "Contrail WEB UI provides the Web UI service to end user.", "io.opensdn.container.name": "opensdn-controller-webui-web", "io.opensdn.pod": "webui", "io.opensdn.service": "web", "name": "opensdn-controller-webui-web", "release": "5.1.0", "summary": "Contrail WEB UI", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail control] ************************************************* [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_control : update contrail control image] ************************* changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.217795", "end": "2025-04-30 11:46:46.622895", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:46:46.405100", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.102995", "end": "2025-04-30 11:46:47.194835", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:46:47.091840", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-control-control) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0", "delta": "0:00:06.932191", "end": "2025-04-30 11:46:54.602369", "item": "opensdn-controller-control-control", "msg": "", "rc": 0, "start": "2025-04-30 11:46:47.670178", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-control-control\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\ndceb0b57d31f: Pulling fs layer\na6595d48df81: Pulling fs layer\n7a5753f16091: Pulling fs layer\na6595d48df81: Verifying Checksum\na6595d48df81: Download complete\n7a5753f16091: Verifying Checksum\n7a5753f16091: Download complete\ndceb0b57d31f: Verifying Checksum\ndceb0b57d31f: Download complete\ndceb0b57d31f: Pull complete\na6595d48df81: Pull complete\n7a5753f16091: Pull complete\nDigest: sha256:a1c24dd5345fe615503ce637d8d5aaaa9f0666d2c1dd31407ed2f446eb3ea698\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-control-control", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "dceb0b57d31f: Pulling fs layer", "a6595d48df81: Pulling fs layer", "7a5753f16091: Pulling fs layer", "a6595d48df81: Verifying Checksum", "a6595d48df81: Download complete", "7a5753f16091: Verifying Checksum", "7a5753f16091: Download complete", "dceb0b57d31f: Verifying Checksum", "dceb0b57d31f: Download complete", "dceb0b57d31f: Pull complete", "a6595d48df81: Pull complete", "7a5753f16091: Pull complete", "Digest: sha256:a1c24dd5345fe615503ce637d8d5aaaa9f0666d2c1dd31407ed2f446eb3ea698", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-control-named) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0", "delta": "0:00:00.262716", "end": "2025-04-30 11:46:55.323485", "item": "opensdn-controller-control-named", "msg": "", "rc": 0, "start": "2025-04-30 11:46:55.060769", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-control-named\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\ndceb0b57d31f: Already exists\n470103e4c498: Pulling fs layer\n470103e4c498: Verifying Checksum\n470103e4c498: Download complete\n470103e4c498: Pull complete\nDigest: sha256:90f3b7914e2f87444722d703b84678580fca6047840e7334578599d7864278d6\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-control-named", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "dceb0b57d31f: Already exists", "470103e4c498: Pulling fs layer", "470103e4c498: Verifying Checksum", "470103e4c498: Download complete", "470103e4c498: Pull complete", "Digest: sha256:90f3b7914e2f87444722d703b84678580fca6047840e7334578599d7864278d6", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-controller-control-dns) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0", "delta": "0:00:00.276667", "end": "2025-04-30 11:46:56.076599", "item": "opensdn-controller-control-dns", "msg": "", "rc": 0, "start": "2025-04-30 11:46:55.799932", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-controller-control-dns\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\ndceb0b57d31f: Already exists\nadabdd080b09: Pulling fs layer\nadabdd080b09: Download complete\nadabdd080b09: Pull complete\nDigest: sha256:0c99e0efaef26bb2de5bfa4adc887358ce6e3879e9d5b5414aca4b09bed41fc5\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-controller-control-dns", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "dceb0b57d31f: Already exists", "adabdd080b09: Pulling fs layer", "adabdd080b09: Download complete", "adabdd080b09: Pull complete", "Digest: sha256:0c99e0efaef26bb2de5bfa4adc887358ce6e3879e9d5b5414aca4b09bed41fc5", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.124720", "end": "2025-04-30 11:46:56.680197", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:46:56.555477", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_control : create /etc/contrail/control] ************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/control", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_control : get /etc/contrail/common_control.env stat] ************* ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_control : create /etc/contrail/common_control.env] *************** changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_control.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_control : populate global common_control.env] ******************** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_control : populate pod specific common_control.env] ************** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_control : create contrail control compose file] ****************** changed: [10.0.0.254] => {"changed": true, "checksum": "febdc6c1c41e22cf4b244491a45654d1665edd63", "dest": "/etc/contrail/control/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "0c395c9327a4f0059f4cd06a60900e20", "mode": "0644", "owner": "root", "size": 3011, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013635.439542-72825-180295630367080/source", "state": "file", "uid": 0} TASK [opensdn_control : start contrail control] ******************************** changed: [10.0.0.254] => {"changed": true, "services": {"control": {"control_control_1": {"cmd": ["/usr/bin/contrail-control"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "cafdd4b36c9b7ca5e75bc9f10243ea7590c58fc1e5645afe05f4c0d4debb9ecb", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "control", "com.docker.compose.version": "1.29.2", "description": "Contrail Control is xmpp/bgp based routing engine for Contrail.", "io.opensdn.container.name": "opensdn-controller-control-control", "io.opensdn.pod": "control", "io.opensdn.service": "control", "name": "opensdn-controller-control-control", "release": "5.1.0", "summary": "Contrail Controller", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "dns": {"control_dns_1": {"cmd": ["/usr/bin/contrail-dns"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "9fb968f66910b0505132752184083bc4cf3bb67b85d8eaa33ec0e404eff0927f", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "dns", "com.docker.compose.version": "1.29.2", "description": "Contrail DNS provides DNS service to the VMs spawned on compute nodes.", "io.opensdn.container.name": "opensdn-controller-control-dns", "io.opensdn.pod": "control", "io.opensdn.service": "dns", "name": "opensdn-controller-control-dns", "release": "5.1.0", "summary": "Contrail DNS", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "named": {"control_named_1": {"cmd": ["/usr/bin/contrail-named", "-f", "-u", "contrail", "-c", "/etc/contrail/dns/contrail-named.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "cfc1c315a1452564475fdd671cbfab9061b5a175c182e937b9887f040bb8bb9d", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "named", "com.docker.compose.version": "1.29.2", "description": "Contrail Named complements Contrail DNS service.", "io.opensdn.container.name": "opensdn-controller-control-named", "io.opensdn.pod": "control", "io.opensdn.service": "named", "name": "opensdn-controller-control-named", "release": "5.1.0", "summary": "Contrail Named", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"control_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"control_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "e8d898d7fa75a3af8868eabb9d449099ec09038f78d974d08b7d68ac9b9476ff", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"control_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "8ed04ec8c3e26eb9178872a219be24897147bd7786fdd2c5d5898ebea9cb9bfc", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "control", "com.docker.compose.project.config_files": "/etc/contrail/control/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/control", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail analytics database] ************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics_database : update contrail analytics database image] *** changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.105409", "end": "2025-04-30 11:47:19.842025", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:47:19.736616", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.130367", "end": "2025-04-30 11:47:20.438385", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:47:20.308018", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-query-engine) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0", "delta": "0:00:06.610295", "end": "2025-04-30 11:47:27.568845", "item": "opensdn-analytics-query-engine", "msg": "", "rc": 0, "start": "2025-04-30 11:47:20.958550", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-query-engine\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\n2f26ccaf2aae: Pulling fs layer\n840dd339fb7a: Pulling fs layer\n2f26ccaf2aae: Verifying Checksum\n2f26ccaf2aae: Download complete\n2f26ccaf2aae: Pull complete\n840dd339fb7a: Verifying Checksum\n840dd339fb7a: Download complete\n840dd339fb7a: Pull complete\nDigest: sha256:eb3fc9c338cf9075c5868f5d31a1384aee03562083e2e72078a5c6d72ab4b2d9\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-query-engine", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "2f26ccaf2aae: Pulling fs layer", "840dd339fb7a: Pulling fs layer", "2f26ccaf2aae: Verifying Checksum", "2f26ccaf2aae: Download complete", "2f26ccaf2aae: Pull complete", "840dd339fb7a: Verifying Checksum", "840dd339fb7a: Download complete", "840dd339fb7a: Pull complete", "Digest: sha256:eb3fc9c338cf9075c5868f5d31a1384aee03562083e2e72078a5c6d72ab4b2d9", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-cassandra) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "delta": "0:00:00.106719", "end": "2025-04-30 11:47:28.167269", "item": "opensdn-external-cassandra", "msg": "", "rc": 0, "start": "2025-04-30 11:47:28.060550", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-cassandra\nDigest: sha256:9ca671347a2514c7f6631f30adc632035eeb4a4b806f5792641ab2cb2e20029a\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-cassandra", "Digest: sha256:9ca671347a2514c7f6631f30adc632035eeb4a4b806f5792641ab2cb2e20029a", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.116938", "end": "2025-04-30 11:47:28.753240", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:47:28.636302", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_analytics_database : create /etc/contrail/analytics_database] **** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/analytics_database", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_analytics_database : set cassandra seeds to ANALYTICSDB_NODES if defined] *** ok: [10.0.0.254] => {"ansible_facts": {"cassandra_seeds": "10.0.0.254"}, "changed": false} TASK [opensdn_analytics_database : get /etc/contrail/common_analytics_database.env stat] *** ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_analytics_database : create /etc/contrail/common_analytics_database.env] *** changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_analytics_database.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics_database : populate global common_analytics_database.env] *** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_analytics_database : populate pod specific common_analytics_database.env] *** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_analytics_database : create contrail analytics database compose file] *** changed: [10.0.0.254] => {"changed": true, "checksum": "58f63641fee182c34419fcb815d4ed26b5084305", "dest": "/etc/contrail/analytics_database/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "4932f08778b415f89ccc1e3d44d2432f", "mode": "0644", "owner": "root", "size": 3026, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013667.7464669-77789-151953401618400/source", "state": "file", "uid": 0} TASK [opensdn_analytics_database : start contrail analyticsdb] ***************** changed: [10.0.0.254] => {"changed": true, "services": {"cassandra": {"analytics_database_cassandra_1": {"cmd": ["cassandra", "-f"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "04aa5f0b59c30deafe34becd464e1af85a1cfe2724b84e1241f69ba908db4497", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_database", "com.docker.compose.project.config_files": "/etc/contrail/analytics_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_database", "com.docker.compose.service": "cassandra", "com.docker.compose.version": "1.29.2", "description": "Configuration database for Contrail Controller.", "io.opensdn.container.name": "opensdn-external-cassandra", "io.opensdn.service": "cassandra", "name": "opensdn-external-cassandra", "release": "5.1.0", "summary": "Contrail Cassandra DB", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"analytics_database_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_database", "com.docker.compose.project.config_files": "/etc/contrail/analytics_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_database", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"analytics_database_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "390ce36611007a894cf849ddc3b47d7e7800c634b17ad8a62f3763b0c8a0c2b6", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_database", "com.docker.compose.project.config_files": "/etc/contrail/analytics_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_database", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"analytics_database_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "afd87e307184699d9591b8019aa58724323ce03c1315a27c0b1441be045e6231", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_database", "com.docker.compose.project.config_files": "/etc/contrail/analytics_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_database", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "query-engine": {"analytics_database_query-engine_1": {"cmd": ["/usr/bin/contrail-query-engine", "--conf_file", "/etc/contrail/contrail-query-engine.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "8f36ef4191925b9e584db25d4caa178724e3ff6ef3efdc8235dd99eeda966654", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_database", "com.docker.compose.project.config_files": "/etc/contrail/analytics_database/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_database", "com.docker.compose.service": "query-engine", "com.docker.compose.version": "1.29.2", "description": "Contrail Query Engine handles the queries to access data from Analytics DB.", "io.opensdn.container.name": "opensdn-analytics-query-engine", "io.opensdn.pod": "database", "io.opensdn.service": "query-engine", "name": "opensdn-analytics-query-engine", "release": "5.1.0", "summary": "Contrail Query Engine", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail analytics] *********************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics : update contrail analytics images] ******************** changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.109821", "end": "2025-04-30 11:47:52.237219", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:47:52.127398", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.118726", "end": "2025-04-30 11:47:52.857062", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:47:52.738336", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-api) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0", "delta": "0:00:03.153355", "end": "2025-04-30 11:47:56.481704", "item": "opensdn-analytics-api", "msg": "", "rc": 0, "start": "2025-04-30 11:47:53.328349", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-api\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\n59b2906bc987: Pulling fs layer\nb74ea428c2bb: Pulling fs layer\n59b2906bc987: Verifying Checksum\n59b2906bc987: Download complete\n59b2906bc987: Pull complete\nb74ea428c2bb: Verifying Checksum\nb74ea428c2bb: Download complete\nb74ea428c2bb: Pull complete\nDigest: sha256:06cc354a7bbd63e617c808fa0c99284eee12e700f885b615aefa68fc15504c27\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-api", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "59b2906bc987: Pulling fs layer", "b74ea428c2bb: Pulling fs layer", "59b2906bc987: Verifying Checksum", "59b2906bc987: Download complete", "59b2906bc987: Pull complete", "b74ea428c2bb: Verifying Checksum", "b74ea428c2bb: Download complete", "b74ea428c2bb: Pull complete", "Digest: sha256:06cc354a7bbd63e617c808fa0c99284eee12e700f885b615aefa68fc15504c27", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-collector) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0", "delta": "0:00:06.246231", "end": "2025-04-30 11:48:03.204092", "item": "opensdn-analytics-collector", "msg": "", "rc": 0, "start": "2025-04-30 11:47:56.957861", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-collector\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\na244996efcd3: Pulling fs layer\ne96e7f8a84ae: Pulling fs layer\na244996efcd3: Verifying Checksum\na244996efcd3: Download complete\na244996efcd3: Pull complete\ne96e7f8a84ae: Verifying Checksum\ne96e7f8a84ae: Download complete\ne96e7f8a84ae: Pull complete\nDigest: sha256:3267bcbfcd7f86dab34100be68f9a5125dee553cbc1be709d872946da28cd72d\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-collector", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "a244996efcd3: Pulling fs layer", "e96e7f8a84ae: Pulling fs layer", "a244996efcd3: Verifying Checksum", "a244996efcd3: Download complete", "a244996efcd3: Pull complete", "e96e7f8a84ae: Verifying Checksum", "e96e7f8a84ae: Download complete", "e96e7f8a84ae: Pull complete", "Digest: sha256:3267bcbfcd7f86dab34100be68f9a5125dee553cbc1be709d872946da28cd72d", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.109241", "end": "2025-04-30 11:48:03.777737", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:48:03.668496", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_analytics : create /etc/contrail/analytics] ********************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/analytics", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_analytics : get /etc/contrail/common_analytics.env stat] ********* ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_analytics : create /etc/contrail/common_analytics.env] *********** changed: [10.0.0.254] => {"changed": true, "dest": "/etc/contrail/common_analytics.env", "gid": 0, "group": "root", "mode": "0640", "owner": "root", "size": 0, "state": "file", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics : populate global common_analytics.env] **************** changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => (item=None) => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} changed: [10.0.0.254] => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": true} TASK [opensdn_analytics : populate pod specific common_analytics.env] ********** fatal: [10.0.0.254]: FAILED! => {"censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result"} ...ignoring TASK [opensdn_analytics : create contrail analytics file] ********************** changed: [10.0.0.254] => {"changed": true, "checksum": "465abb8d1241fc697954e6ab8f42948edbb63662", "dest": "/etc/contrail/analytics/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "a76f0713232c2fce80d11f2e5bb29c22", "mode": "0644", "owner": "root", "size": 2415, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013702.0732937-82997-276589648701642/source", "state": "file", "uid": 0} TASK [opensdn_analytics : start contrail analytics] **************************** changed: [10.0.0.254] => {"changed": true, "services": {"api": {"analytics_api_1": {"cmd": ["/usr/local/bin/contrail-analytics-api", "-c", "/etc/contrail/contrail-analytics-api.conf", "-c", "/etc/contrail/contrail-keystone-auth.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "b52931a7b61147d2e2f7f1752386f0e16dd45cad50153909bccfad06b6573d37", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics", "com.docker.compose.project.config_files": "/etc/contrail/analytics/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics", "com.docker.compose.service": "api", "com.docker.compose.version": "1.29.2", "description": "Contrail Analytics API provides REST API to access collected analytics data.", "io.opensdn.container.name": "opensdn-analytics-api", "io.opensdn.pod": "analytics", "io.opensdn.service": "api", "name": "opensdn-analytics-api", "release": "5.1.0", "summary": "Contrail Analytics API", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "collector": {"analytics_collector_1": {"cmd": ["/usr/bin/contrail-collector"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "7fc52d8dcceb05c84786ec573799e1042ab3e753f16d2023b3d9da30d776de1d", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics", "com.docker.compose.project.config_files": "/etc/contrail/analytics/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics", "com.docker.compose.service": "collector", "com.docker.compose.version": "1.29.2", "description": "Contrail Analytics Collector collects the running state of different processes sent by other nodes.", "io.opensdn.container.name": "opensdn-analytics-collector", "io.opensdn.pod": "analytics", "io.opensdn.service": "collector", "name": "opensdn-analytics-collector", "release": "5.1.0", "summary": "Contrail Analytics Collector", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"analytics_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics", "com.docker.compose.project.config_files": "/etc/contrail/analytics/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"analytics_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "52a06e2873bb53ed4084e9741e9f8ad8fc17ffcf3b9a4bb039033bbb75d0a66d", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics", "com.docker.compose.project.config_files": "/etc/contrail/analytics/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"analytics_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "562bc9df2d1399a836f6681cab415deeaf726b31f6e05f6dd0a9c4845400740c", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics", "com.docker.compose.project.config_files": "/etc/contrail/analytics/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail analytics alarm] ***************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics_alarm : update alarm, external-kafka image] ************ changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.110304", "end": "2025-04-30 11:48:26.525204", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:48:26.414900", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.118457", "end": "2025-04-30 11:48:27.115929", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:48:26.997472", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-alarm-gen) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0", "delta": "0:00:00.729573", "end": "2025-04-30 11:48:28.316578", "item": "opensdn-analytics-alarm-gen", "msg": "", "rc": 0, "start": "2025-04-30 11:48:27.587005", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-alarm-gen\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\nd213250cf98a: Pulling fs layer\nb667dc5b6a79: Pulling fs layer\nd213250cf98a: Verifying Checksum\nd213250cf98a: Download complete\nd213250cf98a: Pull complete\nb667dc5b6a79: Verifying Checksum\nb667dc5b6a79: Download complete\nb667dc5b6a79: Pull complete\nDigest: sha256:4e7189a2359cddb144eb13800009e820f60913bd61e9763e07160cc69203b6be\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-alarm-gen", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "d213250cf98a: Pulling fs layer", "b667dc5b6a79: Pulling fs layer", "d213250cf98a: Verifying Checksum", "d213250cf98a: Download complete", "d213250cf98a: Pull complete", "b667dc5b6a79: Verifying Checksum", "b667dc5b6a79: Download complete", "b667dc5b6a79: Pull complete", "Digest: sha256:4e7189a2359cddb144eb13800009e820f60913bd61e9763e07160cc69203b6be", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-external-kafka) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0", "delta": "0:00:08.384243", "end": "2025-04-30 11:48:37.289615", "item": "opensdn-external-kafka", "msg": "", "rc": 0, "start": "2025-04-30 11:48:28.905372", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-kafka\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\n3883c6364f0a: Pulling fs layer\neaf011ab4e4f: Pulling fs layer\n4f4fb700ef54: Pulling fs layer\n4f4fb700ef54: Verifying Checksum\n4f4fb700ef54: Download complete\n3883c6364f0a: Download complete\n3883c6364f0a: Pull complete\neaf011ab4e4f: Download complete\neaf011ab4e4f: Pull complete\n4f4fb700ef54: Pull complete\nDigest: sha256:26d23e47a47e5aa943c9dc73b9f1d98bcd2bf57192b4689832a93f640b4d6c37\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-kafka", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "3883c6364f0a: Pulling fs layer", "eaf011ab4e4f: Pulling fs layer", "4f4fb700ef54: Pulling fs layer", "4f4fb700ef54: Verifying Checksum", "4f4fb700ef54: Download complete", "3883c6364f0a: Download complete", "3883c6364f0a: Pull complete", "eaf011ab4e4f: Download complete", "eaf011ab4e4f: Pull complete", "4f4fb700ef54: Pull complete", "Digest: sha256:26d23e47a47e5aa943c9dc73b9f1d98bcd2bf57192b4689832a93f640b4d6c37", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.105130", "end": "2025-04-30 11:48:37.852318", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:48:37.747188", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_analytics_alarm : create /etc/contrail/analytics_alarm] ********** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/analytics_alarm", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_analytics_alarm : set zookeeper nodes to CONFIGDB_NODES if defined] *** ok: [10.0.0.254] => {"ansible_facts": {"zookeeper_nodes": "10.0.0.254"}, "changed": false} TASK [opensdn_analytics_alarm : create contrail analytics_alarm docker-compose file] *** changed: [10.0.0.254] => {"changed": true, "checksum": "00154a86b34d4e7d13e32f02c48cddedf9d8e8c7", "dest": "/etc/contrail/analytics_alarm/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "c1e30ea415e6bc9ec9b037c4c5c4dda1", "mode": "0644", "owner": "root", "size": 2488, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013719.0956798-85780-166956264934530/source", "state": "file", "uid": 0} TASK [opensdn_analytics_alarm : start contrail analytics_alarm] **************** changed: [10.0.0.254] => {"changed": true, "services": {"alarm-gen": {"analytics_alarm_alarm-gen_1": {"cmd": ["/usr/local/bin/contrail-alarm-gen", "-c", "/etc/contrail/contrail-alarm-gen.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "d4a8d1da95cb58939a6a36124bf993e7d30214f63e10c6518c34d499b2a980c8", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_alarm", "com.docker.compose.project.config_files": "/etc/contrail/analytics_alarm/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_alarm", "com.docker.compose.service": "alarm-gen", "com.docker.compose.version": "1.29.2", "description": "Contrail Alarm Generator generates alerts (alarms) which highlight unusual conditions that may require more urgent administrator attention and action.", "io.opensdn.container.name": "opensdn-analytics-alarm-gen", "io.opensdn.pod": "analytics-alarm", "io.opensdn.service": "alarm-gen", "name": "opensdn-analytics-alarm-gen", "release": "5.1.0", "summary": "Contrail Alarm Generator", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "kafka": {"analytics_alarm_kafka_1": {"cmd": ["bin/kafka-server-start.sh", "config/server.properties"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "7fa5867d524f00655b2e16d1aff86473768b65b019907afbdc290765d704c634", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_alarm", "com.docker.compose.project.config_files": "/etc/contrail/analytics_alarm/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_alarm", "com.docker.compose.service": "kafka", "com.docker.compose.version": "1.29.2", "description": "Contrail Kafka is used for streaming data in Analytics DB.", "io.opensdn.container.name": "opensdn-external-kafka", "io.opensdn.service": "kafka", "name": "opensdn-external-kafka", "release": "5.1.0", "summary": "Contrail Kafka", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "node-init": {"analytics_alarm_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_alarm", "com.docker.compose.project.config_files": "/etc/contrail/analytics_alarm/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_alarm", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"analytics_alarm_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "a6347b6f1d75b325284ac478dae6918e353016574736512173090b81a912bead", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_alarm", "com.docker.compose.project.config_files": "/etc/contrail/analytics_alarm/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_alarm", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"analytics_alarm_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "bc9aaaebb8f17f4d1ad8605e4a941c0a6efd50c164112e35522bf4d64118c66f", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_alarm", "com.docker.compose.project.config_files": "/etc/contrail/analytics_alarm/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_alarm", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail analytics snmp] ****************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_analytics_snmp : update contrail-snmp-collector and contrail-analytics-snmp-topology image] *** changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.112397", "end": "2025-04-30 11:48:43.189269", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:48:43.076872", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.112258", "end": "2025-04-30 11:48:43.793036", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:48:43.680778", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-snmp-topology) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0", "delta": "0:00:05.255434", "end": "2025-04-30 11:48:49.510331", "item": "opensdn-analytics-snmp-topology", "msg": "", "rc": 0, "start": "2025-04-30 11:48:44.254897", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-snmp-topology\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\nedb43f41ba57: Pulling fs layer\n3991611b708a: Pulling fs layer\n82be40e9f67d: Pulling fs layer\n3991611b708a: Download complete\n82be40e9f67d: Download complete\nedb43f41ba57: Verifying Checksum\nedb43f41ba57: Download complete\nedb43f41ba57: Pull complete\n3991611b708a: Pull complete\n82be40e9f67d: Pull complete\nDigest: sha256:1b8eb0e0668954dcf37352a0bbd4fb355c219a2f59458a28c343c7d028e80a58\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-snmp-topology", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "edb43f41ba57: Pulling fs layer", "3991611b708a: Pulling fs layer", "82be40e9f67d: Pulling fs layer", "3991611b708a: Download complete", "82be40e9f67d: Download complete", "edb43f41ba57: Verifying Checksum", "edb43f41ba57: Download complete", "edb43f41ba57: Pull complete", "3991611b708a: Pull complete", "82be40e9f67d: Pull complete", "Digest: sha256:1b8eb0e0668954dcf37352a0bbd4fb355c219a2f59458a28c343c7d028e80a58", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-analytics-snmp-collector) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0", "delta": "0:00:00.394199", "end": "2025-04-30 11:48:50.420063", "item": "opensdn-analytics-snmp-collector", "msg": "", "rc": 0, "start": "2025-04-30 11:48:50.025864", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-analytics-snmp-collector\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\nedb43f41ba57: Already exists\n906cc3a3d325: Pulling fs layer\n9a3ed0e318ab: Pulling fs layer\n906cc3a3d325: Verifying Checksum\n906cc3a3d325: Download complete\n9a3ed0e318ab: Download complete\n906cc3a3d325: Pull complete\n9a3ed0e318ab: Pull complete\nDigest: sha256:bc7084502ebdbf1220af2f3f3ca9a4bfb649e370bac04f64c9dd2e6c9a839ab0\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-analytics-snmp-collector", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "edb43f41ba57: Already exists", "906cc3a3d325: Pulling fs layer", "9a3ed0e318ab: Pulling fs layer", "906cc3a3d325: Verifying Checksum", "906cc3a3d325: Download complete", "9a3ed0e318ab: Download complete", "906cc3a3d325: Pull complete", "9a3ed0e318ab: Pull complete", "Digest: sha256:bc7084502ebdbf1220af2f3f3ca9a4bfb649e370bac04f64c9dd2e6c9a839ab0", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.126291", "end": "2025-04-30 11:48:51.021491", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:48:50.895200", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} TASK [opensdn_analytics_snmp : create /etc/contrail/analytics_snmp] ************ changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/analytics_snmp", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_analytics_snmp : create contrail analytics_snmp docker-compose file] *** changed: [10.0.0.254] => {"changed": true, "checksum": "8322e5f9945f1e99b9c18653de625a7435ba8c7c", "dest": "/etc/contrail/analytics_snmp/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "b4847dbdde1d0b691fae6a9438fd95e3", "mode": "0644", "owner": "root", "size": 2368, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013731.9334912-88238-39924429675815/source", "state": "file", "uid": 0} TASK [opensdn_analytics_snmp : start contrail analytics_snmp] ****************** changed: [10.0.0.254] => {"changed": true, "services": {"node-init": {"analytics_snmp_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_snmp", "com.docker.compose.project.config_files": "/etc/contrail/analytics_snmp/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_snmp", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"analytics_snmp_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "711ea0f14c1087e429a919b23e12984ba9d5d2673c78a2b9821f24546e726453", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_snmp", "com.docker.compose.project.config_files": "/etc/contrail/analytics_snmp/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_snmp", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"analytics_snmp_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "f6f5f4115e3f32f6b5568916717950b237070fa01ab285efaf1c712b7669ecd4", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_snmp", "com.docker.compose.project.config_files": "/etc/contrail/analytics_snmp/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_snmp", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "snmp-collector": {"analytics_snmp_snmp-collector_1": {"cmd": ["/usr/local/bin/tf-snmp-collector", "-c", "/etc/contrail/tf-snmp-collector.conf", "--device-config-file", "/etc/contrail/device.ini"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "bdc4edf5fa537c6959f0714554ec077d83b691fd4a9e8880e836e0abc80ba719", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_snmp", "com.docker.compose.project.config_files": "/etc/contrail/analytics_snmp/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_snmp", "com.docker.compose.service": "snmp-collector", "com.docker.compose.version": "1.29.2", "description": "SNMP Collector collects data from switches(Spine/Leaf).", "io.opensdn.container.name": "opensdn-analytics-snmp-collector", "io.opensdn.pod": "analytics-snmp", "io.opensdn.service": "snmp-collector", "name": "opensdn-analytics-snmp-collector", "release": "5.1.0", "summary": "SNMP Collector", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "topology": {"analytics_snmp_topology_1": {"cmd": ["/usr/local/bin/tf-topology", "-c", "/etc/contrail/tf-topology.conf"], "image": "nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "b03d218273dbb3543c4b61652fdcb5107743ef281392650ac6ea4b2b3d292625", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "analytics_snmp", "com.docker.compose.project.config_files": "/etc/contrail/analytics_snmp/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/analytics_snmp", "com.docker.compose.service": "topology", "com.docker.compose.version": "1.29.2", "description": "SNMP Topology periodically updates topology table, which is used by UI to draw maps.", "io.opensdn.container.name": "opensdn-analytics-snmp-topology", "io.opensdn.pod": "analytics-snmp", "io.opensdn.service": "topology", "name": "opensdn-analytics-snmp-topology", "release": "5.1.0", "summary": "SNMP Topology", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail rsyslogd for Linux] ************************************** [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_rsyslogd : update contrail rsyslogd image] *********************** changed: [10.0.0.254] => (item=opensdn-external-rsyslogd) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0", "delta": "0:00:00.501470", "end": "2025-04-30 11:48:56.473370", "item": "opensdn-external-rsyslogd", "msg": "", "rc": 0, "start": "2025-04-30 11:48:55.971900", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-external-rsyslogd\n446f83f14b23: Already exists\n45c3a3b0853d: Already exists\nc82a39c39703: Already exists\n4839aa04a76e: Already exists\n5731b0faae00: Already exists\n8ab8cc2c18c9: Already exists\n2e726770a351: Already exists\n582524f093fe: Pulling fs layer\nda6ce95b7972: Pulling fs layer\n734f7ed26127: Pulling fs layer\nd07347ef7b42: Pulling fs layer\nd07347ef7b42: Waiting\n582524f093fe: Verifying Checksum\n582524f093fe: Download complete\n734f7ed26127: Verifying Checksum\n734f7ed26127: Download complete\n582524f093fe: Pull complete\nd07347ef7b42: Verifying Checksum\nd07347ef7b42: Download complete\nda6ce95b7972: Verifying Checksum\nda6ce95b7972: Download complete\nda6ce95b7972: Pull complete\n734f7ed26127: Pull complete\nd07347ef7b42: Pull complete\nDigest: sha256:39c2892eacb9655a7b1baee085d2c458ae7c0165c26ced212b94e43d3fc3e755\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-external-rsyslogd", "446f83f14b23: Already exists", "45c3a3b0853d: Already exists", "c82a39c39703: Already exists", "4839aa04a76e: Already exists", "5731b0faae00: Already exists", "8ab8cc2c18c9: Already exists", "2e726770a351: Already exists", "582524f093fe: Pulling fs layer", "da6ce95b7972: Pulling fs layer", "734f7ed26127: Pulling fs layer", "d07347ef7b42: Pulling fs layer", "d07347ef7b42: Waiting", "582524f093fe: Verifying Checksum", "582524f093fe: Download complete", "734f7ed26127: Verifying Checksum", "734f7ed26127: Download complete", "582524f093fe: Pull complete", "d07347ef7b42: Verifying Checksum", "d07347ef7b42: Download complete", "da6ce95b7972: Verifying Checksum", "da6ce95b7972: Download complete", "da6ce95b7972: Pull complete", "734f7ed26127: Pull complete", "d07347ef7b42: Pull complete", "Digest: sha256:39c2892eacb9655a7b1baee085d2c458ae7c0165c26ced212b94e43d3fc3e755", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0"]} TASK [opensdn_rsyslogd : create /etc/contrail/rsyslogd] ************************ changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/rsyslogd", "size": 4096, "state": "directory", "uid": 0} TASK [opensdn_rsyslogd : create rsyslogd compose file] ************************* changed: [10.0.0.254] => {"changed": true, "checksum": "5d83306c209b69c2f618c6df3c103b05e8ff06b4", "dest": "/etc/contrail/rsyslogd/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "b5930c9ad46ba78303eafe58838794ea", "mode": "0644", "owner": "root", "size": 617, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013737.270007-89745-189793620276950/source", "state": "file", "uid": 0} TASK [opensdn_rsyslogd : start rsyslogd] *************************************** changed: [10.0.0.254] => {"changed": true, "services": {"rsyslogd": {"rsyslogd_rsyslogd_1": {"cmd": ["/bin/sh", "-c", "rsyslogd -n -f /etc/rsyslog.conf -i $RSYSLOGD_PIDFILE"], "image": "nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "52d3e4c0f45fa95dcd1c07ad855594e3ff338348ea09e46c58720147a3afe6e2", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "rsyslogd", "com.docker.compose.project.config_files": "/etc/contrail/rsyslogd/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/rsyslogd", "com.docker.compose.service": "rsyslogd", "com.docker.compose.version": "1.29.2", "description": "Contrail rsyslogd support", "io.opensdn.container.name": "", "io.opensdn.service": "rsyslogd", "name": "", "release": "5.1.0", "summary": "Contrail rsyslogd", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [create contrail vrouter for Linux] *************************************** TASK [opensdn_vrouter : set vrouter kernel init image name] ******************** ok: [10.0.0.254] => {"ansible_facts": {"vrouter_kernel_init_img_name": "opensdn-vrouter-kernel-build-init"}, "changed": false} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_vrouter : update image] ****************************************** changed: [10.0.0.254] => (item=opensdn-node-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "delta": "0:00:00.113311", "end": "2025-04-30 11:49:00.204747", "item": "opensdn-node-init", "msg": "", "rc": 0, "start": "2025-04-30 11:49:00.091436", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-node-init\nDigest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-node-init", "Digest: sha256:b6a66b2626c3bf5bacf3fbde5bf214ceccdc0d7b1caa529b8bc78dde862536d0", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-nodemgr) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "delta": "0:00:00.127913", "end": "2025-04-30 11:49:00.814684", "item": "opensdn-nodemgr", "msg": "", "rc": 0, "start": "2025-04-30 11:49:00.686771", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-nodemgr\nDigest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-nodemgr", "Digest: sha256:dbc404376783169465001d308b17031102adc5d7f99ca36e2f719e565f735410", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-provisioner) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "delta": "0:00:00.106741", "end": "2025-04-30 11:49:01.408924", "item": "opensdn-provisioner", "msg": "", "rc": 0, "start": "2025-04-30 11:49:01.302183", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-provisioner\nDigest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de\nStatus: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-provisioner", "Digest: sha256:63d5de0041a13ca2d2a53278438cc7641a4d8e851c3f6f4b90d850a25038d9de", "Status: Image is up to date for nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-vrouter-kernel-build-init) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0", "delta": "0:00:07.155652", "end": "2025-04-30 11:49:09.066621", "item": "opensdn-vrouter-kernel-build-init", "msg": "", "rc": 0, "start": "2025-04-30 11:49:01.910969", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-vrouter-kernel-build-init\nac0c285abb48: Pulling fs layer\nd01806536b5c: Pulling fs layer\ndda2293e2926: Pulling fs layer\n441ef5174cde: Pulling fs layer\nf524e198a17d: Pulling fs layer\nd13d3dee094a: Pulling fs layer\nd6396eb441c6: Pulling fs layer\n7c3b5fbad581: Pulling fs layer\nf524e198a17d: Waiting\nd13d3dee094a: Waiting\nd6396eb441c6: Waiting\n7c3b5fbad581: Waiting\n441ef5174cde: Waiting\nd01806536b5c: Verifying Checksum\nd01806536b5c: Download complete\ndda2293e2926: Verifying Checksum\ndda2293e2926: Download complete\nf524e198a17d: Verifying Checksum\nf524e198a17d: Download complete\n441ef5174cde: Verifying Checksum\n441ef5174cde: Download complete\nd6396eb441c6: Verifying Checksum\nd6396eb441c6: Download complete\n7c3b5fbad581: Verifying Checksum\n7c3b5fbad581: Download complete\nac0c285abb48: Verifying Checksum\nac0c285abb48: Download complete\nd13d3dee094a: Verifying Checksum\nd13d3dee094a: Download complete\nac0c285abb48: Pull complete\nd01806536b5c: Pull complete\ndda2293e2926: Pull complete\n441ef5174cde: Pull complete\nf524e198a17d: Pull complete\nd13d3dee094a: Pull complete\nd6396eb441c6: Pull complete\n7c3b5fbad581: Pull complete\nDigest: sha256:3ed76e5e8306643c8e05dfe36b54f8283a14292848175f685e6857f3286baf56\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-vrouter-kernel-build-init", "ac0c285abb48: Pulling fs layer", "d01806536b5c: Pulling fs layer", "dda2293e2926: Pulling fs layer", "441ef5174cde: Pulling fs layer", "f524e198a17d: Pulling fs layer", "d13d3dee094a: Pulling fs layer", "d6396eb441c6: Pulling fs layer", "7c3b5fbad581: Pulling fs layer", "f524e198a17d: Waiting", "d13d3dee094a: Waiting", "d6396eb441c6: Waiting", "7c3b5fbad581: Waiting", "441ef5174cde: Waiting", "d01806536b5c: Verifying Checksum", "d01806536b5c: Download complete", "dda2293e2926: Verifying Checksum", "dda2293e2926: Download complete", "f524e198a17d: Verifying Checksum", "f524e198a17d: Download complete", "441ef5174cde: Verifying Checksum", "441ef5174cde: Download complete", "d6396eb441c6: Verifying Checksum", "d6396eb441c6: Download complete", "7c3b5fbad581: Verifying Checksum", "7c3b5fbad581: Download complete", "ac0c285abb48: Verifying Checksum", "ac0c285abb48: Download complete", "d13d3dee094a: Verifying Checksum", "d13d3dee094a: Download complete", "ac0c285abb48: Pull complete", "d01806536b5c: Pull complete", "dda2293e2926: Pull complete", "441ef5174cde: Pull complete", "f524e198a17d: Pull complete", "d13d3dee094a: Pull complete", "d6396eb441c6: Pull complete", "7c3b5fbad581: Pull complete", "Digest: sha256:3ed76e5e8306643c8e05dfe36b54f8283a14292848175f685e6857f3286baf56", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0"]} changed: [10.0.0.254] => (item=opensdn-vrouter-agent) => {"ansible_loop_var": "item", "attempts": 1, "changed": true, "cmd": "docker pull nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0", "delta": "0:00:08.022832", "end": "2025-04-30 11:49:17.540467", "item": "opensdn-vrouter-agent", "msg": "", "rc": 0, "start": "2025-04-30 11:49:09.517635", "stderr": "", "stderr_lines": [], "stdout": "master-1_0_8_7-7_0: Pulling from opensdn-vrouter-agent\n446f83f14b23: Already exists\nf2eaa67e8674: Already exists\nde64a881df05: Already exists\n02275d3048eb: Already exists\n5ba73c705052: Already exists\nfa68789187c1: Already exists\nb774710f9e82: Already exists\ne8e0575a1565: Already exists\naed38ff48549: Already exists\n1f3cd31035fc: Pulling fs layer\n1b08d9e6877c: Pulling fs layer\n0f9d2b055349: Pulling fs layer\n13ae4bbae36e: Pulling fs layer\n0a1a6d722477: Pulling fs layer\n57c76187c17e: Pulling fs layer\n0a1a6d722477: Waiting\n13ae4bbae36e: Waiting\n57c76187c17e: Waiting\n1b08d9e6877c: Download complete\n13ae4bbae36e: Verifying Checksum\n13ae4bbae36e: Download complete\n0a1a6d722477: Verifying Checksum\n0a1a6d722477: Download complete\n57c76187c17e: Verifying Checksum\n57c76187c17e: Download complete\n1f3cd31035fc: Verifying Checksum\n1f3cd31035fc: Download complete\n0f9d2b055349: Verifying Checksum\n0f9d2b055349: Download complete\n1f3cd31035fc: Pull complete\n1b08d9e6877c: Pull complete\n0f9d2b055349: Pull complete\n13ae4bbae36e: Pull complete\n0a1a6d722477: Pull complete\n57c76187c17e: Pull complete\nDigest: sha256:b2218fbc232f9581bd3331af0e96230b53a9bd8d95654e80c99afa11cffb7930\nStatus: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0\nnexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0", "stdout_lines": ["master-1_0_8_7-7_0: Pulling from opensdn-vrouter-agent", "446f83f14b23: Already exists", "f2eaa67e8674: Already exists", "de64a881df05: Already exists", "02275d3048eb: Already exists", "5ba73c705052: Already exists", "fa68789187c1: Already exists", "b774710f9e82: Already exists", "e8e0575a1565: Already exists", "aed38ff48549: Already exists", "1f3cd31035fc: Pulling fs layer", "1b08d9e6877c: Pulling fs layer", "0f9d2b055349: Pulling fs layer", "13ae4bbae36e: Pulling fs layer", "0a1a6d722477: Pulling fs layer", "57c76187c17e: Pulling fs layer", "0a1a6d722477: Waiting", "13ae4bbae36e: Waiting", "57c76187c17e: Waiting", "1b08d9e6877c: Download complete", "13ae4bbae36e: Verifying Checksum", "13ae4bbae36e: Download complete", "0a1a6d722477: Verifying Checksum", "0a1a6d722477: Download complete", "57c76187c17e: Verifying Checksum", "57c76187c17e: Download complete", "1f3cd31035fc: Verifying Checksum", "1f3cd31035fc: Download complete", "0f9d2b055349: Verifying Checksum", "0f9d2b055349: Download complete", "1f3cd31035fc: Pull complete", "1b08d9e6877c: Pull complete", "0f9d2b055349: Pull complete", "13ae4bbae36e: Pull complete", "0a1a6d722477: Pull complete", "57c76187c17e: Pull complete", "Digest: sha256:b2218fbc232f9581bd3331af0e96230b53a9bd8d95654e80c99afa11cffb7930", "Status: Downloaded newer image for nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0", "nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0"]} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_vrouter : create /etc/contrail/vrouter] ************************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/etc/contrail/vrouter", "size": 4096, "state": "directory", "uid": 0} [WARNING]: The loop variable 'item' is already in use. You should set the `loop_var` value in the `loop_control` option for the task to something else to avoid variable collisions and unexpected behavior. TASK [opensdn_vrouter : populate common_vrouter.env] *************************** changed: [10.0.0.254] => {"changed": true, "checksum": "699ed66fc9add79c1097e31b8fcb73dcbd31c130", "dest": "/etc/contrail/common_vrouter.env", "gid": 0, "group": "root", "md5sum": "6f0c681429ecf6558843ff92a919b234", "mode": "0640", "owner": "root", "size": 1040, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013758.868472-91807-222592588927374/source", "state": "file", "uid": 0} TASK [opensdn_vrouter : set vrouter kernel init image name] ******************** ok: [10.0.0.254] => {"ansible_facts": {"vrouter_kernel_init_img_name": "opensdn-vrouter-kernel-build-init"}, "changed": false} TASK [opensdn_vrouter : check /etc/contrail/vrouter/docker-compose.yaml] ******* ok: [10.0.0.254] => {"changed": false, "stat": {"exists": false}} TASK [opensdn_vrouter : create contrail vrouter compose file] ****************** changed: [10.0.0.254] => {"changed": true, "checksum": "e9b0aeae581815c06469160963d669e549120144", "dest": "/etc/contrail/vrouter/docker-compose.yaml", "gid": 0, "group": "root", "md5sum": "f7741ecdd318b7b19d061bafeb79b837", "mode": "0644", "owner": "root", "size": 2757, "src": "/home/ubuntu/.ansible/tmp/ansible-tmp-1746013760.9078276-92040-101334383239655/source", "state": "file", "uid": 0} TASK [opensdn_vrouter : create /var/run/contrail/loadbalancer] ***************** changed: [10.0.0.254] => {"changed": true, "gid": 0, "group": "root", "mode": "0755", "owner": "root", "path": "/var/run/contrail/loadbalancer", "size": 40, "state": "directory", "uid": 0} TASK [opensdn_vrouter : start contrail vrouter] ******************************** changed: [10.0.0.254] => {"changed": true, "services": {"node-init": {"vrouter_node-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-node-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "fb8c2b0b18301683cc08d4a871073b7df778a1cc9802746d7523c386974c0112", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "vrouter", "com.docker.compose.project.config_files": "/etc/contrail/vrouter/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/vrouter", "com.docker.compose.service": "node-init", "com.docker.compose.version": "1.29.2", "description": "Container is used to configure operating system for Contrail services.", "io.opensdn.container.name": "opensdn-node-init", "name": "opensdn-node-init", "release": "5.1.0", "summary": "Contrail Init container", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": false, "status": "exited"}}}, "nodemgr": {"vrouter_nodemgr_1": {"cmd": ["/bin/sh", "-c", "/usr/local/bin/contrail-nodemgr --nodetype=${NODEMGR_TYPE}"], "image": "nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "984755e5d192129859b57468eb36fc054043843bfeab6fb96bc590638df15199", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "vrouter", "com.docker.compose.project.config_files": "/etc/contrail/vrouter/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/vrouter", "com.docker.compose.service": "nodemgr", "com.docker.compose.version": "1.29.2", "description": "Contrail Node Manager is a monitor process per contrail virtual node that tracks the running state of the processes.", "io.opensdn.container.name": "opensdn-nodemgr", "io.opensdn.service": "nodemgr", "name": "opensdn-nodemgr", "release": "5.1.0", "summary": "Contrail Node Manager", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "provisioner": {"vrouter_provisioner_1": {"cmd": ["/usr/bin/tail", "-f", "/dev/null"], "image": "nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "0cffa0b413c0294d4dd9cb64207c93b82b6726252a273054184728639e70df5a", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "vrouter", "com.docker.compose.project.config_files": "/etc/contrail/vrouter/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/vrouter", "com.docker.compose.service": "provisioner", "com.docker.compose.version": "1.29.2", "description": "Contrail Provisioner ia caoneiner that manage env for other containers.", "io.opensdn.container.name": "opensdn-provisioner", "io.opensdn.service": "provisioner", "name": "opensdn-provisioner", "release": "5.1.0", "summary": "Contrail Provisioner", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "vrouter-agent": {"vrouter_vrouter-agent_1": {"cmd": ["/usr/bin/contrail-vrouter-agent"], "image": "nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "ae838e491fb3682a6d5a39f10fbfefa08cc1b88934b9ca36e93e188aedb7c086", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "vrouter", "com.docker.compose.project.config_files": "/etc/contrail/vrouter/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/vrouter", "com.docker.compose.service": "vrouter-agent", "com.docker.compose.version": "1.29.2", "description": "The vRouter agent is a user space process running inside Linux. It acts as the local, lightweight control plane.", "io.opensdn.container.name": "opensdn-vrouter-agent", "io.opensdn.pod": "vrouter", "io.opensdn.service": "agent", "name": "opensdn-vrouter-agent", "release": "5.1.0", "summary": "Contrail Vrouter Agent", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}, "vrouter-kernel-init": {"vrouter_vrouter-kernel-init_1": {"cmd": [], "image": "nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-1_0_8_7-7_0", "labels": {"com.docker.compose.config-hash": "9a3ff1144025ce64a0aea6d0c1db134d03bf474c4465a3480e99e05bc480c153", "com.docker.compose.container-number": "1", "com.docker.compose.oneoff": "False", "com.docker.compose.project": "vrouter", "com.docker.compose.project.config_files": "/etc/contrail/vrouter/docker-compose.yaml", "com.docker.compose.project.working_dir": "/etc/contrail/vrouter", "com.docker.compose.service": "vrouter-kernel-init", "com.docker.compose.version": "1.29.2", "description": "This image is used to build vrouter.ko for current ubuntu operating system that it's running on.", "io.opensdn.container.name": "opensdn-vrouter-kernel-build-init", "name": "opensdn-vrouter-kernel-build-init", "org.opencontainers.image.ref.name": "ubuntu", "org.opencontainers.image.version": "24.04", "release": "5.1.0", "summary": "Contrail vrouter kernel module for ubuntu", "vendor": "OpenSDN-IO", "version": "master-1_0_8_7-7_0"}, "networks": {"host": {"IPAddress": "", "IPPrefixLen": 0, "aliases": [], "globalIPv6": "", "globalIPv6PrefixLen": 0, "links": null, "macAddress": ""}}, "state": {"running": true, "status": "running"}}}}} TASK [opensdn_vrouter : Set variables for DPDK plugins] ************************ ok: [10.0.0.254] => {"ansible_facts": {"mellanox": false, "n3000": false, "plugin_os": "ubuntu"}, "changed": false} PLAY RECAP ********************************************************************* 10.0.0.254 : ok=92 changed=63 unreachable=0 failed=0 skipped=60 rescued=0 ignored=7 localhost : ok=66 changed=0 unreachable=0 failed=0 skipped=34 rescued=0 ignored=0 INFO: done in 0s INFO: check time sync on nodes and force sync Wed Apr 30 11:51:18 UTC 2025 INFO: controller nodes - 10.0.0.254 INFO: agent nodes - 10.0.0.254 INFO: openstack controller nodes - INFO: sync time on machine ubuntu@10.0.0.254 Warning: Permanently added '10.0.0.254' (ED25519) to the list of known hosts. Warning: Permanently added '10.0.0.254' (ED25519) to the list of known hosts. INFO: Wed Apr 30 11:51:19 UTC 2025: ensure time is synced (chronyd) INFO: Wed Apr 30 11:51:19 UTC 2025: time is synced TF Web UI must be available at https://10.0.0.254:8143 OpenStack UI must be avaiable at http://10.0.0.254 Use admin/contrail123 to log in INFO: Stage tf was run successfully Wed Apr 30 11:51:19 UTC 2025 INFO: Running stage wait at Wed Apr 30 11:51:19 UTC 2025 . INFO: done in 10s INFO: Stage wait was run successfully Wed Apr 30 11:51:40 UTC 2025 [update tf stack configuration] tf setup profile /home/ubuntu/.tf/stack.env DEPLOYER=ansible CONTRAIL_CONTAINER_TAG=master-1_0_8_7-7_0 CONTRAIL_DEPLOYER_CONTAINER_TAG=master-1_0_8_7-7_0 CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 DEPLOYER_CONTAINER_REGISTRY=nexus.gz1.opensdn.io:5101 ORCHESTRATOR=openstack OPENSTACK_VERSION="yoga" CONTROLLER_NODES="10.0.0.254 " AGENT_NODES="10.0.0.254" CONTROL_NODES="10.0.0.254 " SSL_ENABLE="false" LEGACY_ANALYTICS_ENABLE="true" HUGE_PAGES_1G= CONTAINER_RUNTIME=docker K8S_CA= DEPLOY_IPA_SERVER= IPA_PASSWORD= OPENSTACK_CONTROLLER_NODES='10.0.0.254' OS_AUTH_URL='http://10.0.0.254:5000/v3' AUTH_PASSWORD='contrail123' AUTH_URL='' INFO: Successful deployment Wed Apr 30 11:51:40 UTC 2025 DEBUG: kill running child jobs: INFO: Deploy finished + exit Archiving artifacts Finished: SUCCESS