# Use imutable image tags rather than mutable tags (like ubuntu:22.04) FROM ubuntu:jammy-20230308 # Some tools like yamllint need this # Pip needs this as well at the moment to install ansible # (and potentially other packages) # See: https://github.com/pypa/pip/issues/10219 ENV LANG=C.UTF-8 \ DEBIAN_FRONTEND=noninteractive \ PYTHONDONTWRITEBYTECODE=1 WORKDIR /kubespray COPY *.yml ./ COPY *.cfg ./ COPY roles ./roles COPY contrib ./contrib COPY inventory ./inventory COPY library ./library COPY extra_playbooks ./extra_playbooks COPY playbooks ./playbooks COPY plugins ./plugins RUN apt update -q \ && apt install -yq --no-install-recommends \ curl \ python3 \ python3-pip \ sshpass \ vim \ rsync \ openssh-client \ && pip install --no-compile --no-cache-dir \ ansible==7.6.0 \ ansible-core==2.14.6 \ cryptography==41.0.1 \ jinja2==3.1.2 \ netaddr==0.8.0 \ jmespath==1.0.1 \ MarkupSafe==2.1.3 \ ruamel.yaml==0.17.21 \ && KUBE_VERSION=$(sed -n 's/^kube_version: //p' roles/kubespray-defaults/defaults/main.yaml) \ && curl -L https://dl.k8s.io/release/$KUBE_VERSION/bin/linux/$(dpkg --print-architecture)/kubectl -o /usr/local/bin/kubectl \ && echo $(curl -L https://dl.k8s.io/release/$KUBE_VERSION/bin/linux/$(dpkg --print-architecture)/kubectl.sha256) /usr/local/bin/kubectl | sha256sum --check \ && chmod a+x /usr/local/bin/kubectl \ && rm -rf /var/lib/apt/lists/* /var/log/* \ && find /usr -type d -name '*__pycache__' -prune -exec rm -rf {} \;