-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2 from sclorg/support_c10s
Support Valkey 7 in CentOS Stream 10
- Loading branch information
Showing
44 changed files
with
516 additions
and
865 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
FROM quay.io/sclorg/s2i-core-c10s:c10s | ||
|
||
# Valkey image based on Software Collections packages | ||
# | ||
# Volumes: | ||
# * /var/lib/valkey/data - Datastore for Valkey | ||
# Environment: | ||
# * $VALKEY_PASSWORD - Database password | ||
|
||
ENV VALKEY_VERSION=7 \ | ||
HOME=/var/lib/valkey \ | ||
NAME=valkey | ||
|
||
ENV SUMMARY="Valkey in-memory data structure store, used as database, cache and message broker" \ | ||
DESCRIPTION="Valkey $VALKEY_VERSION available as container, is an advanced key-value store. \ | ||
It is often referred to as a data structure server since keys can contain strings, hashes, lists, \ | ||
sets and sorted sets. You can run atomic operations on these types, like appending to a string; \ | ||
incrementing the value in a hash; pushing to a list; computing set intersection, union and difference; \ | ||
or getting the member with highest ranking in a sorted set. In order to achieve its outstanding \ | ||
performance, Valkey works with an in-memory dataset. Depending on your use case, you can persist \ | ||
it either by dumping the dataset to disk every once in a while, or by appending each command to a log." | ||
|
||
LABEL summary="$SUMMARY" \ | ||
description="$DESCRIPTION" \ | ||
io.k8s.description="$DESCRIPTION" \ | ||
io.k8s.display-name="Valkey $VALKEY_VERSION" \ | ||
io.openshift.expose-services="6379:valkey" \ | ||
io.openshift.tags="database,valkey,valkey,valkey-$VALKEY_VERSION" \ | ||
com.redhat.component="valkey-$VALKEY_VERSION-container" \ | ||
name="sclorg/valkey-$VALKEY_VERSION-c10s" \ | ||
version="$VALKEY_VERSION" \ | ||
com.redhat.license_terms="https://www.redhat.com/en/about/red-hat-end-user-license-agreements#rhel" \ | ||
usage="podman run -d --name valkey_database -p 6379:6379 quay.io/sclorg/valkey-$VALKEY_VERSION-c10s" \ | ||
maintainer="SoftwareCollections.org <[email protected]>" | ||
|
||
EXPOSE 6379 | ||
|
||
# Get prefix path and path to scripts rather than hard-code them in scripts | ||
ENV CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/valkey \ | ||
VALKEY_PREFIX=/usr \ | ||
VALKEY_CONF=/etc/valkey/valkey.conf \ | ||
VALKEY_SOCK=/run/valkey/valkey.sock \ | ||
VALKEY_LIB=/var/lib/valkey \ | ||
VALKEY_RUN=/run/valkey | ||
|
||
|
||
# Create user for Valkey that has known UID | ||
# We need to do this before installing the RPMs which would create user with random UID | ||
# The UID is the one used by the default user from the parent layer (1001), | ||
# and since the user exists already, do not create a new one, but only rename | ||
# the existing | ||
# This image must forever use UID 1001 for Valkey user so our volumes are | ||
# safe in the future. This should *never* change, the last test is there | ||
# to make sure of that. | ||
RUN getent group valkey &> /dev/null || groupadd -r valkey &> /dev/null && \ | ||
usermod -l valkey -aG valkey -c 'Valkey Server' default &> /dev/null && \ | ||
# Install gettext for envsubst command | ||
INSTALL_PKGS="policycoreutils gettext bind valkey" && \ | ||
dnf install -y --setopt=tsflags=nodocs $INSTALL_PKGS && \ | ||
rpm -V $INSTALL_PKGS && \ | ||
dnf -y clean all --enablerepo='*' && \ | ||
valkey-server --version | grep -qe "^Server v=$VALKEY_VERSION\." && echo "Found VERSION $VALKEY_VERSION" && \ | ||
mkdir -p $VALKEY_LIB/data && chown -R valkey:0 $VALKEY_LIB && \ | ||
mkdir -p $VALKEY_RUN && chown -R valkey:0 $VALKEY_RUN && \ | ||
chmod -R ug+rwX $VALKEY_RUN && \ | ||
chmod -R ug+rwX $VALKEY_LIB && \ | ||
[[ "$(id valkey)" == "uid=1001(valkey)"* ]] | ||
|
||
# Get prefix path and path to scripts rather than hard-code them in scripts | ||
ENV CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/valkey \ | ||
VALKEY_PREFIX=/usr \ | ||
VALKEY_CONF=/etc/valkey/valkey.conf | ||
|
||
COPY root / | ||
|
||
# this is needed due to issues with squash | ||
# when this directory gets rm'd by the container-setup | ||
# script. | ||
RUN /usr/libexec/container-setup | ||
|
||
VOLUME ["/var/lib/valkey/data"] | ||
|
||
# Using a numeric value because of a comment in [1]: | ||
# If your S2I image does not include a USER declaration with a numeric user, | ||
# your builds will fail by default. | ||
# [1] https://docs.openshift.com/container-platform/4.4/openshift_images/create-images.html#images-create-guide-openshift_create-images | ||
USER 1001 | ||
|
||
ENTRYPOINT ["container-entrypoint"] | ||
CMD ["run-valkey"] |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,65 +1,70 @@ | ||
FROM quay.io/fedora/s2i-core:38 | ||
FROM quay.io/fedora/s2i-core:40 | ||
|
||
# Redis image based on Software Collections packages | ||
# Valkey image based on Software Collections packages | ||
# | ||
# Volumes: | ||
# * /var/lib/redis/data - Datastore for Redis | ||
# * /var/lib/valkey/data - Datastore for Valkey | ||
# Environment: | ||
# * $REDIS_PASSWORD - Database password | ||
# * $VALKEY_PASSWORD - Database password | ||
|
||
ENV NAME=redis \ | ||
VERSION=7 | ||
ENV VALKEY_VERSION=7 \ | ||
HOME=/var/lib/valkey \ | ||
NAME=valkey | ||
|
||
ENV REDIS_VERSION=$VERSION \ | ||
HOME=/var/lib/redis | ||
|
||
ENV SUMMARY="Redis in-memory data structure store, used as database, cache and message broker" \ | ||
DESCRIPTION="Redis $REDIS_VERSION available as container, is an advanced key-value store. \ | ||
ENV SUMMARY="Valkey in-memory data structure store, used as database, cache and message broker" \ | ||
DESCRIPTION="Valkey $VALKEY_VERSION available as container, is an advanced key-value store. \ | ||
It is often referred to as a data structure server since keys can contain strings, hashes, lists, \ | ||
sets and sorted sets. You can run atomic operations on these types, like appending to a string; \ | ||
incrementing the value in a hash; pushing to a list; computing set intersection, union and difference; \ | ||
or getting the member with highest ranking in a sorted set. In order to achieve its outstanding \ | ||
performance, Redis works with an in-memory dataset. Depending on your use case, you can persist \ | ||
performance, Valkey works with an in-memory dataset. Depending on your use case, you can persist \ | ||
it either by dumping the dataset to disk every once in a while, or by appending each command to a log." | ||
|
||
LABEL summary="$SUMMARY" \ | ||
description="$DESCRIPTION" \ | ||
io.k8s.description="$SUMMARY" \ | ||
io.k8s.display-name="Redis 7" \ | ||
io.openshift.expose-services="6379:redis" \ | ||
io.openshift.tags="database,redis,redis7" \ | ||
io.k8s.description="$DESCRIPTION" \ | ||
io.k8s.display-name="Valkey $VALKEY_VERSION" \ | ||
io.openshift.expose-services="6379:valkey" \ | ||
io.openshift.tags="database,valkey,valkey$VALKEY_VERSION,valkey-$VALKEY_VERSION" \ | ||
com.redhat.component="$NAME" \ | ||
name="fedora/$NAME-$VERSION" \ | ||
version="$VERSION" \ | ||
usage="docker run -d --name redis_database -p 6379:6379 quay.io/fedora/$NAME-$VERSION" \ | ||
name="fedora/$NAME-$VALKEY_VERSION" \ | ||
version="$VALKEY_VERSION" \ | ||
usage="podman run -d --name valkey_database -p 6379:6379 quay.io/fedora/$NAME-$VALKEY_VERSION" \ | ||
maintainer="SoftwareCollections.org <[email protected]>" | ||
|
||
EXPOSE 6379 | ||
|
||
# Create user for redis that has known UID | ||
# Get prefix path and path to scripts rather than hard-code them in scripts | ||
ENV CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/valkey \ | ||
VALKEY_PREFIX=/usr \ | ||
VALKEY_CONF=/etc/valkey/valkey.conf \ | ||
VALKEY_SOCK=/run/valkey/valkey.sock \ | ||
VALKEY_LIB=/var/lib/valkey \ | ||
VALKEY_RUN=/run/valkey | ||
|
||
# Create user for valkey that has known UID | ||
# We need to do this before installing the RPMs which would create user with random UID | ||
# The UID is the one used by the default user from the parent layer (1001), | ||
# and since the user exists already, do not create a new one, but only rename | ||
# the existing | ||
# This image must forever use UID 1001 for redis user so our volumes are | ||
# This image must forever use UID 1001 for valkey user so our volumes are | ||
# safe in the future. This should *never* change, the last test is there | ||
# to make sure of that. | ||
RUN getent group redis &> /dev/null || groupadd -r redis &> /dev/null && \ | ||
usermod -l redis -aG redis -c 'Redis Server' default &> /dev/null && \ | ||
RUN getent group valkey &> /dev/null || groupadd -r valkey &> /dev/null && \ | ||
usermod -l valkey -aG valkey -c 'Server' default &> /dev/null && \ | ||
# Install gettext for envsubst command | ||
dnf install -y yum-utils gettext policycoreutils && \ | ||
INSTALL_PKGS="redis" && \ | ||
dnf install -y dnf-utils gettext policycoreutils && \ | ||
INSTALL_PKGS="valkey" && \ | ||
dnf install -y --setopt=tsflags=nodocs --nogpgcheck $INSTALL_PKGS && \ | ||
rpm -V $INSTALL_PKGS && \ | ||
dnf clean all && \ | ||
redis-server --version | grep -qe "^Redis server v=$REDIS_VERSION\." && echo "Found VERSION $REDIS_VERSION" && \ | ||
mkdir -p /var/lib/redis/data && chown -R redis.0 /var/lib/redis && \ | ||
[[ "$(id redis)" == "uid=1001(redis)"* ]] | ||
dnf -y clean all --enablerepo='*' && \ | ||
valkey-server --version | grep -qe "^Server v=$VALKEY_VERSION\." && echo "Found VERSION $VALKEY_VERSION" && \ | ||
mkdir -p $VALKEY_LIB/data && chown -R valkey:0 $VALKEY_LIB && \ | ||
mkdir -p $VALKEY_RUN && chown -R valkey:0 $VALKEY_RUN && \ | ||
chmod -R ug+rwX $VALKEY_RUN && \ | ||
chmod -R ug+rwX $VALKEY_LIB && \ | ||
[[ "$(id valkey)" == "uid=1001(valkey)"* ]] | ||
|
||
# Get prefix path and path to scripts rather than hard-code them in scripts | ||
ENV CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/redis \ | ||
REDIS_PREFIX=/usr \ | ||
REDIS_CONF=/etc/redis/redis.conf | ||
|
||
COPY root / | ||
|
||
|
@@ -68,7 +73,7 @@ COPY root / | |
# script. | ||
RUN /usr/libexec/container-setup | ||
|
||
VOLUME ["/var/lib/redis/data"] | ||
VOLUME ["/var/lib/valkey/data"] | ||
|
||
# Using a numeric value because of a comment in [1]: | ||
# If your S2I image does not include a USER declaration with a numeric user, | ||
|
@@ -77,4 +82,4 @@ VOLUME ["/var/lib/redis/data"] | |
USER 1001 | ||
|
||
ENTRYPOINT ["container-entrypoint"] | ||
CMD ["run-redis"] | ||
CMD ["run-valkey"] |
Oops, something went wrong.