2026-06-08 15:05:54,629: INFO: Building opensdn-controller-config-devicemgr 2026-06-08 15:05:54,684: INFO: Building args: --network host --build-arg PIP_REPOSITORY=http://localhost:6667/pip/simple --build-arg CONTRAIL_REGISTRY=nexus.gz1.opensdn.io:5101 --build-arg CONTRAIL_CONTAINER_TAG=master-2_8_0_1-9 --build-arg SITE_MIRROR=http://nexus.gz1.opensdn.io/repository/external-web-cache --build-arg LINUX_DISTR_VER=9 --build-arg LINUX_DISTR=rockylinux --build-arg CONTAINER_NAME=opensdn-controller-config-devicemgr --build-arg UBUNTU_DISTR_VERSION=24.04 --build-arg UBUNTU_DISTR=ubuntu --build-arg VENDOR_NAME=OpenSDN-IO --build-arg VENDOR_DOMAIN=io.opensdn --build-arg BUILD_IMAGE=tf-dev-sandbox:compile --build-arg BUILD_ROOT=/buildroot --build-arg DEBUGINFO_ROOT=/debuginfo #0 building with "default" instance using docker driver #1 [internal] load build definition from Dockerfile #1 transferring dockerfile: #1 transferring dockerfile: 2.19kB done #1 WARN: InvalidDefaultArgInFrom: Default value for ARG ${BUILD_IMAGE} results in empty or invalid base image name (line 4) #1 WARN: InvalidDefaultArgInFrom: Default value for ARG ${CONTRAIL_REGISTRY}/opensdn-controller-config-base:${CONTRAIL_CONTAINER_TAG} results in empty or invalid base image name (line 6) #1 DONE 0.6s #2 [internal] load metadata for nexus.gz1.opensdn.io:5101/opensdn-controller-config-base:master-2_8_0_1-9 #2 DONE 0.0s #3 [internal] load metadata for docker.io/library/tf-dev-sandbox:compile #3 DONE 0.0s #4 [internal] load .dockerignore #4 transferring context: #4 transferring context: 2B done #4 DONE 1.6s #5 [1/1] FROM nexus.gz1.opensdn.io:5101/opensdn-base:master-2_8_0_1-9 #5 DONE 0.2s #6 [build 1/1] FROM docker.io/library/tf-dev-sandbox:compile #6 CACHED #7 [1/3] FROM nexus.gz1.opensdn.io:5101/opensdn-controller-config-base:master-2_8_0_1-9 #7 DONE 0.0s #8 [stage-1 2/4] COPY --from=build /pip/fabric_ansible_playbooks-0.1.dev0.tar.gz /opt/ #8 DONE 1.2s #9 [internal] load build context #9 transferring context: 1.97kB done #9 DONE 1.5s #10 [stage-1 3/4] RUN set -e ; dnf install -y libffi-devel iputils ; python3 -m pip install "cryptography<3.5" "importlib-resources<5.1"; python3 -m pip install --no-compile --no-binary :all: ansible ansible-core ; dnf clean all -y ; rm -rf /var/cache/yum ; source /functions.sh ; download_package https://github.com Juniper/ansible-junos-stdlib/archive/2.4.2.tar.gz Juniper.junos ; ansible-galaxy install Juniper.junos ; rm -f Juniper.junos ; python3 -m pip install --no-compile --extra-index-url http://localhost:6667/pip/simple "device_manager==0.1.dev0" "fabric_ansible==0.1.dev0" ; rm -rf /root/.cache ; mkdir -p /etc/ansible ; last="fabric_ansible_playbooks-0.1.dev0.tar.gz" ; echo "DBG: /opt/ last tar.gz = $last" ; tar -xzf /opt/$last -C /opt ; mv /opt/${last/.tar.gz/}/* /opt/ ; rmdir /opt/${last/.tar.gz/}/ ; cp /opt/ansible.cfg /etc/ansible/ansible.cfg #10 1.434 added from: http://tf-mirrors.gz1.opensdn.io/re 41 MB/s | 14 MB 00:00 #10 4.085 added from: http://tf-mirrors.gz1.opensdn.io/re 31 MB/s | 1.9 MB 00:00 #10 4.733 added from: http://tf-mirrors.gz1.opensdn.io/re 11 MB/s | 402 kB 00:00 #10 5.384 added from: http://tf-mirrors.gz1.opensdn.io/re 53 MB/s | 16 MB 00:00 #10 13.16 added from: http://tf-mirrors.gz1.opensdn.io/re 49 MB/s | 11 MB 00:00 #10 18.74 added from: http://tf-mirrors.gz1.opensdn.io/re 17 MB/s | 1.1 MB 00:00 #10 19.56 added from: http://tf-mirrors.gz1.opensdn.io/re 29 MB/s | 4.8 MB 00:00 #10 22.37 added from: http://tf-mirrors.gz1.opensdn.io/re 17 MB/s | 697 kB 00:00 #10 22.78 added from: http://tf-mirrors.gz1.opensdn.io/re 12 MB/s | 474 kB 00:00 #10 23.53 added from: http://tf-mirrors.gz1.opensdn.io/re 499 kB/s | 18 kB 00:00 #10 24.10 added from: http://tf-mirrors.gz1.opensdn.io/re 10 kB/s | 257 B 00:00 #10 24.58 added from: http://tf-mirrors.gz1.opensdn.io/re 58 kB/s | 15 kB 00:00 #10 25.15 added from: http://tf-mirrors.gz1.opensdn.io/re 1.3 MB/s | 96 kB 00:00 #10 26.49 added from: http://tf-mirrors.gz1.opensdn.io/re 44 MB/s | 39 MB 00:00 #10 55.92 Third parties for OpenSDN 14 MB/s | 5.1 MB 00:00 #10 77.52 Dependencies resolved. #10 77.52 ================================================================================ #10 77.52 Package Arch Version Repository Size #10 77.52 ================================================================================ #10 77.52 Installing: #10 77.52 iputils x86_64 20210202-15.el9 tf-mirrors.ci_repos_yum9-baseos 167 k #10 77.52 libffi-devel x86_64 3.4.2-8.el9 tf-mirrors.ci_repos_yum9-appstream 28 k #10 77.52 #10 77.52 Transaction Summary #10 77.52 ================================================================================ #10 77.52 Install 2 Packages #10 77.52 #10 77.52 Total download size: 196 k #10 77.52 Installed size: 531 k #10 77.52 Downloading Packages: #10 77.54 (1/2): libffi-devel-3.4.2-8.el9.x86_64.rpm 1.3 MB/s | 28 kB 00:00 #10 77.55 (2/2): iputils-20210202-15.el9.x86_64.rpm 6.5 MB/s | 167 kB 00:00 #10 77.55 -------------------------------------------------------------------------------- #10 77.55 Total 7.3 MB/s | 196 kB 00:00 #10 77.55 Running transaction check #10 77.60 Transaction check succeeded. #10 77.62 Running transaction test #10 77.69 Transaction test succeeded. #10 77.69 Running transaction #10 77.73 Preparing : 1/1 #10 77.82 Installing : libffi-devel-3.4.2-8.el9.x86_64 1/2 #10 77.83 Installing : iputils-20210202-15.el9.x86_64 2/2 #10 77.85 Running scriptlet: iputils-20210202-15.el9.x86_64 2/2 #10 78.54 Verifying : iputils-20210202-15.el9.x86_64 1/2 #10 78.54 Verifying : libffi-devel-3.4.2-8.el9.x86_64 2/2 #10 78.63 #10 78.63 Installed: #10 78.63 iputils-20210202-15.el9.x86_64 libffi-devel-3.4.2-8.el9.x86_64 #10 78.63 #10 78.63 Complete! #10 80.26 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/ #10 84.33 Collecting cryptography<3.5 #10 84.36 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/996/5c46c674ba8cc/cryptography-3.4.8-cp36-abi3-manylinux_2_24_x86_64.whl (3.0 MB) #10 84.72 Collecting importlib-resources<5.1 #10 84.75 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/223/8159eb743bd85/importlib_resources-5.0.7-py3-none-any.whl (24 kB) #10 87.34 Collecting cffi>=1.12 #10 87.36 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/61d/028e90346df14/cffi-2.0.0-cp39-cp39-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (216 kB) #10 87.54 Collecting pycparser #10 87.56 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e5c/6e8d3fbad5347/pycparser-2.23-py3-none-any.whl (118 kB) #10 88.58 Installing collected packages: pycparser, cffi, importlib-resources, cryptography #10 90.19 Successfully installed cffi-2.0.0 cryptography-3.4.8 importlib-resources-5.0.7 pycparser-2.23 #10 90.19 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv #10 92.55 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/ #10 93.12 Collecting ansible #10 93.39 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/3a5/ca5152e4547d5/ansible-8.7.0.tar.gz (49.3 MB) #10 148.3 Installing build dependencies: started #10 153.8 Installing build dependencies: finished with status 'done' #10 153.8 Getting requirements to build wheel: started #10 223.4 Getting requirements to build wheel: still running... #10 223.4 Getting requirements to build wheel: finished with status 'done' #10 223.4 Preparing metadata (pyproject.toml): started #10 286.4 Preparing metadata (pyproject.toml): still running... #10 286.4 Preparing metadata (pyproject.toml): finished with status 'done' #10 286.6 Collecting ansible-core #10 286.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f54/2e702ee31fb04/ansible_core-2.15.13.tar.gz (3.1 MB) #10 288.9 Installing build dependencies: started #10 294.7 Installing build dependencies: finished with status 'done' #10 294.7 Getting requirements to build wheel: started #10 295.5 Getting requirements to build wheel: finished with status 'done' #10 295.6 Preparing metadata (pyproject.toml): started #10 296.1 Preparing metadata (pyproject.toml): finished with status 'done' #10 296.1 Collecting jinja2>=3.0.0 #10 296.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/013/7fb05990d35f1/jinja2-3.1.6.tar.gz (245 kB) #10 296.4 Installing build dependencies: started #10 298.5 Installing build dependencies: finished with status 'done' #10 298.5 Getting requirements to build wheel: started #10 298.6 Getting requirements to build wheel: finished with status 'done' #10 298.6 Preparing metadata (pyproject.toml): started #10 298.6 Preparing metadata (pyproject.toml): finished with status 'done' #10 298.7 Collecting resolvelib<1.1.0,>=0.5.3 #10 298.7 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/04c/e76cbd63fded2/resolvelib-1.0.1.tar.gz (21 kB) #10 298.9 Installing build dependencies: started #10 308.5 Installing build dependencies: finished with status 'done' #10 308.5 Getting requirements to build wheel: started #10 308.7 Getting requirements to build wheel: finished with status 'done' #10 308.7 Preparing metadata (pyproject.toml): started #10 308.9 Preparing metadata (pyproject.toml): finished with status 'done' #10 308.9 Requirement already satisfied: packaging in /usr/local/lib/python3.9/site-packages (from ansible-core) (26.0) #10 309.0 Collecting PyYAML>=5.1 #10 309.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/d76/623373421df22/pyyaml-6.0.3.tar.gz (130 kB) #10 309.4 Installing build dependencies: started #10 380.7 Installing build dependencies: still running... #10 441.0 Installing build dependencies: still running... #10 455.3 Installing build dependencies: finished with status 'done' #10 455.3 Getting requirements to build wheel: started #10 456.5 Getting requirements to build wheel: finished with status 'done' #10 456.5 Preparing metadata (pyproject.toml): started #10 456.8 Preparing metadata (pyproject.toml): finished with status 'done' #10 456.8 Requirement already satisfied: importlib-resources<5.1,>=5.0 in /usr/local/lib/python3.9/site-packages (from ansible-core) (5.0.7) #10 456.8 Requirement already satisfied: cryptography in /usr/local/lib64/python3.9/site-packages (from ansible-core) (3.4.8) #10 457.0 Collecting MarkupSafe>=2.0 #10 457.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/722/695808f4b6457/markupsafe-3.0.3.tar.gz (80 kB) #10 457.2 Installing build dependencies: started #10 461.8 Installing build dependencies: finished with status 'done' #10 461.8 Getting requirements to build wheel: started #10 462.0 Getting requirements to build wheel: finished with status 'done' #10 462.0 Preparing metadata (pyproject.toml): started #10 462.2 Preparing metadata (pyproject.toml): finished with status 'done' #10 462.3 Requirement already satisfied: cffi>=1.12 in /usr/local/lib64/python3.9/site-packages (from cryptography->ansible-core) (2.0.0) #10 462.3 Requirement already satisfied: pycparser in /usr/local/lib/python3.9/site-packages (from cffi>=1.12->cryptography->ansible-core) (2.23) #10 462.3 Building wheels for collected packages: ansible, ansible-core, jinja2, PyYAML, resolvelib, MarkupSafe #10 462.3 Building wheel for ansible (pyproject.toml): started #10 539.6 Building wheel for ansible (pyproject.toml): still running... #10 550.0 Building wheel for ansible (pyproject.toml): finished with status 'done' #10 550.2 Created wheel for ansible: filename=ansible-8.7.0-py3-none-any.whl size=48371394 sha256=0a8a930fbf796bf819cd7a0c4afaab5859b67c169153df419c2767b660e04422 #10 550.2 Stored in directory: /root/.cache/pip/wheels/45/76/58/9502290a467417ab1444d84c63019adb1daaed6d18d308b817 #10 550.4 Building wheel for ansible-core (pyproject.toml): started #10 552.1 Building wheel for ansible-core (pyproject.toml): finished with status 'done' #10 552.1 Created wheel for ansible-core: filename=ansible_core-2.15.13-py3-none-any.whl size=2251441 sha256=220927128e4035cfd1497475551ff9e9c82cc405a5fb9c5437bb6e998748c92d #10 552.1 Stored in directory: /root/.cache/pip/wheels/de/f1/0f/5bdba5e828d49ff45930d6032cef3961e2e673467b0d7bbb1e #10 552.1 Building wheel for jinja2 (pyproject.toml): started #10 552.3 Building wheel for jinja2 (pyproject.toml): finished with status 'done' #10 552.3 Created wheel for jinja2: filename=jinja2-3.1.6-py3-none-any.whl size=134897 sha256=005a2fc379b662ac007c271a8122f7a7db49bb67fbedfc85db50fccde34d839f #10 552.3 Stored in directory: /root/.cache/pip/wheels/7b/c3/fc/fe2ea80be37d89f3c720e53076aac0407f529f0c29356a6215 #10 552.3 Building wheel for PyYAML (pyproject.toml): started #10 552.7 Building wheel for PyYAML (pyproject.toml): finished with status 'done' #10 552.7 Created wheel for PyYAML: filename=pyyaml-6.0.3-cp39-cp39-linux_x86_64.whl size=45461 sha256=734030a98adf4f4bf1d6fb51ea14b98d4059d982df3106d0c64ac80fe6eb73de #10 552.7 Stored in directory: /root/.cache/pip/wheels/79/fb/92/ef421e052606484d88d2a8592c227e766d44081f6c09bdecbb #10 552.7 Building wheel for resolvelib (pyproject.toml): started #10 553.0 Building wheel for resolvelib (pyproject.toml): finished with status 'done' #10 553.0 Created wheel for resolvelib: filename=resolvelib-1.0.1-py2.py3-none-any.whl size=17235 sha256=d0cf46a0a5a0b62a698603a2eea367d8f7b1773e87a4ab0ce6515f0998fc889c #10 553.0 Stored in directory: /root/.cache/pip/wheels/9b/e8/75/66577720290e60215abc77f8972bc2f567d4058bd85a58f881 #10 553.0 Building wheel for MarkupSafe (pyproject.toml): started #10 553.4 Building wheel for MarkupSafe (pyproject.toml): finished with status 'done' #10 553.4 Created wheel for MarkupSafe: filename=markupsafe-3.0.3-cp39-cp39-linux_x86_64.whl size=21266 sha256=8e39c1e542c15537ef484f19332287177d9e1ad953531fa7143e5a9755fb1ca5 #10 553.4 Stored in directory: /root/.cache/pip/wheels/da/bd/2a/6dd1ba50acf54588ceab2b7322c7a9bc5f41b28772c485e8fc #10 553.4 Successfully built ansible ansible-core jinja2 PyYAML resolvelib MarkupSafe #10 553.8 Installing collected packages: MarkupSafe, resolvelib, PyYAML, jinja2, ansible-core, ansible #10 558.8 Successfully installed MarkupSafe-3.0.3 PyYAML-6.0.3 ansible-8.7.0 ansible-core-2.15.13 jinja2-3.1.6 resolvelib-1.0.1 #10 558.8 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv #10 561.6 77 files removed #10 561.6 2026-06-08 15:15:22 URL:http://nexus.gz1.opensdn.io/repository/external-web-cache/Juniper/ansible-junos-stdlib/archive/2.4.2.tar.gz [108498/108498] -> "Juniper.junos" [1] #10 562.5 Starting galaxy role install process #10 562.5 - extracting Juniper.junos to /root/.ansible/roles/Juniper.junos #10 562.5 - Juniper.junos was installed successfully #10 562.9 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/, http://localhost:6667/pip/simple #10 563.2 Collecting device_manager==0.1.dev0 #10 563.2 Downloading http://localhost:6667/pip/simple/device-manager/device_manager-0.1.dev0-py3-none-any.whl (321 kB) #10 563.2 Collecting fabric_ansible==0.1.dev0 #10 563.2 Downloading http://localhost:6667/pip/simple/fabric-ansible/fabric_ansible-0.1.dev0-py3-none-any.whl (41 kB) #10 563.3 Collecting netifaces #10 563.3 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e76/c7f351e044472/netifaces-0.11.0-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.whl (32 kB) #10 563.8 Collecting cityhash #10 563.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/428/9853163c77966/cityhash-0.4.10-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (555 kB) #10 563.8 Collecting ncclient #10 563.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/47b/eeeee6074bd70/ncclient-0.7.1-py3-none-any.whl (94 kB) #10 563.8 Requirement already satisfied: contrail-config-common==0.1.dev0 in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.1.dev0) #10 563.9 Collecting inflection #10 563.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f38/b2b640938a4f3/inflection-0.5.1-py2.py3-none-any.whl (9.5 kB) #10 563.9 Requirement already satisfied: netaddr<1 in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.10.1) #10 563.9 Requirement already satisfied: timeout-decorator in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.5.0) #10 563.9 Requirement already satisfied: stevedore in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (5.5.0) #10 565.0 Collecting lxml #10 565.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/ee2/a470a1be95c3d/lxml-6.0.4-cp39-cp39-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (5.3 MB) #10 565.1 Requirement already satisfied: bitarray in /usr/local/lib64/python3.9/site-packages (from device_manager==0.1.dev0) (3.8.1) #10 565.1 Collecting junos-eznc #10 565.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/a4f/9cc290fde95b8/junos_eznc-2.7.6-py2.py3-none-any.whl (207 kB) #10 565.2 Requirement already satisfied: kombu in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (5.6.2) #10 565.3 Collecting jsonschema #10 565.3 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/3fb/a0169e345c717/jsonschema-4.25.1-py3-none-any.whl (90 kB) #10 565.4 Collecting attrdict #10 565.4 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/943/2e3498c74ff7e/attrdict-2.0.1-py2.py3-none-any.whl (9.9 kB) #10 565.7 Collecting psutil #10 565.7 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/076/a2d2f923fd482/psutil-7.2.2-cp36-abi3-manylinux2010_x86_64.manylinux_2_12_x86_64.manylinux_2_28_x86_64.whl (155 kB) #10 565.7 Requirement already satisfied: gevent in /usr/local/lib64/python3.9/site-packages (from device_manager==0.1.dev0) (26.4.0) #10 565.8 Collecting docker #10 565.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c96/b93b7f0a746f9/docker-7.1.0-py3-none-any.whl (147 kB) #10 565.8 Requirement already satisfied: bottle<0.13 in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.12.25) #10 565.9 Collecting pysnmp #10 565.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e3f/ed6eab479a4ec/pysnmp-7.1.21-py3-none-any.whl (343 kB) #10 566.0 Collecting subprocess32 #10 566.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/eb2/937c80497978d/subprocess32-3.5.4.tar.gz (97 kB) #10 566.0 Preparing metadata (setup.py): started #10 566.2 Preparing metadata (setup.py): finished with status 'done' #10 566.2 Requirement already satisfied: xmltodict==0.12.0 in /usr/local/lib/python3.9/site-packages (from fabric_ansible==0.1.dev0) (0.12.0) #10 566.2 Requirement already satisfied: jinja2 in /usr/local/lib/python3.9/site-packages (from fabric_ansible==0.1.dev0) (3.1.6) #10 566.2 Collecting pycrypto #10 566.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f2c/e1e989b272cfc/pycrypto-2.6.1.tar.gz (446 kB) #10 566.3 Preparing metadata (setup.py): started #10 566.5 Preparing metadata (setup.py): finished with status 'done' #10 566.6 Collecting jsnapy #10 566.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/520/2fd0910cecd32/jsnapy-1.3.8-py2.py3-none-any.whl (50 kB) #10 566.6 Collecting pyroute2 #10 566.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/333/4091326e560a5/pyroute2-0.9.6-py3-none-any.whl (483 kB) #10 566.7 Requirement already satisfied: greenlet in /usr/local/lib64/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (3.2.5) #10 566.7 Requirement already satisfied: simplejson in /usr/local/lib64/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (3.20.2) #10 566.7 Requirement already satisfied: cassandra-driver in /usr/local/lib64/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (3.29.3) #10 566.7 Requirement already satisfied: requests in /usr/local/lib/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (2.32.5) #10 566.7 Requirement already satisfied: sandesh==0.1.dev0 in /usr/local/lib/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (0.1.dev0) #10 566.7 Requirement already satisfied: contrail-api-client==0.1.dev0 in /usr/local/lib/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (0.1.dev0) #10 566.7 Requirement already satisfied: sandesh-common==0.1.dev0 in /usr/local/lib/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (0.1.dev0) #10 566.7 Requirement already satisfied: kazoo in /usr/local/lib/python3.9/site-packages (from contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (2.11.0) #10 566.7 Requirement already satisfied: fysom in /usr/local/lib/python3.9/site-packages (from sandesh==0.1.dev0->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (2.1.6) #10 566.7 Requirement already satisfied: six in /usr/lib/python3.9/site-packages (from attrdict->device_manager==0.1.dev0) (1.15.0) #10 566.7 Requirement already satisfied: urllib3>=1.26.0 in /usr/local/lib/python3.9/site-packages (from docker->device_manager==0.1.dev0) (2.6.3) #10 566.7 Requirement already satisfied: zope.interface in /usr/local/lib64/python3.9/site-packages (from gevent->device_manager==0.1.dev0) (8.0.1) #10 566.7 Requirement already satisfied: zope.event in /usr/local/lib/python3.9/site-packages (from gevent->device_manager==0.1.dev0) (6.0) #10 566.7 Requirement already satisfied: MarkupSafe>=2.0 in /usr/local/lib64/python3.9/site-packages (from jinja2->fabric_ansible==0.1.dev0) (3.0.3) #10 566.8 Collecting colorama #10 566.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/4f1/d9991f5acc0ca/colorama-0.4.6-py2.py3-none-any.whl (25 kB) #10 566.8 Collecting configparser #10 566.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/fee/5e1f3db4156dc/configparser-7.2.0-py3-none-any.whl (17 kB) #10 566.9 Collecting future #10 566.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/929/292d34f5872e7/future-1.0.0-py3-none-any.whl (491 kB) #10 567.0 Collecting pyparsing #10 567.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/850/ba148bd908d7e/pyparsing-3.3.2-py3-none-any.whl (122 kB) #10 567.1 Collecting icdiff==1.9.1 #10 567.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/669/72dd03318da55/icdiff-1.9.1.tar.gz (9.1 kB) #10 567.1 Preparing metadata (setup.py): started #10 567.3 Preparing metadata (setup.py): finished with status 'done' #10 567.3 Collecting jsonschema-specifications>=2023.03.6 #10 567.4 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/988/02fee3a11ee76/jsonschema_specifications-2025.9.1-py3-none-any.whl (18 kB) #10 567.5 Collecting referencing>=0.28.4 #10 567.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e86/99adbbf8b5c7d/referencing-0.36.2-py3-none-any.whl (26 kB) #10 569.0 Collecting rpds-py>=0.7.1 #10 569.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/2fd/50659a069c15e/rpds_py-0.27.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (384 kB) #10 569.1 Collecting attrs>=22.2.0 #10 569.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c64/7aa4a12dfbad9/attrs-26.1.0-py3-none-any.whl (67 kB) #10 569.1 Collecting ncclient #10 569.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/318/e8e3e72b1d2a7/ncclient-0.7.0.tar.gz (116 kB) #10 569.2 Preparing metadata (setup.py): started #10 569.4 Preparing metadata (setup.py): finished with status 'done' #10 569.5 Collecting paramiko>=3.5.0 #10 569.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/0e2/0e00ac666503b/paramiko-4.0.0-py3-none-any.whl (223 kB) #10 569.5 Collecting scp>=0.7.0 #10 569.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/9e7/f721e5ac563c3/scp-0.15.0-py2.py3-none-any.whl (8.8 kB) #10 569.5 Requirement already satisfied: PyYAML>=5.1 in /usr/local/lib64/python3.9/site-packages (from junos-eznc->device_manager==0.1.dev0) (6.0.3) #10 569.6 Collecting transitions #10 569.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/024/63248f2b668d8/transitions-0.9.3-py2.py3-none-any.whl (112 kB) #10 569.7 Collecting pyserial #10 569.7 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c44/51db6ba391ca6/pyserial-3.5-py2.py3-none-any.whl (90 kB) #10 569.7 Collecting yamlloader #10 569.7 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/d9e/a9948759732ea/yamlloader-1.6.0-py3-none-any.whl (7.8 kB) #10 569.8 Requirement already satisfied: packaging in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (26.0) #10 569.8 Requirement already satisfied: amqp<6.0.0,>=5.1.1 in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (5.3.1) #10 569.8 Requirement already satisfied: vine==5.1.0 in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (5.1.0) #10 569.8 Requirement already satisfied: tzdata>=2025.2 in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (2026.1) #10 570.0 Collecting pyasn1!=0.5.0,>=0.4.8 #10 570.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/a80/184d120f0864a/pyasn1-0.6.3-py3-none-any.whl (83 kB) #10 570.1 Collecting invoke>=2.0 #10 570.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f11/327165e5cbb89/invoke-3.0.3-py3-none-any.whl (160 kB) #10 570.2 Collecting pynacl>=1.5 #10 570.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c8a/231e36ec2cab0/pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl (1.4 MB) #10 570.4 Collecting bcrypt>=3.2 #10 570.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/611/f0a17aa4a25a6/bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl (278 kB) #10 570.5 Requirement already satisfied: cryptography>=3.3 in /usr/local/lib64/python3.9/site-packages (from paramiko>=3.5.0->junos-eznc->device_manager==0.1.dev0) (3.4.8) #10 570.5 Collecting typing-extensions>=4.4.0 #10 570.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f0f/a19c6845758ab/typing_extensions-4.15.0-py3-none-any.whl (44 kB) #10 570.6 Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.9/site-packages (from requests->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (3.11) #10 570.6 Requirement already satisfied: charset_normalizer<4,>=2 in /usr/local/lib64/python3.9/site-packages (from requests->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (3.4.7) #10 570.6 Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.9/site-packages (from requests->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (2026.2.25) #10 570.6 Requirement already satisfied: geomet>=1.1 in /usr/local/lib/python3.9/site-packages (from cassandra-driver->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (1.1.0) #10 570.7 Requirement already satisfied: setuptools>=75.8.2 in /usr/local/lib/python3.9/site-packages (from zope.event->gevent->device_manager==0.1.dev0) (82.0.1) #10 570.7 Requirement already satisfied: cffi>=1.12 in /usr/local/lib64/python3.9/site-packages (from cryptography>=3.3->paramiko>=3.5.0->junos-eznc->device_manager==0.1.dev0) (2.0.0) #10 570.7 Requirement already satisfied: click in /usr/local/lib/python3.9/site-packages (from geomet>=1.1->cassandra-driver->contrail-config-common==0.1.dev0->device_manager==0.1.dev0) (8.1.8) #10 570.8 Requirement already satisfied: pycparser in /usr/local/lib/python3.9/site-packages (from cffi>=1.12->cryptography>=3.3->paramiko>=3.5.0->junos-eznc->device_manager==0.1.dev0) (2.23) #10 570.8 Using legacy 'setup.py install' for icdiff, since package 'wheel' is not installed. #10 570.8 Using legacy 'setup.py install' for ncclient, since package 'wheel' is not installed. #10 570.8 Using legacy 'setup.py install' for pycrypto, since package 'wheel' is not installed. #10 570.8 Using legacy 'setup.py install' for subprocess32, since package 'wheel' is not installed. #10 571.1 Installing collected packages: pynacl, invoke, bcrypt, typing-extensions, rpds-py, paramiko, lxml, attrs, yamlloader, transitions, scp, referencing, pyserial, pyparsing, ncclient, pyasn1, junos-eznc, jsonschema-specifications, icdiff, future, configparser, colorama, subprocess32, pysnmp, pyroute2, pycrypto, psutil, netifaces, jsonschema, jsnapy, inflection, docker, cityhash, attrdict, fabric-ansible, device-manager #10 571.4 Running setup.py install for ncclient: started #10 571.7 Running setup.py install for ncclient: finished with status 'done' #10 571.8 Running setup.py install for icdiff: started #10 572.0 Running setup.py install for icdiff: finished with status 'done' #10 572.1 Running setup.py install for subprocess32: started #10 572.4 Running setup.py install for subprocess32: finished with status 'done' #10 572.5 Running setup.py install for pycrypto: started #10 580.0 Running setup.py install for pycrypto: finished with status 'done' #10 580.2 Successfully installed attrdict-2.0.1 attrs-26.1.0 bcrypt-5.0.0 cityhash-0.4.10 colorama-0.4.6 configparser-7.2.0 device-manager-0.1.dev0 docker-7.1.0 fabric-ansible-0.1.dev0 future-1.0.0 icdiff-1.9.1 inflection-0.5.1 invoke-3.0.3 jsnapy-1.3.8 jsonschema-4.25.1 jsonschema-specifications-2025.9.1 junos-eznc-2.7.6 lxml-6.0.4 ncclient-0.7.0 netifaces-0.11.0 paramiko-4.0.0 psutil-7.2.2 pyasn1-0.6.3 pycrypto-2.6.1 pynacl-1.6.2 pyparsing-3.3.2 pyroute2-0.9.6 pyserial-3.5 pysnmp-7.1.21 referencing-0.36.2 rpds-py-0.27.1 scp-0.15.0 subprocess32-3.5.4 transitions-0.9.3 typing-extensions-4.15.0 yamlloader-1.6.0 #10 580.2 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv #10 580.4 DBG: /opt/ last tar.gz = fabric_ansible_playbooks-0.1.dev0.tar.gz #10 DONE 584.8s #11 [stage-1 4/4] COPY *.sh / #11 DONE 0.1s #12 exporting to image #12 exporting layers #12 exporting layers 4.2s done #12 writing image sha256:eb46977a793e591f513edd848c5755a5ca691cc6fa31f9cf0c6da5d0695f7c7a done #12 naming to nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-2_8_0_1-9 done #12 DONE 4.2s 2 warnings found (use docker --debug to expand):  - InvalidDefaultArgInFrom: Default value for ARG ${BUILD_IMAGE} results in empty or invalid base image name (line 4) - InvalidDefaultArgInFrom: Default value for ARG ${CONTRAIL_REGISTRY}/opensdn-controller-config-base:${CONTRAIL_CONTAINER_TAG} results in empty or invalid base image name (line 6) 2026-06-08 15:15:50,402: INFO: Docker build duration: 596 seconds The push refers to repository [nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr] bcabbcd3b83b: Preparing b590c3bf2188: Preparing f1b794169b0e: Preparing 8c1a4100d503: Preparing 4b0b2386cbfe: Preparing 1322bec76e6b: Preparing 446cd3b18ea7: Preparing 956f70c01747: Preparing 5c64bc9b2798: Preparing 450f319ee6f9: Preparing eafb36869cda: Preparing 36d1e65879da: Preparing f68cf63f744b: Preparing 0ba3b1f6cacf: Preparing 65b0a58b9d53: Preparing 13d3031cfee0: Preparing 44343de3ea1d: Preparing 5c64bc9b2798: Waiting 450f319ee6f9: Waiting eafb36869cda: Waiting 36d1e65879da: Waiting f68cf63f744b: Waiting 0ba3b1f6cacf: Waiting 65b0a58b9d53: Waiting 13d3031cfee0: Waiting 44343de3ea1d: Waiting 1322bec76e6b: Waiting 446cd3b18ea7: Waiting 956f70c01747: Waiting 8c1a4100d503: Layer already exists 4b0b2386cbfe: Layer already exists 1322bec76e6b: Layer already exists 446cd3b18ea7: Layer already exists 5c64bc9b2798: Layer already exists 956f70c01747: Layer already exists bcabbcd3b83b: Pushed eafb36869cda: Layer already exists f1b794169b0e: Pushed 450f319ee6f9: Layer already exists 36d1e65879da: Layer already exists 65b0a58b9d53: Layer already exists f68cf63f744b: Layer already exists 0ba3b1f6cacf: Layer already exists 13d3031cfee0: Layer already exists 44343de3ea1d: Layer already exists b590c3bf2188: Pushed master-2_8_0_1-9: digest: sha256:c76af01ffa2541643bfd8296c7bb965f91ce1d3518b8da1a757cc6790c2de693 size: 3878 2026-06-08 15:16:02,679: INFO: Building opensdn-controller-config-devicemgr finished successfully, duration: 608 seconds WARNING: This output is designed for human readability. For machine-readable output, please use --format. IMAGE ID DISK USAGE CONTENT SIZE EXTRA nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen:master-2_8_0_1-9 1529b671f22e 692MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-api:master-2_8_0_1-9 c85df8bc300b 701MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-base:master-2_8_0_1-9 647d37417566 676MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-collector:master-2_8_0_1-9 cd2492b4607c 758MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine:master-2_8_0_1-9 642e1f778c21 754MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-base:master-2_8_0_1-9 037c21f2dfc7 917MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector:master-2_8_0_1-9 1cf19e834036 918MB 0B nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology:master-2_8_0_1-9 60c1c9f447df 918MB 0B nexus.gz1.opensdn.io:5101/opensdn-ansible-deployer-src:master-2_8_0_1-9 66d70a80e0f7 1.41MB 0B nexus.gz1.opensdn.io:5101/opensdn-base:master-2_8_0_1-9 f1854913b285 676MB 0B nexus.gz1.opensdn.io:5101/opensdn-build-manifest-src:master-2_8_0_1-9 a09fdf1065f4 4.17kB 0B nexus.gz1.opensdn.io:5101/opensdn-charms-src:master-2_8_0_1-9 916cc59414af 6.05MB 0B nexus.gz1.opensdn.io:5101/opensdn-container-builder-src:master-2_8_0_1-9 36b40064eda7 2.49MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-api:master-2_8_0_1-9 8d94ccbcc4ba 714MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-base:master-2_8_0_1-9 5d7e7d3bbb23 676MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-2_8_0_1-9 eb46977a793e 1.03GB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq:master-2_8_0_1-9 23940c698b3d 691MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema:master-2_8_0_1-9 7e77384106ef 677MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor:master-2_8_0_1-9 0aea2f1434c1 698MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-control-base:master-2_8_0_1-9 0241737f910d 735MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-control-control:master-2_8_0_1-9 f3efa1d640de 762MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns:master-2_8_0_1-9 82ee68ad833d 762MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-control-named:master-2_8_0_1-9 3eaf939b29a2 743MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-webui-base:master-2_8_0_1-9 8d10b68ebc58 914MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job:master-2_8_0_1-9 61728719d771 914MB 0B nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web:master-2_8_0_1-9 17a71f50f490 914MB 0B nexus.gz1.opensdn.io:5101/opensdn-debug:master-2_8_0_1-9 3c0da3cb104e 428MB 0B nexus.gz1.opensdn.io:5101/opensdn-deployment-test:master-2_8_0_1-9 7627025a3807 441MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-cassandra:master-2_8_0_1-9 3be8c7c6f42a 331MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-haproxy:master-2_8_0_1-9 6954d93f4dcb 144MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-kafka:master-2_8_0_1-9 9c5c7ded5af4 392MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq:master-2_8_0_1-9 b374c682f13f 363MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-redis:master-2_8_0_1-9 eee52a0b7b68 171MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd:master-2_8_0_1-9 06853c62267a 440MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-stunnel:master-2_8_0_1-9 0a8fa7c37ba6 454MB 0B nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper:master-2_8_0_1-9 26517714c354 301MB 0B nexus.gz1.opensdn.io:5101/opensdn-general-base:master-2_8_0_1-9 a6b657d2ee87 428MB 0B nexus.gz1.opensdn.io:5101/opensdn-kolla-ansible-src:master-2_8_0_1-9 0ff79d7ab952 32.7MB 0B nexus.gz1.opensdn.io:5101/opensdn-kubernetes-cni-init:master-2_8_0_1-9 6d299f08e193 696MB 0B nexus.gz1.opensdn.io:5101/opensdn-kubernetes-kube-manager:master-2_8_0_1-9 fdaf80c3379a 681MB 0B nexus.gz1.opensdn.io:5101/opensdn-node-init:master-2_8_0_1-9 e4a7355de495 676MB 0B nexus.gz1.opensdn.io:5101/opensdn-nodemgr:master-2_8_0_1-9 7e0602072fac 811MB 0B nexus.gz1.opensdn.io:5101/opensdn-openstack-compute-init:master-2_8_0_1-9 719948734668 428MB 0B nexus.gz1.opensdn.io:5101/opensdn-openstack-heat-init:master-2_8_0_1-9 640d208ba6d9 444MB 0B nexus.gz1.opensdn.io:5101/opensdn-openstack-neutron-init:master-2_8_0_1-9 d308fcb4e763 444MB 0B nexus.gz1.opensdn.io:5101/opensdn-provisioner:master-2_8_0_1-9 ba5339e50538 676MB 0B nexus.gz1.opensdn.io:5101/opensdn-status:master-2_8_0_1-9 eca8a5a5f328 811MB 0B nexus.gz1.opensdn.io:5101/opensdn-test-test:master-2_8_0_1-9 b17dcd8a8a6d 1.84GB 0B nexus.gz1.opensdn.io:5101/opensdn-tools:master-2_8_0_1-9 fe8a14d7b3a3 1.28GB 0B nexus.gz1.opensdn.io:5101/opensdn-tor-agent:master-2_8_0_1-9 96b6a1cd4264 735MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent-dpdk:master-2_8_0_1-9 961b2af70dae 967MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent:master-2_8_0_1-9 4270bf63cef5 934MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-base:master-2_8_0_1-9 6d1333336f43 743MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init:master-2_8_0_1-9 abe134bd8850 614MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-init-dpdk:master-2_8_0_1-9 96be3c21d136 743MB 0B nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-init:master-2_8_0_1-9 e7f007476ea7 365MB 0B nexus.gz1.opensdn.io:5101/tf-dev-sandbox:frozen 37d1221c31c8 2.9GB 0B U opensdn-test-test:master-2_8_0_1-9 b17dcd8a8a6d 1.84GB 0B rockylinux:9 9cc24f05f309 176MB 0B tf-dev-sandbox:compile 71dfdf602547 22.2GB 0B tf-dev-sandbox:frozen 37d1221c31c8 2.9GB 0B U