summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.gitignore9
-rw-r--r--Makefile4
-rw-r--r--valkey-conf.patch61
-rw-r--r--valkey-sentinel.service34
-rw-r--r--valkey.logrotate9
-rw-r--r--valkey.service35
-rw-r--r--valkey.spec516
-rw-r--r--valkey.sysusers1
-rw-r--r--valkey.tmpfiles3
9 files changed, 672 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..01f0400
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,9 @@
+clog
+package-*.xml
+*.tgz
+*.tar.bz2
+*.tar.gz
+*.tar.xz
+*.tar.xz.asc
+*.src.rpm
+*/*rpm
diff --git a/Makefile b/Makefile
new file mode 100644
index 0000000..91b0fd5
--- /dev/null
+++ b/Makefile
@@ -0,0 +1,4 @@
+SRCDIR := $(shell pwd)
+NAME := $(shell basename $(SRCDIR))
+include ../../common/Makefile
+
diff --git a/valkey-conf.patch b/valkey-conf.patch
new file mode 100644
index 0000000..d714e01
--- /dev/null
+++ b/valkey-conf.patch
@@ -0,0 +1,61 @@
+diff -up ./sentinel.conf.rpm ./sentinel.conf
+--- ./sentinel.conf.rpm 2025-07-24 10:05:46.477794769 +0200
++++ ./sentinel.conf 2025-07-24 10:07:27.023483441 +0200
+@@ -17,7 +17,7 @@ daemonize no
+ # When running daemonized, Valkey Sentinel writes a pid file in
+ # /var/run/valkey-sentinel.pid by default. You can specify a custom pid file
+ # location here.
+-pidfile /var/run/valkey-sentinel.pid
++pidfile /run/valkey/sentinel.pid
+
+ # Specify the server verbosity level.
+ # This can be one of:
+@@ -31,7 +31,7 @@ loglevel notice
+ # Specify the log file name. Also the empty string can be used to force
+ # Sentinel to log on the standard output. Note that if you use standard
+ # output for logging but daemonize, logs will be sent to /dev/null
+-logfile ""
++logfile /var/log/valkey/sentinel.log
+
+ # To enable logging to the system logger, just set 'syslog-enabled' to yes,
+ # and optionally update the other syslog parameters to suit your needs.
+diff -up ./valkey.conf.rpm ./valkey.conf
+--- ./valkey.conf.rpm 2025-07-24 10:05:46.475591081 +0200
++++ ./valkey.conf 2025-07-24 10:07:23.219331838 +0200
+@@ -43,6 +43,9 @@
+ # include /path/to/other.conf
+ # include /path/to/fragments/*.conf
+ #
++# Module configuration files
++include /etc/redis/modules/*.conf
++
+
+ ################################## MODULES #####################################
+
+@@ -153,7 +156,7 @@ tcp-backlog 511
+ # incoming connections. There is no default, so the server will not listen
+ # on a unix socket when not specified.
+ #
+-# unixsocket /run/valkey.sock
++unixsocket /run/valkey/valkey.sock
+ # unixsocketgroup wheel
+ # unixsocketperm 700
+
+@@ -385,7 +388,7 @@ daemonize no
+ #
+ # Note that on modern Linux systems "/run/valkey.pid" is more conforming
+ # and should be used instead.
+-pidfile /var/run/valkey_6379.pid
++pidfile /run/valkey/valkey.pid
+
+ # Specify the server verbosity level.
+ # This can be one of:
+@@ -416,7 +419,7 @@ loglevel notice
+ # Specify the log file name. Also the empty string can be used to force
+ # the server to log on the standard output. Note that if you use standard
+ # output for logging but daemonize, logs will be sent to /dev/null
+-logfile ""
++logfile /var/log/valkey/valkey.log
+
+ # To enable logging to the system logger, just set 'syslog-enabled' to yes,
+ # and optionally update the other syslog parameters to suit your needs.
diff --git a/valkey-sentinel.service b/valkey-sentinel.service
new file mode 100644
index 0000000..36093e0
--- /dev/null
+++ b/valkey-sentinel.service
@@ -0,0 +1,34 @@
+[Unit]
+Description=Valkey Sentinel
+After=network.target
+After=network-online.target
+Wants=network-online.target
+
+[Service]
+# ensure var is set
+Environment=OPTIONS=
+EnvironmentFile=-/etc/sysconfig/valkey-sentinel
+# we must keep $OPTIONS and the env file as some older installs will still be using /etc/sysconfig/valkey-sentinel
+ExecStart=/usr/bin/valkey-sentinel /etc/valkey/sentinel.conf --daemonize no --supervised systemd $OPTIONS
+Type=notify
+User=valkey
+Group=valkey
+RuntimeDirectory=valkey
+RuntimeDirectoryMode=0755
+
+# If you need to change max open file limit
+# for example, when you change maxclient in configuration
+# you can change the LimitNOFILE value below.
+# See "man systemd.exec" for more information.
+LimitNOFILE=10240
+
+# Slave nodes on large system may take lot of time to start.
+# You may need to uncomment TimeoutStartSec and TimeoutStopSec
+# directives below and raise their value.
+# See "man systemd.service" for more information.
+#TimeoutStartSec=90s
+#TimeoutStopSec=90s
+
+[Install]
+WantedBy=multi-user.target
+
diff --git a/valkey.logrotate b/valkey.logrotate
new file mode 100644
index 0000000..e91fcd3
--- /dev/null
+++ b/valkey.logrotate
@@ -0,0 +1,9 @@
+/var/log/valkey/*.log {
+ weekly
+ rotate 10
+ copytruncate
+ delaycompress
+ compress
+ notifempty
+ missingok
+}
diff --git a/valkey.service b/valkey.service
new file mode 100644
index 0000000..827f5f2
--- /dev/null
+++ b/valkey.service
@@ -0,0 +1,35 @@
+[Unit]
+Description=Valkey persistent key-value database
+After=network.target
+After=network-online.target
+Wants=network-online.target
+
+[Service]
+WorkingDirectory=/var/lib/valkey
+# ensure var is set
+Environment=OPTIONS=
+EnvironmentFile=-/etc/sysconfig/valkey
+# we must keep $OPTIONS and the env file as some older installs will still be using /etc/sysconfig/valkey
+ExecStart=/usr/bin/valkey-server /etc/valkey/valkey.conf --daemonize no --supervised systemd $OPTIONS
+Type=notify
+User=valkey
+Group=valkey
+RuntimeDirectory=valkey
+RuntimeDirectoryMode=0755
+
+# If you need to change max open file limit
+# for example, when you change maxclient in configuration
+# you can change the LimitNOFILE value below.
+# See "man systemd.exec" for more information.
+LimitNOFILE=10240
+
+# Slave nodes on large system may take lot of time to start.
+# You may need to uncomment TimeoutStartSec and TimeoutStopSec
+# directives below and raise their value.
+# See "man systemd.service" for more information.
+#TimeoutStartSec=90s
+#TimeoutStopSec=90s
+
+[Install]
+WantedBy=multi-user.target
+
diff --git a/valkey.spec b/valkey.spec
new file mode 100644
index 0000000..1096472
--- /dev/null
+++ b/valkey.spec
@@ -0,0 +1,516 @@
+# Docs require pandoc, which is not included in RHEL
+%if %{undefined rhel} || %{defined epel}
+%bcond_without docs
+%else
+%bcond_with docs
+%endif
+# See https://github.com/valkey-io/valkey-doc/tags
+%global doc_version 8.1.1
+# Tests fail in mock, not in local build.
+%bcond_with tests
+
+Name: valkey
+Version: 8.1.3
+Release: 2%{?dist}
+Summary: A persistent key-value database
+# valkey: BSD-3-Clause
+# hiredis: BSD-3-Clause
+# hdrhistogram, jemalloc, lzf, linenoise: BSD-2-Clause
+# lua: MIT
+# fpconv: BSL-1.0
+License: BSD-3-Clause AND BSD-2-Clause AND MIT AND BSL-1.0
+URL: https://valkey.io
+Source0: https://github.com/valkey-io/%{name}/archive/%{version}/%{name}-%{version}.tar.gz
+Source1: %{name}.logrotate
+Source2: %{name}-sentinel.service
+Source3: %{name}.service
+Source4: %{name}.sysusers
+Source5: %{name}.tmpfiles
+Source9: migrate_redis_to_valkey.sh
+Source50: https://github.com/valkey-io/%{name}-doc/archive/%{doc_version}/%{name}-doc-%{doc_version}.tar.gz
+
+# Fix default paths in configuration files for RPM layout
+Patch0: %{name}-conf.patch
+
+BuildRequires: make
+BuildRequires: gcc
+%if %{with tests}
+BuildRequires: procps-ng
+BuildRequires: tcl
+%endif
+BuildRequires: pkgconfig(libsystemd)
+BuildRequires: systemd-devel
+BuildRequires: systemd-rpm-macros
+BuildRequires: openssl-devel
+%if %{with docs}
+# for docs/man pages
+BuildRequires: pandoc
+BuildRequires: python3
+BuildRequires: python3-pyyaml
+%endif
+
+Requires: logrotate
+# from deps/hiredis/hiredis.h
+Provides: bundled(hiredis) = 1.0.3
+# from deps/jemalloc/VERSION
+Provides: bundled(jemalloc) = 5.3.0
+# from deps/lua/src/lua.h
+Provides: bundled(lua-libs) = 5.1.5
+# from deps/linenoise/linenoise.h
+Provides: bundled(linenoise) = 1.0
+Provides: bundled(lzf)
+# from deps/hdr_histogram/README.md
+Provides: bundled(hdr_histogram) = 0.11.0
+# no version
+Provides: bundled(fpconv)
+
+%global valkey_modules_abi 1
+%global valkey_modules_dir %{_libdir}/%{name}/modules
+%global valkey_modules_cfg %{_sysconfdir}/%{name}/modules
+Provides: valkey(modules_abi)%{?_isa} = %{valkey_modules_abi}
+
+ExcludeArch: %{ix86}
+
+%description
+Valkey 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.
+
+Valkey also supports trivial-to-setup master-slave replication, with very
+fast non-blocking first synchronization, auto-reconnection on net split
+and so forth.
+
+Other features include Transactions, Pub/Sub, Lua scripting, Keys with a
+limited time-to-live, and configuration settings to make Valkey behave like
+a cache.
+
+You can use Valkey from most programming languages also.
+
+%package devel
+Summary: Development header for Valkey module development
+# Header-Only Library (https://fedoraproject.org/wiki/Packaging:Guidelines)
+Provides: %{name}-static = %{version}-%{release}
+
+%description devel
+Header file required for building loadable Valkey modules.
+
+
+%package compat-redis
+Summary: Conversion script and compatibility symlinks for Redis
+Requires: valkey = %{version}-%{release}
+%if 0%{?fedora} > 40 || 0%{?rhel} > 9
+Obsoletes: redis < 7.4
+Provides: redis = %{version}-%{release}
+%else
+Conflicts: redis < 7.4
+%endif
+BuildArch: noarch
+
+
+%description compat-redis
+%summary
+
+
+%package compat-redis-devel
+Summary: Compatibility development header for Redis API Valkey modules
+Requires: valkey-devel = %{version}-%{release}
+%if 0%{?fedora} > 40 || 0%{?rhel} > 9
+Obsoletes: redis-devel < 7.4
+Provides: redis-devel = %{version}-%{release}
+# Header-Only Library (https://fedoraproject.org/wiki/Packaging:Guidelines)
+Obsoletes: redis-static < 7.4
+Provides: redis-static = %{version}-%{release}
+%else
+Conflicts: redis-devel < 7.4
+Conflicts: redis-static < 7.4
+%endif
+BuildArch: noarch
+
+
+%description compat-redis-devel
+Header file required for building loadable Valkey modules with the legacy
+Redis API.
+
+
+%if %{with docs}
+%package doc
+Summary: Documentation and extra man pages for %{name}
+BuildArch: noarch
+License: CC-BY-SA-4.0
+%if 0%{?fedora} > 40 || 0%{?rhel} > 9
+Obsoletes: redis-doc < 7.4
+Provides: redis-doc = %{version}-%{release}
+%endif
+
+
+%description doc
+%summary
+%endif
+
+
+%prep
+# no autosetup due to no support for multiple source extraction
+%setup -n %{name}-%{version} -a50
+%patch -P0 -p1 -b.rpm
+
+mv deps/lua/COPYRIGHT COPYRIGHT-lua
+mv deps/jemalloc/COPYING COPYING-jemalloc
+mv deps/hiredis/COPYING COPYING-hiredis-BSD-3-Clause
+mv deps/hdr_histogram/LICENSE.txt LICENSE-hdrhistogram
+mv deps/hdr_histogram/COPYING.txt COPYING-hdrhistogram
+mv deps/fpconv/LICENSE.txt LICENSE-fpconv
+
+# See https://bugzilla.redhat.com/2240293
+# See https://src.fedoraproject.org/rpms/jemalloc/blob/rawhide/f/jemalloc.spec#_34
+%ifarch %ix86 %arm x86_64 s390x
+sed -e 's/--with-lg-quantum/--with-lg-page=12 --with-lg-quantum/' -i deps/Makefile
+%endif
+%ifarch ppc64 ppc64le aarch64
+sed -e 's/--with-lg-quantum/--with-lg-page=16 --with-lg-quantum/' -i deps/Makefile
+%endif
+
+# Module API version safety check
+api=`sed -n -e 's/#define VALKEYMODULE_APIVER_[0-9][0-9]* //p' src/valkeymodule.h`
+if test "$api" != "%{valkey_modules_abi}"; then
+ : Error: Upstream API version is now ${api}, expecting %%{valkey_modules_abi}.
+ : Update the valkey_modules_abi macro, and rebuild.
+ exit 1
+fi
+
+# Generates macro file
+cat << 'EOF' | tee macros.%{name}
+%%valkey_modules_abi %valkey_modules_abi
+%%valkey_modules_dir %valkey_modules_dir
+%%valkey_modules_cfg %valkey_modules_cfg
+EOF
+
+%if (%{defined fedora} && 0%{?fedora} < 42) || (%{defined rhel} && 0%{?rhel} < 10)
+# these lines are for conditionals around sysconfig to valkey.conf porting scriptlets to avoid re-runs
+echo '# valkey_rpm_conf' >> valkey.conf
+echo '# valkey-sentinel_rpm_conf' >> sentinel.conf
+%endif
+
+%global make_flags DEBUG="" V="echo" PREFIX=%{buildroot}%{_prefix} BUILD_WITH_SYSTEMD=yes BUILD_TLS=yes
+
+
+%build
+%make_build %{make_flags}
+
+%if %{with docs}
+# docs
+pushd %{name}-doc-%{doc_version}
+# build man pages
+%make_build VALKEY_ROOT=../
+# build html docs
+%make_build html VALKEY_ROOT=../
+popd
+%endif
+
+
+%install
+%make_install %{make_flags}
+%if %{with docs}
+# install docs
+pushd %{name}-doc-%{doc_version}
+# man pages
+%make_install INSTALL_MAN_DIR=%{buildroot}%{_mandir} VALKEY_ROOT=../
+# install html docs
+install -d %{buildroot}%{_docdir}/%{name}/
+cp -ra _build/html/* %{buildroot}%{_docdir}/%{name}/
+# install doc license
+install -d %{buildroot}%{_defaultlicensedir}/valkey-doc/
+cp -a LICENSE %{buildroot}%{_defaultlicensedir}/valkey-doc/
+popd
+%endif
+
+# remove sample confs
+rm -rf %{buildroot}%{_datadir}/%{name}
+
+# System user
+install -p -D -m 0644 %{S:4} %{buildroot}%{_sysusersdir}/%{name}.conf
+
+# Install tmpfiles.d file
+install -p -D -m 0644 %{S:5} %{buildroot}%{_tmpfilesdir}/%{name}.conf
+
+# Filesystem.
+install -d %{buildroot}%{_sharedstatedir}/%{name}
+install -d %{buildroot}%{_localstatedir}/log/%{name}
+install -d %{buildroot}%{_localstatedir}/run/%{name}
+install -d %{buildroot}%{valkey_modules_dir}
+
+# Install logrotate file.
+install -pDm644 %{S:1} %{buildroot}%{_sysconfdir}/logrotate.d/%{name}
+
+# Install configuration files.
+install -pDm640 %{name}.conf %{buildroot}%{_sysconfdir}/%{name}/%{name}.conf
+install -pDm640 sentinel.conf %{buildroot}%{_sysconfdir}/%{name}/sentinel.conf
+install -dm750 %{buildroot}%{valkey_modules_cfg}
+
+# Install systemd unit files.
+mkdir -p %{buildroot}%{_unitdir}
+install -pm644 %{S:3} %{buildroot}%{_unitdir}
+install -pm644 %{S:2} %{buildroot}%{_unitdir}
+
+# Fix non-standard-executable-perm error.
+chmod 755 %{buildroot}%{_bindir}/%{name}-*
+
+# Install valkey module header
+install -pDm644 src/%{name}module.h %{buildroot}%{_includedir}/%{name}module.h
+
+# Install rpm macros for valkey modules
+#mkdir -p %{buildroot}%{_rpmmacrodir}
+install -pDm644 macros.%{name} %{buildroot}%{_rpmmacrodir}/macros.%{name}
+
+# compat script
+install -Dpm 755 %{S:9} %{buildroot}%{_libexecdir}/migrate_redis_to_valkey.sh
+
+# compat header
+install -pDm644 src/redismodule.h %{buildroot}%{_includedir}/redismodule.h
+
+# compat systemd symlinks
+ln -sr %{buildroot}/usr/lib/systemd/system/valkey.service %{buildroot}/usr/lib/systemd/system/redis.service
+ln -sr %{buildroot}/usr/lib/systemd/system/valkey-sentinel.service %{buildroot}/usr/lib/systemd/system/redis-sentinel.service
+
+
+%check
+%if %{with tests}
+# https://github.com/redis/redis/issues/1417 (for "taskset -c 1")
+taskset -c 1 ./runtest --clients 50 --skiptest "Active defrag - AOF loading"
+
+# sentinel tests fail in mock, but we want the normal tests above
+#./runtest-sentinel
+%endif
+
+
+
+%post
+%if (%{defined fedora} && 0%{?fedora} < 42) || (%{defined rhel} && 0%{?rhel} < 10)
+# migrate away from /etc/sysconfig/valkey
+# only during upgrades, not installs
+if [ $1 -eq 2 ]; then
+ # if valkey.rpmsave doesn't exist then it wasn't modified by the user
+ # and we should write our defaults into the config file to ensure continuity of service
+ # these defaults are what was previously in /etc/sysconfig/valkey
+ # if there's no .rpmnew file they got the updated default config file so we don't need to sed
+ if [ ! -f /etc/sysconfig/valkey.rpmsave ] && [ -f /etc/valkey/valkey.conf.rpmnew ] && ! grep -q valkey_rpm_conf /etc/valkey/valkey.conf; then
+ sed -i -e 's|^logfile ""$|logfile /var/log/valkey/valkey.log|g' \
+ -e 's|^pidfile /var/run/valkey_6379.pid$|pidfile /run/valkey/valkey.pid|g' \
+ /etc/valkey/valkey.conf
+ # we need an extra conditional around this one to make sure we don't end up with duplicate
+ # config lines for unixsocket since the default is commented
+ if ! grep -q "^unixsocket " /etc/valkey/valkey.conf; then
+ sed -i 's|^# unixsocket /run/valkey.sock$|unixsocket /run/valkey/valkey.sock|g' /etc/valkey/valkey.conf
+ fi
+ echo '# valkey_rpm_conf' >> /etc/valkey/valkey.conf
+ fi
+ if [ ! -f /etc/sysconfig/valkey-sentinel.rpmsave ] && [ -f /etc/valkey/valkey-sentinel.conf.rpmnew ] && ! grep -q valkey-sentinel_rpm_conf /etc/valkey/sentinel.conf; then
+ sed -i -e 's|^logfile ""$|logfile /var/log/valkey/sentinel.log|g' \
+ -e 's|^pidfile /var/run/valkey_6379.pid$|pidfile /run/valkey/sentinel.pid|g' \
+ /etc/valkey/sentinel.conf
+ echo '# valkey-sentinel_rpm_conf' >> /etc/valkey/sentinel.conf
+ fi
+
+ # if valkey.rpmsave does exist then it was modified and we still need it
+ # becuase we don't know what was modified so we cannot sed the main config
+ # or remove the sysconfig file. This will detach the sysconfig file from the RPM
+ # and as long as we keep the line to load it in the service file nothing will break
+ # for the user
+ if [ -f /etc/sysconfig/valkey.rpmsave ]; then
+ mv -n /etc/sysconfig/valkey{.rpmsave,}
+ fi
+ if [ -f /etc/sysconfig/valkey-sentinel.rpmsave ]; then
+ mv -n /etc/sysconfig/valkey-sentinel{.rpmsave,}
+ fi
+fi
+%endif
+
+%systemd_post %{name}.service
+%systemd_post %{name}-sentinel.service
+
+
+%post compat-redis
+%{_libexecdir}/migrate_redis_to_valkey.sh
+
+
+%preun
+%systemd_preun %{name}.service
+%systemd_preun %{name}-sentinel.service
+
+
+%postun
+%systemd_postun_with_restart %{name}.service
+%systemd_postun_with_restart %{name}-sentinel.service
+
+
+%files
+%license COPYING
+%license COPYRIGHT-lua
+%license COPYING-jemalloc
+%license LICENSE-hdrhistogram
+%license COPYING-hdrhistogram
+%license LICENSE-fpconv
+%license COPYING-hiredis-BSD-3-Clause
+%config(noreplace) %{_sysconfdir}/logrotate.d/%{name}
+%attr(0750, valkey, root) %dir %{_sysconfdir}/%{name}
+%attr(0750, valkey, root) %dir %{valkey_modules_cfg}
+%attr(0640, valkey, root) %config(noreplace) %{_sysconfdir}/%{name}/%{name}.conf
+%attr(0640, valkey, root) %config(noreplace) %{_sysconfdir}/%{name}/sentinel.conf
+%dir %{_libdir}/%{name}
+%dir %{valkey_modules_dir}
+%dir %attr(0750, valkey, valkey) %{_sharedstatedir}/%{name}
+%dir %attr(0750, valkey, valkey) %{_localstatedir}/log/%{name}
+%{_bindir}/%{name}-*
+%{_unitdir}/%{name}.service
+%{_unitdir}/%{name}-sentinel.service
+%dir %attr(0755, valkey, valkey) %ghost %{_localstatedir}/run/%{name}
+%{_sysusersdir}/%{name}.conf
+%{_tmpfilesdir}/%{name}.conf
+%if %{with docs}
+%{_mandir}/man1/%{name}*.gz
+%{_mandir}/man5/%{name}.conf.5.gz
+%endif
+
+
+%if %{with docs}
+%files doc
+%license LICENSE
+%doc %{_docdir}/valkey/
+%{_mandir}/man{3,7}/*%{name}*.gz
+%endif
+
+
+%files devel
+# main package is not required
+%license COPYING
+%{_includedir}/%{name}module.h
+%{_rpmmacrodir}/macros.%{name}
+
+
+%files compat-redis
+%{_libexecdir}/migrate_redis_to_valkey.sh
+%{_bindir}/redis-*
+%{_unitdir}/redis.service
+%{_unitdir}/redis-sentinel.service
+
+%files compat-redis-devel
+%{_includedir}/redismodule.h
+
+
+%changelog
+* Thu Jul 24 2025 Remi Collet <remi@fedoraproject.org> - 8.1.3-2
+- use patch for configuration changes
+- add /etc/valkey/modules drop-in directory for module configuration files
+- add %%valkey_modules_cfg macro
+
+* Mon Jul 7 2025 Remi Collet <remi@fedoraproject.org> - 8.1.3-1
+- update to 8.1.3
+ fixes CVE-2025-CVE-2025-32023 and CVE-2025-48367
+
+* Wed Jun 18 2025 Remi Collet <remi@fedoraproject.org> - 8.1.2-1
+- update to 8.1.2
+ fixes CVE-2025-27151
+
+* Thu Apr 24 2025 Remi Collet <remi@fedoraproject.org> - 8.1.1-1
+- update to 8.1.1
+ fixes CVE-2025-21605
+
+* Fri Apr 04 2025 Nathan Scott <nathans@redhat.com> - 8.1.0-1
+- include tmpfiles.d configuration file
+- redis.log transition rhbz#2316030
+- update to 8.1.0 rhbz#22356280
+
+* Tue Feb 11 2025 Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> - 8.0.2-3
+- Drop call to %sysusers_create_compat
+
+* Sun Jan 19 2025 Fedora Release Engineering <releng@fedoraproject.org> - 8.0.2-2
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_42_Mass_Rebuild
+
+* Wed Jan 08 2025 Jonathan Wright <jonathan@almalinux.org> - 8.0.2-1
+- update to 8.0.2 rhbz#2336259
+ fixes CVE-2024-46981
+ fixes CVE-2024-51741
+
+* Wed Nov 13 2024 Jonathan Wright <jonathan@almalinux.org> - 8.0.1-3
+- include license with doc sub-package
+- include systemd symlinks for redis in compat package
+
+* Mon Oct 07 2024 Jonathan Wright <jonathan@almalinux.org> - 8.0.1-2
+- fix spec for epel8
+- buildrequires python3 for docs
+
+* Mon Oct 07 2024 Jonathan Wright <jonathan@almalinux.org> - 8.0.1-1
+- update to 8.0.1 rhbz#2316254
+ fixes CVE-2024-31449
+ fixes CVE-2024-31227
+ fixes CVE-2024-31228
+
+* Fri Sep 27 2024 Yaakov Selkowitz <yselkowi@redhat.com> - 8.0.0-3
+- Disable docs on RHEL
+
+* Tue Sep 24 2024 Jonathan Wright <jonathan@almalinux.org> - 8.0.0-2
+- add man pages rhbz#2276017
+- add doc subpackage rhbz#2276020
+
+* Mon Sep 16 2024 Jonathan Wright <jonathan@almalinux.org> - 8.0.0-1
+- update to 8.0.0 rhbz#2312577
+
+* Mon Aug 12 2024 Neal Gompa <ngompa@fedoraproject.org> - 7.2.6-2
+- Add compat-redis-devel subpackage for Redis API Valkey modules
+ Resolves: rhbz#2304083
+
+* Mon Aug 05 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.6-1
+- update to 7.2.6 rhbz#2302510
+
+* Thu Aug 1 2024 Remi Collet <rcollet@redhat.com> - 7.2.5-11
+- merge limit.conf in main service files
+- fix obsoletes/conflicts up to 7.4
+
+* Sat Jul 20 2024 Fedora Release Engineering <releng@fedoraproject.org> - 7.2.5-10
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_41_Mass_Rebuild
+
+* Mon Jul 15 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5-9
+- Fix journal warning rhbz#2297457
+
+* Tue Jul 02 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5-8
+- Enable tests by default
+ selectively disable tests that fail in mock for redis
+ disable redis-sentinel tests, they always fail in mock
+
+* Sat Jun 22 2024 Neal Gompa <ngompa@fedoraproject.org> - 7.2.5-7
+- Enable automatic replacement of redis with valkey
+
+* Mon Jun 17 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5-6
+- drop /etc/sysconfig/valkey
+
+* Mon Apr 29 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5-5
+- improve migration scripts
+- rename compat package
+- fix working dir
+
+* Mon Apr 22 2024 Nathan Scott <nathans@redhat.com> - 7.2.5-3
+- remove version_no_tilde code
+
+* Mon Apr 22 2024 Nathan Scott <nathans@redhat.com> - 7.2.5-2
+- move redis compat symlinks to compat subpackage
+
+* Wed Apr 17 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5-1
+- update to 7.2.5 rhbz#2275379
+
+* Fri Apr 12 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5~rc1-2
+- add compat subpackage with migration scripts from redis
+
+* Fri Apr 12 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.5~rc1-1
+- update to 7.2.5-rc1
+
+* Tue Apr 09 2024 Jonathan Wright <jonathan@almalinux.org> - 7.2.4~rc1-1
+- Initial package build, release candidate
diff --git a/valkey.sysusers b/valkey.sysusers
new file mode 100644
index 0000000..94242f3
--- /dev/null
+++ b/valkey.sysusers
@@ -0,0 +1 @@
+u valkey - "Valkey Database Server" /dev/null /sbin/nologin
diff --git a/valkey.tmpfiles b/valkey.tmpfiles
new file mode 100644
index 0000000..2383ddb
--- /dev/null
+++ b/valkey.tmpfiles
@@ -0,0 +1,3 @@
+D /run/valkey 0755 valkey valkey -
+d /var/lib/valkey 0750 valkey valkey -
+d /var/log/valkey 0750 valkey valkey -