OBS-URL: https://build.opensuse.org/package/show/devel:BCI:Tumbleweed/valkey-image?expand=0&rev=152
79 lines
3.7 KiB
Docker
79 lines
3.7 KiB
Docker
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright (c) 2026 SUSE LLC
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon.
|
|
|
|
# The content of THIS FILE IS AUTOGENERATED and should not be manually modified.
|
|
# It is maintained by the BCI team and generated by
|
|
# https://github.com/SUSE/BCI-dockerfile-generator
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
# You can contact the BCI team via https://github.com/SUSE/bci/discussions
|
|
|
|
#!UseOBSRepositories
|
|
|
|
#!BuildTag: opensuse/valkey:%%valkey_version%%-%RELEASE%
|
|
#!BuildTag: opensuse/valkey:%%valkey_version%%
|
|
#!BuildTag: opensuse/valkey:9.0
|
|
#!BuildTag: opensuse/valkey:9
|
|
#!BuildTag: opensuse/valkey:latest
|
|
|
|
FROM opensuse/bci/bci-micro:latest AS target
|
|
FROM opensuse/tumbleweed:latest AS builder
|
|
COPY --from=target / /target
|
|
|
|
RUN set -euo pipefail; \
|
|
export PERMCTL_ALLOW_INSECURE_MODE_IF_NO_PROC=1; \
|
|
zypper -n --installroot /target --gpg-auto-import-keys install --no-recommends valkey sed
|
|
|
|
RUN set -euo pipefail; zypper -n install --no-recommends systemd && \
|
|
systemd-tmpfiles --create --root /target valkey.conf
|
|
# sanity check that the version from the tag is equal to the version of valkey that we expect
|
|
RUN set -euo pipefail; \
|
|
[ "$(rpm --root /target -q --qf '%{version}' valkey | \
|
|
cut -d '.' -f -2)" = "9.0" ]
|
|
|
|
# cleanup logs and temporary files
|
|
RUN set -euo pipefail; zypper -n --installroot /target clean -a; \
|
|
rm -rf {/target,}/var/log/{alternatives.log,lastlog,tallylog,zypper.log,zypp/history,YaST2}; \
|
|
rm -rf {/target,}/run/*; \
|
|
rm -f {/target,}/etc/{shadow-,group-,passwd-,.pwd.lock}; \
|
|
rm -f {/target,}/usr/lib/sysimage/rpm/.rpm.lock; \
|
|
rm -f {/target,}/var/cache/ldconfig/aux-cache; \
|
|
command -v zypper >/dev/null 2>&1 || rm -f /var/lib/zypp/AutoInstalled
|
|
|
|
# set the day of last password change to empty
|
|
RUN set -euo pipefail; sed -i 's/^\([^:]*:[^:]*:\)[^:]*\(:.*\)$/\1\2/' /target/etc/shadow
|
|
FROM opensuse/bci/bci-micro:latest
|
|
COPY --from=builder /target /
|
|
# Define labels according to https://en.opensuse.org/Building_derived_containers
|
|
# labelprefix=org.opensuse.application.valkey
|
|
LABEL org.opencontainers.image.title="openSUSE Tumbleweed Persistent key-value database"
|
|
LABEL org.opencontainers.image.description="Valkey is an open source high-performance key/value data store designed for a variety of workloads such as caching, message queuing and primary database use. This image is based on the openSUSE Tumbleweed Base Container Image."
|
|
LABEL org.opencontainers.image.version="%%valkey_version%%"
|
|
LABEL org.opencontainers.image.url="https://www.opensuse.org"
|
|
LABEL org.opencontainers.image.created="%BUILDTIME%"
|
|
LABEL org.opencontainers.image.vendor="openSUSE Project"
|
|
LABEL org.opencontainers.image.source="%SOURCEURL%"
|
|
LABEL org.opencontainers.image.ref.name="%%valkey_version%%-%RELEASE%"
|
|
LABEL org.opensuse.reference="registry.opensuse.org/opensuse/valkey:%%valkey_version%%-%RELEASE%"
|
|
LABEL org.openbuildservice.disturl="%DISTURL%"
|
|
LABEL org.opensuse.lifecycle-url="https://en.opensuse.org/Lifetime#openSUSE_BCI"
|
|
LABEL org.opensuse.release-stage="released"
|
|
# endlabelprefix
|
|
LABEL io.artifacthub.package.readme-url="%SOURCEURL_WITH(README.md)%"
|
|
ENTRYPOINT ["/usr/bin/valkey-server"]
|
|
CMD ["/etc/valkey/valkey.conf"]
|
|
EXPOSE 6379/tcp
|
|
|
|
RUN set -euo pipefail; install -o valkey -g valkey -m 750 -d /data
|
|
WORKDIR /data
|
|
|
|
RUN set -euo pipefail; install -m 0640 -o root -g valkey /etc/valkey/valkey.default.conf.template /etc/valkey/valkey.conf
|
|
RUN set -euo pipefail; printf 'protected-mode no\nbind * -::*\n' >> /etc/valkey/valkey.conf && chmod 0640 /etc/valkey/valkey.conf && chown root:valkey /etc/valkey/valkey.conf
|
|
USER valkey
|
|
VOLUME /data
|