
We have two sets of image build jobs. The first are targetted specifically at docker and docker hub. The second set use the generic container image roles and jobs from zuul/zuul-jobs. In this second set we have the choice of using either podman or docker. Choose podman because podman plays nicer with mirroring images hosted outside of docker hub. This is important for image builds like Gerrit where we build a base image and a gerrit version specific image and we need to lookup the base image from a mirror of a hosted versions outside of docker hub. The main drawback to keep in mind here is that podman handles multi arch container image builds differently to docker. This means if/when we get to porting the python base image builds that are multiarch to quay and pordman we may need to add additional support for multiarch. Though currently only nodepool-builder relies on this and it is being replaced by zuul-launcher so we may just sidestep the issue entirely. We update the hound Dockerfile to force a rebuild of this image. The reason for that is that image is the only one currently affected by the change to build images with podman. This ensures we don't discover problems with podman building hound images later when we have a different reason to rebuild that image. Finally while we are at it drop container_command from the mirror container images job because that job uses skopeo now and doesn't rely on podman or docker. This should reduce overall confusion when trying to understand the behavior of our jobs. Change-Id: Ie7a309452e33e0996702c849167b7881d79db5fb
55 lines
1.8 KiB
Docker
55 lines
1.8 KiB
Docker
# Copyright (c) 2020 Red Hat, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# Trigger rebuild - Wed Apr 23 05:03:23 PM UTC 2025
|
|
|
|
FROM docker.io/library/golang:1.19-bookworm AS builder
|
|
|
|
WORKDIR /tmp
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install -y curl git make rsync \
|
|
&& curl -sS https://deb.nodesource.com/gpgkey/nodesource.gpg.key | apt-key add - \
|
|
&& echo "deb https://deb.nodesource.com/node_16.x bookworm main" | tee /etc/apt/sources.list.d/nodesource.list \
|
|
&& apt-get update \
|
|
&& apt-get -q --option "Dpkg::Options::=--force-confold" --assume-yes install nodejs npm
|
|
|
|
RUN git clone https://github.com/hound-search/hound \
|
|
&& cd hound \
|
|
&& make
|
|
|
|
FROM docker.io/opendevorg/python-base:3.12-bookworm
|
|
|
|
COPY --from=builder /tmp/hound/.build/bin/hound /usr/local/bin
|
|
COPY --from=builder /tmp/hound/.build/bin/houndd /usr/local/bin
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install -y curl git
|
|
|
|
RUN pip install git+https://opendev.org/opendev/jeepyb#egg=jeepyb \
|
|
supervisor
|
|
|
|
RUN apt-get clean \
|
|
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
|
|
|
ADD supervisord.conf /etc/supervisor/conf.d/supervisord.conf
|
|
ADD start-container.sh /usr/bin/start-container
|
|
ADD update-hound-config.sh /usr/local/bin/update-hound-config
|
|
ADD resync-hound.sh /usr/local/bin/resync-hound
|
|
ADD sample-projects.yaml /var/run/sample-projects.yaml
|
|
|
|
ENTRYPOINT ["start-container"]
|
|
|