Skip to content

Commit

Permalink
Cleanup base sources
Browse files Browse the repository at this point in the history
Signed-off-by: Christian Berendt <[email protected]>
  • Loading branch information
berendt committed Dec 20, 2023
1 parent 9ab0ae4 commit 7677d7f
Show file tree
Hide file tree
Showing 3 changed files with 121 additions and 6 deletions.
16 changes: 16 additions & 0 deletions files/cleanup-base-sources.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#!/usr/bin/env bash

for e in $(find /*-base-source -name '*config-generator*'); do
if [[ -d $e ]]; then
mkdir -p /x/$e
cp -r $e/* /x/$e
else
f=$(dirname $e)
mkdir -p /x/$f
cp -r $f/* /x/$f
fi
done

rm -rf /*-base-source
mv /x/* /
rm -rf /x
23 changes: 17 additions & 6 deletions scripts/004-build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ set -x
# BUILD_TYPE
# KOLLA_IMAGES
# OPENSTACK_VERSION
# SQUASH
# VERSION

# Set default values
Expand All @@ -18,7 +17,6 @@ BUILD_ID=${BUILD_ID:-$(date +%Y%m%d)}
BUILD_TYPE=${BUILD_TYPE:-all}
OPENSTACK_VERSION=${OPENSTACK_VERSION:-latest}
VERSION=${VERSION:-latest}
SQUASH=${SQUASH:-false}

KOLLA_CONF=kolla-build.conf

Expand All @@ -33,10 +31,6 @@ fi
export VERSION
export OPENSTACK_VERSION

if [[ $SQUASH == "true" ]]; then
BUILD_OPTS+=" --squash"
fi

if [[ -z "$KOLLA_IMAGES" ]]; then
KOLLA_IMAGES="$(python3 src/get-projects-from-versions-file.py)"
fi
Expand All @@ -51,13 +45,19 @@ if [[ $BUILD_TYPE == "base" ]]; then
fi
done

# The line can be commented out for tests to build keystone images only.
KOLLA_IMAGES_BASE=^keystone-base

kolla-build \
--template-override templates/$OPENSTACK_VERSION/template-overrides.j2 \
--config-file $KOLLA_CONF \
--pull \
$BUILD_OPTS \
$KOLLA_IMAGES_BASE 2>&1 | tee kolla-build-$BUILD_ID.log
else
# The line can be commented out for tests to build keystone images only.
KOLLA_IMAGES=^keystone

kolla-build \
--template-override templates/$OPENSTACK_VERSION/template-overrides.j2 \
--config-file $KOLLA_CONF \
Expand All @@ -71,4 +71,15 @@ if grep -q "Failed with status: error" kolla-build-$BUILD_ID.log; then
exit 1
fi

# Cleanup images

export DOCKER_NAMESPACE=${DOCKER_NAMESPACE:-osism}
export DOCKER_REGISTRY=${DOCKER_REGISTRY:-quay.io}

python3 src/cleanup-images.py

# List images

docker images

docker inspect testing
88 changes: 88 additions & 0 deletions src/cleanup-images.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
#!/usr/bin/env python3

import os
import shutil
import sys
import tempfile

from docker import APIClient, DockerClient
from loguru import logger

DOCKER_NAMESPACE = os.environ.get("DOCKER_NAMESPACE", "osism")
DOCKER_REGISTRY = os.environ.get("DOCKER_REGISTRY", "quay.io")

VERSION = os.environ.get("OPENSTACK_VERSION", "zed")
FILTERS = {"label": f"de.osism.release.openstack={VERSION}"}

SUPPORTED_IMAGES = ["keystone"]

level = "INFO"
log_fmt = (
"<green>{time:YYYY-MM-DD HH:mm:ss}</green> | <level>{level: <8}</level> | "
"<level>{message}</level>"
)

logger.remove()
logger.add(sys.stderr, format=log_fmt, level=level, colorize=True)

client = DockerClient()
client_api = APIClient()

for image in client.images.list(filters=FILTERS):
# skip images without a tag
if not image.tags:
continue

tag = image.tags[0]

# Check if the image is supported
if not [x for x in SUPPORTED_IMAGES if x in image.labels["name"]]:
logger.info(f"Image {tag} not supported")
continue

logger.info(f"Cleaning up image {tag}")

# Image layers

# 0: "sha256:59c56aee1fb4dbaeb334aef06088b49902105d1ea0c15a9e5a2a9ce560fa4c5d" <-- ubuntu:22.04
# 1: "sha256:295ebbacd98b98d173f5fba0371e4fee8bbdf9ff0ad2676670ddb2b521482004" <-- base
# 2: "sha256:bd9f5e1f11d685268d42d7bf3a7850fdd7b6767bfcfbdb1bcc0b31227dae8f91" <-- openstack-base
# 3: "sha256:6ae01f1fd7a8c29837ddc7ed50e78ba70666f5967bdaf8438f07da2971d3d024" <-- service-base
# 4: "sha256:591d1c8305854fabc586786673d87f55eb142f0efed7a002f696c6a1c4c26880" <-- service

with tempfile.TemporaryDirectory() as d:
shutil.copy("files/cleanup-base-sources.sh", d)

dockerfile = os.path.join(d, "Dockerfile")
logger.info(f"Generating Dockerfile in {d}")

# Get current username
result = client.containers.run(tag, "bash -c 'whoami'")
username = result.decode("utf-8")

with open(dockerfile, "w+") as fp:
# Cleanup the sources
fp.write(f"FROM {tag} as cleanup\n")
fp.write("COPY cleanup-base-sources.sh /cleanup-base-sources.sh\n")
fp.write("USER root\n")
fp.write("RUN bash /cleanup-base-sources.sh\n")
fp.write("RUN rm /cleanup-base-sources.sh\n")
fp.write(f"USER {username}\n")
fp.write("\n")

# Rebase on openstack-base
fp.write(
f"FROM {DOCKER_REGISTRY}/{DOCKER_NAMESPACE}/openstack-base:{tag.split(':')[1]}\n"
)
fp.write("COPY --from=cleanup / /\n")

with open(dockerfile, "r+") as fp:
logger.info(fp.read())

client.images.build(path=d, tag=f"{tag}-after-cleanup")

# Re-tag the image
client.images.remove(tag, force=True)
client.api.tag(f"{tag}-after-cleanup", tag)
client.api.tag(f"{tag}-after-cleanup", "testing")
client.images.remove("{tag}-after-cleanup", force=True)

0 comments on commit 7677d7f

Please sign in to comment.