2026-02-03 12:07:42,293: INFO: Building opensdn-controller-config-devicemgr 2026-02-03 12:07:42,342: 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_5_1_4-6 --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 #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 docker.io/library/tf-dev-sandbox:compile #2 DONE 0.0s #3 [internal] load metadata for nexus.gz1.opensdn.io:5101/opensdn-controller-config-base:master-2_5_1_4-6 #3 DONE 0.0s #4 [internal] load .dockerignore #4 transferring context: #4 transferring context: 2B done #4 DONE 1.9s #5 [build 1/1] FROM docker.io/library/tf-dev-sandbox:compile #5 CACHED #6 [stage-1 1/4] FROM nexus.gz1.opensdn.io:5101/opensdn-controller-config-base:master-2_5_1_4-6 #6 DONE 0.0s #7 [1/3] FROM nexus.gz1.opensdn.io:5101/opensdn-analytics-base:master-2_5_1_4-6 #7 CACHED #8 [internal] load build context #8 ... #7 [1/3] FROM nexus.gz1.opensdn.io:5101/opensdn-analytics-base:master-2_5_1_4-6 #7 CACHED #8 [internal] load build context #8 transferring context: 1.97kB done #8 DONE 2.2s #9 [stage-1 2/4] COPY --from=build /pip/fabric_ansible_playbooks-0.1.dev0.tar.gz /opt/ #9 DONE 1.9s #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.177 added from: http://tf-mirrors.gz1.opensdn.io/re 37 MB/s | 2.1 MB 00:00 #10 1.807 added from: http://tf-mirrors.gz1.opensdn.io/re 19 MB/s | 730 kB 00:00 #10 2.039 added from: http://tf-mirrors.gz1.opensdn.io/re 5.3 MB/s | 264 kB 00:00 #10 2.250 added from: http://tf-mirrors.gz1.opensdn.io/re 52 MB/s | 7.0 MB 00:00 #10 4.441 added from: http://tf-mirrors.gz1.opensdn.io/re 30 MB/s | 4.0 MB 00:00 #10 5.921 added from: http://tf-mirrors.gz1.opensdn.io/re 17 MB/s | 939 kB 00:00 #10 6.565 added from: http://tf-mirrors.gz1.opensdn.io/re 29 MB/s | 2.3 MB 00:00 #10 7.172 added from: http://tf-mirrors.gz1.opensdn.io/re 8.1 MB/s | 392 kB 00:00 #10 7.545 added from: http://tf-mirrors.gz1.opensdn.io/re 8.9 MB/s | 451 kB 00:00 #10 7.804 added from: http://tf-mirrors.gz1.opensdn.io/re 385 kB/s | 16 kB 00:00 #10 8.234 added from: http://tf-mirrors.gz1.opensdn.io/re 8.5 kB/s | 257 B 00:00 #10 8.719 added from: http://tf-mirrors.gz1.opensdn.io/re 400 kB/s | 13 kB 00:00 #10 9.026 added from: http://tf-mirrors.gz1.opensdn.io/re 1.1 MB/s | 64 kB 00:00 #10 9.953 added from: http://tf-mirrors.gz1.opensdn.io/re 56 MB/s | 30 MB 00:00 #10 23.81 Third parties for OpenSDN 32 MB/s | 5.1 MB 00:00 #10 31.84 Dependencies resolved. #10 31.84 ================================================================================ #10 31.84 Package Arch Version Repository Size #10 31.84 ================================================================================ #10 31.84 Installing: #10 31.84 iputils x86_64 20210202-10.el9_5 tf-mirrors.ci_repos_yum9-baseos 168 k #10 31.84 libffi-devel x86_64 3.4.2-8.el9 tf-mirrors.ci_repos_yum9-appstream 28 k #10 31.84 #10 31.84 Transaction Summary #10 31.84 ================================================================================ #10 31.84 Install 2 Packages #10 31.84 #10 31.84 Total download size: 196 k #10 31.84 Installed size: 519 k #10 31.84 Downloading Packages: #10 31.88 (1/2): libffi-devel-3.4.2-8.el9.x86_64.rpm 950 kB/s | 28 kB 00:00 #10 31.88 (2/2): iputils-20210202-10.el9_5.x86_64.rpm 3.6 MB/s | 168 kB 00:00 #10 31.88 -------------------------------------------------------------------------------- #10 31.88 Total 4.1 MB/s | 196 kB 00:00 #10 31.88 Running transaction check #10 31.94 Transaction check succeeded. #10 31.94 Running transaction test #10 31.98 Transaction test succeeded. #10 31.98 Running transaction #10 32.03 Preparing : 1/1 #10 32.17 Installing : libffi-devel-3.4.2-8.el9.x86_64 1/2 #10 32.18 Installing : iputils-20210202-10.el9_5.x86_64 2/2 #10 32.19 Running scriptlet: iputils-20210202-10.el9_5.x86_64 2/2 #10 32.93 Verifying : iputils-20210202-10.el9_5.x86_64 1/2 #10 32.93 Verifying : libffi-devel-3.4.2-8.el9.x86_64 2/2 #10 32.97 #10 32.97 Installed: #10 32.97 iputils-20210202-10.el9_5.x86_64 libffi-devel-3.4.2-8.el9.x86_64 #10 32.97 #10 32.97 Complete! #10 33.54 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/ #10 35.06 Collecting cryptography<3.5 #10 35.09 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 35.46 Collecting importlib-resources<5.1 #10 35.46 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/223/8159eb743bd85/importlib_resources-5.0.7-py3-none-any.whl (24 kB) #10 36.72 Collecting cffi>=1.12 #10 36.73 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 36.80 Collecting pycparser #10 36.82 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e5c/6e8d3fbad5347/pycparser-2.23-py3-none-any.whl (118 kB) #10 37.22 Installing collected packages: pycparser, cffi, importlib-resources, cryptography #10 38.36 Successfully installed cffi-2.0.0 cryptography-3.4.8 importlib-resources-5.0.7 pycparser-2.23 #10 38.36 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 39.85 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/ #10 40.20 Collecting ansible #10 40.41 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/3a5/ca5152e4547d5/ansible-8.7.0.tar.gz (49.3 MB) #10 85.16 Installing build dependencies: started #10 91.33 Installing build dependencies: finished with status 'done' #10 91.33 Getting requirements to build wheel: started #10 152.8 Getting requirements to build wheel: still running... #10 173.1 Getting requirements to build wheel: finished with status 'done' #10 173.1 Preparing metadata (pyproject.toml): started #10 229.6 Preparing metadata (pyproject.toml): finished with status 'done' #10 229.8 Collecting ansible-core #10 229.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f54/2e702ee31fb04/ansible_core-2.15.13.tar.gz (3.1 MB) #10 231.9 Installing build dependencies: started #10 237.1 Installing build dependencies: finished with status 'done' #10 237.1 Getting requirements to build wheel: started #10 237.7 Getting requirements to build wheel: finished with status 'done' #10 237.7 Preparing metadata (pyproject.toml): started #10 238.2 Preparing metadata (pyproject.toml): finished with status 'done' #10 238.2 Requirement already satisfied: packaging in /usr/local/lib/python3.9/site-packages (from ansible-core) (26.0) #10 238.3 Collecting jinja2>=3.0.0 #10 238.3 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/013/7fb05990d35f1/jinja2-3.1.6.tar.gz (245 kB) #10 238.5 Installing build dependencies: started #10 240.5 Installing build dependencies: finished with status 'done' #10 240.5 Getting requirements to build wheel: started #10 240.5 Getting requirements to build wheel: finished with status 'done' #10 240.5 Preparing metadata (pyproject.toml): started #10 240.6 Preparing metadata (pyproject.toml): finished with status 'done' #10 240.8 Collecting PyYAML>=5.1 #10 240.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/d76/623373421df22/pyyaml-6.0.3.tar.gz (130 kB) #10 241.1 Installing build dependencies: started #10 311.8 Installing build dependencies: still running... #10 372.1 Installing build dependencies: still running... #10 386.5 Installing build dependencies: finished with status 'done' #10 386.5 Getting requirements to build wheel: started #10 387.8 Getting requirements to build wheel: finished with status 'done' #10 387.8 Preparing metadata (pyproject.toml): started #10 388.2 Preparing metadata (pyproject.toml): finished with status 'done' #10 388.2 Requirement already satisfied: cryptography in /usr/local/lib64/python3.9/site-packages (from ansible-core) (3.4.8) #10 388.2 Collecting resolvelib<1.1.0,>=0.5.3 #10 388.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/04c/e76cbd63fded2/resolvelib-1.0.1.tar.gz (21 kB) #10 388.4 Installing build dependencies: started #10 398.3 Installing build dependencies: finished with status 'done' #10 398.3 Getting requirements to build wheel: started #10 398.5 Getting requirements to build wheel: finished with status 'done' #10 398.5 Preparing metadata (pyproject.toml): started #10 398.7 Preparing metadata (pyproject.toml): finished with status 'done' #10 398.7 Requirement already satisfied: importlib-resources<5.1,>=5.0 in /usr/local/lib/python3.9/site-packages (from ansible-core) (5.0.7) #10 398.9 Collecting MarkupSafe>=2.0 #10 398.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/722/695808f4b6457/markupsafe-3.0.3.tar.gz (80 kB) #10 399.1 Installing build dependencies: started #10 403.9 Installing build dependencies: finished with status 'done' #10 403.9 Getting requirements to build wheel: started #10 404.1 Getting requirements to build wheel: finished with status 'done' #10 404.1 Preparing metadata (pyproject.toml): started #10 404.3 Preparing metadata (pyproject.toml): finished with status 'done' #10 404.3 Requirement already satisfied: cffi>=1.12 in /usr/local/lib64/python3.9/site-packages (from cryptography->ansible-core) (2.0.0) #10 404.3 Requirement already satisfied: pycparser in /usr/local/lib/python3.9/site-packages (from cffi>=1.12->cryptography->ansible-core) (2.23) #10 404.3 Building wheels for collected packages: ansible, ansible-core, jinja2, PyYAML, resolvelib, MarkupSafe #10 404.3 Building wheel for ansible (pyproject.toml): started #10 476.0 Building wheel for ansible (pyproject.toml): still running... #10 485.5 Building wheel for ansible (pyproject.toml): finished with status 'done' #10 485.6 Created wheel for ansible: filename=ansible-8.7.0-py3-none-any.whl size=48371393 sha256=8dd0bfe471552e9b21915c322144df49567041e34870e204a04ee96fcd911e6a #10 485.6 Stored in directory: /root/.cache/pip/wheels/45/76/58/9502290a467417ab1444d84c63019adb1daaed6d18d308b817 #10 485.8 Building wheel for ansible-core (pyproject.toml): started #10 487.3 Building wheel for ansible-core (pyproject.toml): finished with status 'done' #10 487.3 Created wheel for ansible-core: filename=ansible_core-2.15.13-py3-none-any.whl size=2251441 sha256=9ee3c02d948054615a7f0c3e65d1e9a668c11122c0114df600eb1a5881855bd4 #10 487.3 Stored in directory: /root/.cache/pip/wheels/de/f1/0f/5bdba5e828d49ff45930d6032cef3961e2e673467b0d7bbb1e #10 487.4 Building wheel for jinja2 (pyproject.toml): started #10 487.5 Building wheel for jinja2 (pyproject.toml): finished with status 'done' #10 487.5 Created wheel for jinja2: filename=jinja2-3.1.6-py3-none-any.whl size=134897 sha256=005a2fc379b662ac007c271a8122f7a7db49bb67fbedfc85db50fccde34d839f #10 487.5 Stored in directory: /root/.cache/pip/wheels/7b/c3/fc/fe2ea80be37d89f3c720e53076aac0407f529f0c29356a6215 #10 487.5 Building wheel for PyYAML (pyproject.toml): started #10 488.1 Building wheel for PyYAML (pyproject.toml): finished with status 'done' #10 488.1 Created wheel for PyYAML: filename=pyyaml-6.0.3-cp39-cp39-linux_x86_64.whl size=45462 sha256=2c955db6e4396920ff2d2c2c14352aba3bf61a05514894022a10723dc654163e #10 488.1 Stored in directory: /root/.cache/pip/wheels/79/fb/92/ef421e052606484d88d2a8592c227e766d44081f6c09bdecbb #10 488.1 Building wheel for resolvelib (pyproject.toml): started #10 488.3 Building wheel for resolvelib (pyproject.toml): finished with status 'done' #10 488.3 Created wheel for resolvelib: filename=resolvelib-1.0.1-py2.py3-none-any.whl size=17235 sha256=a2a01e539490c41a4c9dd707ef7e40f2c9ae57a3206dfec0ba5eb7ec6f798b82 #10 488.3 Stored in directory: /root/.cache/pip/wheels/9b/e8/75/66577720290e60215abc77f8972bc2f567d4058bd85a58f881 #10 488.3 Building wheel for MarkupSafe (pyproject.toml): started #10 488.9 Building wheel for MarkupSafe (pyproject.toml): finished with status 'done' #10 488.9 Created wheel for MarkupSafe: filename=markupsafe-3.0.3-cp39-cp39-linux_x86_64.whl size=21268 sha256=a95e2f28d4ef9ef2be19e7a82b2910acacba177006d6bee09d72b21d8a495beb #10 488.9 Stored in directory: /root/.cache/pip/wheels/da/bd/2a/6dd1ba50acf54588ceab2b7322c7a9bc5f41b28772c485e8fc #10 488.9 Successfully built ansible ansible-core jinja2 PyYAML resolvelib MarkupSafe #10 489.2 Installing collected packages: MarkupSafe, resolvelib, PyYAML, jinja2, ansible-core, ansible #10 494.2 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 494.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 497.7 75 files removed #10 497.7 2026-02-03 12:16:07 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 499.0 Starting galaxy role install process #10 499.0 - extracting Juniper.junos to /root/.ansible/roles/Juniper.junos #10 499.0 - Juniper.junos was installed successfully #10 499.4 Looking in indexes: http://tf-mirrors.gz1.opensdn.io/root/pypi/+simple/, http://localhost:6667/pip/simple #10 499.4 Collecting device_manager==0.1.dev0 #10 499.4 Downloading http://localhost:6667/pip/simple/device-manager/device_manager-0.1.dev0-py3-none-any.whl (321 kB) #10 499.5 Collecting fabric_ansible==0.1.dev0 #10 499.5 Downloading http://localhost:6667/pip/simple/fabric-ansible/fabric_ansible-0.1.dev0-py3-none-any.whl (41 kB) #10 499.5 Requirement already satisfied: gevent in /usr/local/lib64/python3.9/site-packages (from device_manager==0.1.dev0) (25.9.1) #10 499.5 Collecting ncclient #10 499.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/318/e8e3e72b1d2a7/ncclient-0.7.0.tar.gz (116 kB) #10 499.8 Preparing metadata (setup.py): started #10 500.3 Preparing metadata (setup.py): finished with status 'done' #10 500.4 Collecting jsonschema #10 500.5 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/3fb/a0169e345c717/jsonschema-4.25.1-py3-none-any.whl (90 kB) #10 500.6 Requirement already satisfied: timeout-decorator in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.5.0) #10 500.9 Collecting cityhash #10 500.9 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 500.9 Requirement already satisfied: netaddr<1 in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.10.1) #10 500.9 Collecting junos-eznc #10 501.0 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 501.4 Collecting psutil #10 501.4 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 501.4 Requirement already satisfied: bottle<0.13 in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (0.12.25) #10 502.4 Collecting lxml #10 502.4 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/6cd/aefac66e8b8f3/lxml-6.0.2-cp39-cp39-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (5.3 MB) #10 502.5 Collecting attrdict #10 502.5 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 502.6 Collecting netifaces #10 502.6 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 502.7 Collecting inflection #10 502.7 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 502.7 Collecting docker #10 502.7 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c96/b93b7f0a746f9/docker-7.1.0-py3-none-any.whl (147 kB) #10 502.8 Requirement already satisfied: kombu in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (5.6.2) #10 502.8 Requirement already satisfied: bitarray in /usr/local/lib64/python3.9/site-packages (from device_manager==0.1.dev0) (3.8.0) #10 502.8 Requirement already satisfied: stevedore in /usr/local/lib/python3.9/site-packages (from device_manager==0.1.dev0) (5.5.0) #10 502.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 502.8 Collecting pycrypto #10 502.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f2c/e1e989b272cfc/pycrypto-2.6.1.tar.gz (446 kB) #10 502.9 Preparing metadata (setup.py): started #10 503.1 Preparing metadata (setup.py): finished with status 'done' #10 503.1 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 503.1 Requirement already satisfied: jinja2 in /usr/local/lib/python3.9/site-packages (from fabric_ansible==0.1.dev0) (3.1.6) #10 503.2 Collecting pysnmp #10 503.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e3f/ed6eab479a4ec/pysnmp-7.1.21-py3-none-any.whl (343 kB) #10 503.3 Collecting subprocess32 #10 503.3 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/eb2/937c80497978d/subprocess32-3.5.4.tar.gz (97 kB) #10 503.3 Preparing metadata (setup.py): started #10 503.5 Preparing metadata (setup.py): finished with status 'done' #10 503.6 Collecting pyroute2 #10 503.6 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e7d/485ce8274cbf4/pyroute2-0.9.5-py3-none-any.whl (480 kB) #10 503.6 Collecting jsnapy #10 503.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 503.6 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 503.6 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 503.6 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.10.0) #10 503.6 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 503.6 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 503.6 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.4) #10 503.6 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 503.6 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 503.6 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 503.6 Requirement already satisfied: six in /usr/lib/python3.9/site-packages (from attrdict->device_manager==0.1.dev0) (1.15.0) #10 503.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 503.7 Requirement already satisfied: zope.event in /usr/local/lib/python3.9/site-packages (from gevent->device_manager==0.1.dev0) (6.0) #10 503.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 503.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 503.7 Collecting configparser #10 503.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/fee/5e1f3db4156dc/configparser-7.2.0-py3-none-any.whl (17 kB) #10 503.8 Collecting colorama #10 503.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 503.8 Collecting icdiff==1.9.1 #10 503.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/669/72dd03318da55/icdiff-1.9.1.tar.gz (9.1 kB) #10 503.9 Preparing metadata (setup.py): started #10 504.1 Preparing metadata (setup.py): finished with status 'done' #10 504.1 Collecting future #10 504.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/929/292d34f5872e7/future-1.0.0-py3-none-any.whl (491 kB) #10 504.2 Collecting pyparsing #10 504.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/850/ba148bd908d7e/pyparsing-3.3.2-py3-none-any.whl (122 kB) #10 505.6 Collecting rpds-py>=0.7.1 #10 505.7 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 505.8 Collecting referencing>=0.28.4 #10 505.8 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/e86/99adbbf8b5c7d/referencing-0.36.2-py3-none-any.whl (26 kB) #10 505.9 Collecting jsonschema-specifications>=2023.03.6 #10 505.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/988/02fee3a11ee76/jsonschema_specifications-2025.9.1-py3-none-any.whl (18 kB) #10 505.9 Collecting attrs>=22.2.0 #10 505.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/adc/f7e2a1fb3b36a/attrs-25.4.0-py3-none-any.whl (67 kB) #10 506.0 Collecting yamlloader #10 506.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/d9e/a9948759732ea/yamlloader-1.6.0-py3-none-any.whl (7.8 kB) #10 506.0 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 506.0 Collecting transitions #10 506.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/024/63248f2b668d8/transitions-0.9.3-py2.py3-none-any.whl (112 kB) #10 506.1 Collecting paramiko>=3.5.0 #10 506.1 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/0e2/0e00ac666503b/paramiko-4.0.0-py3-none-any.whl (223 kB) #10 506.2 Collecting pyserial #10 506.2 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/c44/51db6ba391ca6/pyserial-3.5-py2.py3-none-any.whl (90 kB) #10 506.2 Collecting scp>=0.7.0 #10 506.2 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 506.3 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 506.3 Requirement already satisfied: packaging in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (26.0) #10 506.3 Requirement already satisfied: tzdata>=2025.2 in /usr/local/lib/python3.9/site-packages (from kombu->device_manager==0.1.dev0) (2025.3) #10 506.3 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 506.4 Collecting pyasn1!=0.5.0,>=0.4.8 #10 506.4 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/1eb/26d860996a18e/pyasn1-0.6.2-py3-none-any.whl (83 kB) #10 506.7 Collecting bcrypt>=3.2 #10 506.7 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 506.8 Collecting pynacl>=1.5 #10 506.8 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 506.8 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 506.9 Collecting invoke>=2.0 #10 506.9 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/241/3bc441b376e5c/invoke-2.2.1-py3-none-any.whl (160 kB) #10 507.0 Collecting typing-extensions>=4.4.0 #10 507.0 Downloading http://tf-mirrors.gz1.opensdn.io/root/pypi/%2Bf/f0f/a19c6845758ab/typing_extensions-4.15.0-py3-none-any.whl (44 kB) #10 507.0 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 507.0 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.4) #10 507.0 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.1.4) #10 507.0 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 507.1 Requirement already satisfied: setuptools>=75.8.2 in /usr/local/lib/python3.9/site-packages (from zope.event->gevent->device_manager==0.1.dev0) (80.10.2) #10 507.1 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 507.2 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 507.2 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 507.2 Using legacy 'setup.py install' for icdiff, since package 'wheel' is not installed. #10 507.2 Using legacy 'setup.py install' for ncclient, since package 'wheel' is not installed. #10 507.2 Using legacy 'setup.py install' for pycrypto, since package 'wheel' is not installed. #10 507.2 Using legacy 'setup.py install' for subprocess32, since package 'wheel' is not installed. #10 507.5 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 507.8 Running setup.py install for ncclient: started #10 508.1 Running setup.py install for ncclient: finished with status 'done' #10 508.2 Running setup.py install for icdiff: started #10 508.4 Running setup.py install for icdiff: finished with status 'done' #10 508.5 Running setup.py install for subprocess32: started #10 508.8 Running setup.py install for subprocess32: finished with status 'done' #10 508.9 Running setup.py install for pycrypto: started #10 517.4 Running setup.py install for pycrypto: finished with status 'done' #10 517.6 Successfully installed attrdict-2.0.1 attrs-25.4.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-2.2.1 jsnapy-1.3.8 jsonschema-4.25.1 jsonschema-specifications-2025.9.1 junos-eznc-2.7.6 lxml-6.0.2 ncclient-0.7.0 netifaces-0.11.0 paramiko-4.0.0 psutil-7.2.2 pyasn1-0.6.2 pycrypto-2.6.1 pynacl-1.6.2 pyparsing-3.3.2 pyroute2-0.9.5 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 517.6 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 517.9 DBG: /opt/ last tar.gz = fabric_ansible_playbooks-0.1.dev0.tar.gz #10 DONE 521.7s #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:9462f339c0bae58adadd353e1e3e8a4f2b1328f6e0ed584e77810b97bac9d62b done #12 naming to nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr:master-2_5_1_4-6 done #12 DONE 4.2s 2026-02-03 12:16:35,404: INFO: Docker build duration: 533 seconds The push refers to repository [nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr] fc28a55e60e9: Preparing 76ebc4a376ee: Preparing 3eedbce05339: Preparing e95c3b7e7aae: Preparing bf55faf1c584: Preparing cc20b423d848: Preparing 59686dcdc48c: Preparing 3a331f8a08d9: Preparing 67768c2c102f: Preparing f30a06cc9e73: Preparing 1b09b66a2873: Preparing 1ce4dd82e18f: Preparing 48b962b86202: Preparing b69da25744c4: Preparing 0d4362f359df: Preparing 1b6ece72d626: Preparing 44343de3ea1d: Preparing cc20b423d848: Waiting 59686dcdc48c: Waiting 3a331f8a08d9: Waiting 67768c2c102f: Waiting f30a06cc9e73: Waiting 1b09b66a2873: Waiting 1ce4dd82e18f: Waiting 48b962b86202: Waiting b69da25744c4: Waiting 0d4362f359df: Waiting 1b6ece72d626: Waiting 44343de3ea1d: Waiting bf55faf1c584: Layer already exists e95c3b7e7aae: Layer already exists cc20b423d848: Layer already exists 59686dcdc48c: Layer already exists 3a331f8a08d9: Layer already exists 67768c2c102f: Layer already exists f30a06cc9e73: Layer already exists 1b09b66a2873: Layer already exists fc28a55e60e9: Pushed 3eedbce05339: Pushed 1ce4dd82e18f: Layer already exists 48b962b86202: Layer already exists b69da25744c4: Layer already exists 1b6ece72d626: Layer already exists 0d4362f359df: Layer already exists 44343de3ea1d: Layer already exists 76ebc4a376ee: Pushed master-2_5_1_4-6: digest: sha256:e1bcbe70dc84472f161fc9438f804a39a35bacc5edd91e0e50fd9255e64e8c93 size: 3878 2026-02-03 12:16:48,732: INFO: Building opensdn-controller-config-devicemgr finished successfully, duration: 546 seconds REPOSITORY TAG IMAGE ID CREATED SIZE nexus.gz1.opensdn.io:5101/opensdn-controller-config-devicemgr master-2_5_1_4-6 9462f339c0ba 17 seconds ago 971MB nexus.gz1.opensdn.io:5101/opensdn-tools master-2_5_1_4-6 4d4da2bcdb34 6 minutes ago 1.48GB nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-build-init master-2_5_1_4-6 e9702702e599 6 minutes ago 627MB nexus.gz1.opensdn.io:5101/opensdn-tor-agent master-2_5_1_4-6 0fbe83c0587f 6 minutes ago 674MB nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-init master-2_5_1_4-6 f012b055487f 6 minutes ago 368MB nexus.gz1.opensdn.io:5101/opensdn-analytics-collector master-2_5_1_4-6 303d1fe07e0e 6 minutes ago 959MB nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent master-2_5_1_4-6 6cfaf0266186 6 minutes ago 1.8GB nexus.gz1.opensdn.io:5101/opensdn-debug master-2_5_1_4-6 874a964df397 7 minutes ago 348MB nexus.gz1.opensdn.io:5101/opensdn-nodemgr master-2_5_1_4-6 3fdd8bf8df7f 7 minutes ago 774MB nexus.gz1.opensdn.io:5101/opensdn-status master-2_5_1_4-6 379e0b644fe3 7 minutes ago 774MB nexus.gz1.opensdn.io:5101/opensdn-analytics-query-engine master-2_5_1_4-6 38e5f37bbeaa 7 minutes ago 840MB nexus.gz1.opensdn.io:5101/opensdn-controller-config-api master-2_5_1_4-6 0330b51618a0 7 minutes ago 650MB nexus.gz1.opensdn.io:5101/opensdn-controller-config-svcmonitor master-2_5_1_4-6 a30331e7d440 7 minutes ago 634MB nexus.gz1.opensdn.io:5101/opensdn-controller-config-dnsmasq master-2_5_1_4-6 9fa8cd389e8a 7 minutes ago 630MB nexus.gz1.opensdn.io:5101/opensdn-vrouter-agent-dpdk master-2_5_1_4-6 72fb5c50cd3f 8 minutes ago 890MB nexus.gz1.opensdn.io:5101/opensdn-openstack-compute-init master-2_5_1_4-6 88e0a53e479f 8 minutes ago 348MB nexus.gz1.opensdn.io:5101/opensdn-kubernetes-cni-init master-2_5_1_4-6 9b536cfe9805 8 minutes ago 632MB nexus.gz1.opensdn.io:5101/opensdn-controller-control-dns master-2_5_1_4-6 bc994126126f 8 minutes ago 996MB nexus.gz1.opensdn.io:5101/opensdn-controller-control-control master-2_5_1_4-6 b18487f156f1 8 minutes ago 1.23GB nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-topology master-2_5_1_4-6 d8196f06beda 8 minutes ago 830MB nexus.gz1.opensdn.io:5101/opensdn-controller-webui-job master-2_5_1_4-6 353c80d734bc 8 minutes ago 858MB nexus.gz1.opensdn.io:5101/opensdn-controller-webui-web master-2_5_1_4-6 970c1dd59220 8 minutes ago 858MB nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-collector master-2_5_1_4-6 9cfe1aa7c2ba 8 minutes ago 830MB nexus.gz1.opensdn.io:5101/opensdn-controller-control-named master-2_5_1_4-6 59548b326af1 8 minutes ago 693MB nexus.gz1.opensdn.io:5101/opensdn-analytics-api master-2_5_1_4-6 ff891ff6b9e1 8 minutes ago 637MB nexus.gz1.opensdn.io:5101/opensdn-vrouter-kernel-init-dpdk master-2_5_1_4-6 ef703cfb6a33 8 minutes ago 682MB nexus.gz1.opensdn.io:5101/opensdn-controller-config-schema master-2_5_1_4-6 2e0dbd257d6a 8 minutes ago 613MB nexus.gz1.opensdn.io:5101/opensdn-openstack-heat-init master-2_5_1_4-6 a7d835d83b8a 8 minutes ago 363MB nexus.gz1.opensdn.io:5101/opensdn-openstack-neutron-init master-2_5_1_4-6 edbe1b622059 8 minutes ago 363MB nexus.gz1.opensdn.io:5101/opensdn-kubernetes-kube-manager master-2_5_1_4-6 5ca60c1589e7 8 minutes ago 616MB nexus.gz1.opensdn.io:5101/opensdn-node-init master-2_5_1_4-6 0beaf8ffe989 8 minutes ago 612MB nexus.gz1.opensdn.io:5101/opensdn-provisioner master-2_5_1_4-6 9caa8fe56517 8 minutes ago 612MB nexus.gz1.opensdn.io:5101/opensdn-analytics-alarm-gen master-2_5_1_4-6 f9562919ecc4 9 minutes ago 629MB nexus.gz1.opensdn.io:5101/opensdn-external-redis master-2_5_1_4-6 ee2ba7e1149a 9 minutes ago 171MB nexus.gz1.opensdn.io:5101/opensdn-external-kafka master-2_5_1_4-6 0ab38698fbea 10 minutes ago 392MB nexus.gz1.opensdn.io:5101/opensdn-external-zookeeper master-2_5_1_4-6 976ca47d4c33 10 minutes ago 301MB nexus.gz1.opensdn.io:5101/opensdn-deployment-test master-2_5_1_4-6 e4098be52287 10 minutes ago 430MB opensdn-test-test master-2_5_1_4-6 0aeb57dc9c10 12 minutes ago 1.74GB nexus.gz1.opensdn.io:5101/opensdn-test-test master-2_5_1_4-6 0aeb57dc9c10 12 minutes ago 1.74GB nexus.gz1.opensdn.io:5101/opensdn-external-cassandra master-2_5_1_4-6 b8dac5cc9fc7 13 minutes ago 331MB nexus.gz1.opensdn.io:5101/opensdn-controller-webui-base master-2_5_1_4-6 95b3b2041b42 13 minutes ago 858MB nexus.gz1.opensdn.io:5101/opensdn-external-rabbitmq master-2_5_1_4-6 34a8b0f71e6f 13 minutes ago 363MB nexus.gz1.opensdn.io:5101/opensdn-external-stunnel master-2_5_1_4-6 1ef07b92f9cc 13 minutes ago 398MB nexus.gz1.opensdn.io:5101/opensdn-external-haproxy master-2_5_1_4-6 6a853dd300d9 13 minutes ago 144MB nexus.gz1.opensdn.io:5101/opensdn-analytics-snmp-base master-2_5_1_4-6 918457cff4b9 13 minutes ago 830MB nexus.gz1.opensdn.io:5101/opensdn-vrouter-base master-2_5_1_4-6 735b015c6506 13 minutes ago 682MB nexus.gz1.opensdn.io:5101/opensdn-controller-control-base master-2_5_1_4-6 cd84c7a0f049 14 minutes ago 673MB nexus.gz1.opensdn.io:5101/opensdn-external-rsyslogd master-2_5_1_4-6 8ba771ae5f56 14 minutes ago 359MB nexus.gz1.opensdn.io:5101/opensdn-analytics-base master-2_5_1_4-6 6499b72d4204 14 minutes ago 612MB nexus.gz1.opensdn.io:5101/opensdn-base master-2_5_1_4-6 65c593117db7 14 minutes ago 612MB nexus.gz1.opensdn.io:5101/opensdn-controller-config-base master-2_5_1_4-6 fb0f765d7b26 14 minutes ago 612MB nexus.gz1.opensdn.io:5101/opensdn-general-base master-2_5_1_4-6 290736aeb0cd 15 minutes ago 348MB nexus.gz1.opensdn.io:5101/opensdn-container-builder-src master-2_5_1_4-6 649712af202e 16 minutes ago 2.47MB tf-dev-sandbox compile aeb8b56b4314 16 minutes ago 24.2GB nexus.gz1.opensdn.io:5101/opensdn-charms-src master-2_5_1_4-6 769bb5d4c1eb 17 minutes ago 6.05MB nexus.gz1.opensdn.io:5101/opensdn-container-builder-src 766e0e0ee57e 17 minutes ago 2.45MB nexus.gz1.opensdn.io:5101/opensdn-kolla-ansible-src master-2_5_1_4-6 55dd126dab34 17 minutes ago 32.7MB nexus.gz1.opensdn.io:5101/opensdn-ansible-deployer-src master-2_5_1_4-6 2b83da2c7fd7 17 minutes ago 1.4MB nexus.gz1.opensdn.io:5101/opensdn-build-manifest-src master-2_5_1_4-6 a9b229b9dc42 17 minutes ago 4.17kB nexus.gz1.opensdn.io:5101/tf-dev-sandbox frozen 5b78a20eac5a 5 hours ago 23.5GB