From 4da5115e1368ff7a80cf2c1c92546c0c88d16d389e522c8d152958ce5e5c8769 Mon Sep 17 00:00:00 2001 From: "Michal Hrusecky (old before rename to _miska_)" Date: Tue, 20 Nov 2012 12:09:48 +0000 Subject: [PATCH 1/4] Accepting request 140668 from home:vjt:ifad As requested on https://build.opensuse.org/request/show/129485 I've added the required .changes entry. Thanks, ~Marcello OBS-URL: https://build.opensuse.org/request/show/140668 OBS-URL: https://build.opensuse.org/package/show/server:database/redis?expand=0&rev=32 --- redis-conf.patch | 36 +++++--- redis-initscript.patch | 192 +++++++++++++++++++++++++++-------------- redis.changes | 17 ++++ redis.spec | 15 +++- 4 files changed, 179 insertions(+), 81 deletions(-) diff --git a/redis-conf.patch b/redis-conf.patch index 413fb72..4af1928 100644 --- a/redis-conf.patch +++ b/redis-conf.patch @@ -1,12 +1,6 @@ ---- - redis.conf | 10 +++++----- - 1 file changed, 5 insertions(+), 5 deletions(-) - -Index: redis.conf -=================================================================== ---- redis.conf.orig 2011-10-17 10:46:00.000000000 +0200 -+++ redis.conf 2011-10-24 12:47:49.839930573 +0200 -@@ -14,7 +14,7 @@ +--- redis.conf.orig 2012-07-31 16:56:02.000000000 +0200 ++++ redis.conf 2012-07-31 16:59:31.000000000 +0200 +@@ -14,11 +14,11 @@ # By default Redis does not run as a daemon. Use 'yes' if you need it. # Note that Redis will write a pid file in /var/run/redis.pid when daemonized. @@ -15,7 +9,12 @@ Index: redis.conf # When running daemonized, Redis writes a pid file in /var/run/redis.pid by # default. You can specify a custom pid file location here. -@@ -27,7 +27,7 @@ port 6379 +-pidfile /var/run/redis.pid ++pidfile /var/run/redis/default.pid + + # Accept connections on the specified port, default is 6379. + # If port 0 is specified Redis will not listen on a TCP socket. +@@ -27,7 +27,7 @@ # If you want you can bind a single interface, if the bind option is not # specified all the interfaces will listen for incoming connections. # @@ -24,7 +23,7 @@ Index: redis.conf # Specify the path for the unix socket that will be used to listen for # incoming connections. There is no default, so Redis will not listen -@@ -45,12 +45,12 @@ timeout 300 +@@ -45,12 +45,12 @@ # verbose (many rarely useful info, but not a mess like the debug level) # notice (moderately verbose, what you want in production probably) # warning (only very important / critical messages are logged) @@ -35,16 +34,25 @@ Index: redis.conf # Redis 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 stdout -+logfile /var/log/redis/redis.log ++logfile /var/log/redis/default.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. -@@ -104,7 +104,7 @@ dbfilename dump.rdb +@@ -104,7 +104,7 @@ # Also the Append Only File will be created inside this directory. # # Note that you must specify a directory here, not a file name. -dir ./ -+dir /var/lib/redis/ ++dir /var/lib/redis/default/ ################################# REPLICATION ################################# +@@ -386,7 +386,7 @@ + # *** WARNING *** if you are using a shared hosting the default of putting + # the swap file under /tmp is not secure. Create a dir with access granted + # only to Redis user and configure Redis to create the swap file there. +-vm-swap-file /tmp/redis.swap ++vm-swap-file /var/lib/redis/default/redis.swap + + # vm-max-memory configures the VM to use at max the specified amount of + # RAM. Everything that deos not fit will be swapped on disk *if* possible, that diff --git a/redis-initscript.patch b/redis-initscript.patch index a8365c9..d8397ac 100644 --- a/redis-initscript.patch +++ b/redis-initscript.patch @@ -1,39 +1,120 @@ -Index: utils/redis_init_script -=================================================================== ---- utils/redis_init_script.orig 2011-10-17 10:46:00.000000000 +0200 -+++ utils/redis_init_script 2011-10-24 12:47:43.108960720 +0200 -@@ -1,42 +1,75 @@ +--- utils/redis_init_script.orig 2012-07-31 16:48:33.000000000 +0200 ++++ utils/redis_init_script 2012-11-08 17:36:19.000000000 +0100 +@@ -1,42 +1,131 @@ #!/bin/sh ++ ++# System startup script for Redis for OpenSUSE >= 11.4 ++# ++# Author: Marcello Barnaba ++# Tue Jul 31 17:32:27 CEST 2012 ++# ++# LSB-compatible service control script; see http://www.linuxbase.org/spec/ ++# Install it in /etc/init.d/redis and run insserv /etc/init.d/redis ++# Define configurations in /etc/init.d/redis/NAME.conf ++# ++# Source: https://gist.github.com/804026 # -# Simple Redis init.d script conceived to work on Linux systems -# as it does use of the /proc filesystem. -+# /etc/init.d/redis -+# +### BEGIN INIT INFO +# Provides: redis +# Required-Start: $syslog $remote_fs -+# Should-Start: +# Required-Stop: $syslog $remote_fs -+# Should-Stop: +# Default-Start: 3 5 +# Default-Stop: 0 1 2 6 +# Short-Description: Redis server -+# Description: Starts and stops the Redis daemon ++# Description: Starts and stops the configured Redis instances +### END INIT INFO + ++EXEC=/usr/sbin/redis-server ++USER=redis ++STATE=/var/run/redis ++CONF=/etc/redis ++ +. /etc/rc.status ++ ++if [ ! -d $STATE ]; then ++ install -d $state -o $USER -g $USER -m 0755 $STATE ++fi ++ ++_get_env() { ++ INSTANCE=$1 ++ PIDFILE=${STATE}/${INSTANCE}.pid ++ CONFIG=${CONF}/${INSTANCE}.conf ++} ++ ++_foreach_config() { ++ command=$1 ++ ++ if [ -n "$2" ]; then ++ $command $2 ++ else ++ for file in /etc/redis/*.conf; do ++ $command `basename $file | sed 's#\.conf##'` # dirty ++ done ++ fi ++} ++ ++start() { ++ _get_env $1 ++ ++ echo -n "Starting Redis server '${INSTANCE}'... " ++ ++ if [ ! -f ${CONFIG} ]; then ++ echo "$CONFIG not found" ++ rc_failed - REDISPORT=6379 +-REDISPORT=6379 -EXEC=/usr/local/bin/redis-server -CLIEXEC=/usr/local/bin/redis-cli -+EXEC=/usr/sbin/redis-server -+CLIEXEC=/usr/bin/redis-cli ++ elif [ -f ${PIDFILE} ] && [ -x /proc/`cat ${PIDFILE}` ]; then ++ echo -n "already running (PID `cat ${PIDFILE}`)" ++ ++ else ++ rm -f ${PIDFILE} ++ sudo -u $USER $EXEC $CONFIG ++ fi ++ rc_status -v ++} ++ ++stop() { ++ _get_env $1 ++ ++ echo -n "Stopping Redis server '${INSTANCE}' ... " ++ ++ if [ ! -f $PIDFILE ]; then ++ echo -n "not running" ++ else ++ PID=`cat $PIDFILE` ++ CLI='/usr/bin/redis-cli' ++ PASS=`grep ^requirepass $CONFIG | awk '{print $2}'` ++ PORT=`grep ^port $CONFIG | awk '{print $2}'` ++ ++ CLI="$CLI -p $PORT" ++ [ -n "$PASS" ] && CLI="$CLI -a $PASS" ++ ++ $CLI shutdown ++ echo -n "Waiting... " ++ ++ while [ -x /proc/${PID} ]; do ++ sleep 1 ++ echo -n '.' ++ done ++ rm -f ${PIDFILE} ++ fi ++ rc_status -v ++} ++ ++status() { ++ _get_env $1 ++ ++ echo -n "Checking for redis '${INSTANCE}'" ++ /sbin/checkproc -p $PIDFILE $EXEC ++ rc_status -v ++} -PIDFILE=/var/run/redis_${REDISPORT}.pid -CONF="/etc/redis/${REDISPORT}.conf" -+CONF=/etc/redis.conf -+PIDFILE=/var/run/redis.pid -+LOGFILE=/var/log/redis/redis.log case "$1" in start) @@ -43,58 +124,43 @@ Index: utils/redis_init_script - else - echo "Starting Redis server..." - $EXEC $CONF -+ if [ ! -r $LOGFILE ]; then -+ touch $LOGFILE -+ chown redis:redis $LOGFILE -+ fi -+ # Create a pidfile the server can write into. -+ if [ ! -r $PIDFILE ]; then -+ touch $PIDFILE -+ chown redis:redis $PIDFILE - fi -+ echo -n "Starting service Redis " -+ /sbin/startproc -u redis -g redis -p $PIDFILE -s -e $EXEC $CONF >/dev/null 2>&1 -+ rc_status -v - ;; +- fi +- ;; ++ _foreach_config start $2 ++ ;; ++ stop) - if [ ! -f $PIDFILE ] - then +- if [ ! -f $PIDFILE ] +- then - echo "$PIDFILE does not exist, process is not running" -+ echo -n "$PIDFILE does not exist, process is not running" -+ rc_failed - else +- else - PID=$(cat $PIDFILE) - echo "Stopping ..." -+ echo -n "Stopping service Redis..." - $CLIEXEC -p $REDISPORT shutdown +- $CLIEXEC -p $REDISPORT shutdown - while [ -x /proc/${PID} ] -+ PID=$(cat $PIDFILE) -+ while [ -x /proc/${PIDFILE} ] - do +- do - echo "Waiting for Redis to shutdown ..." - sleep 1 - done +- sleep 1 +- done - echo "Redis stopped" - fi -+ rc_status -v - ;; -- *) -- echo "Please use start or stop as first argument" -+ restart) -+ $0 stop -+ $0 start - ;; -+ reload) -+ $0 restart -+ ;; -+ status) -+ echo -n "Checking for service Redis: " -+ /sbin/checkproc -p $PIDFILE $EXEC -+ rc_status -v -+ ;; -+ *) -+ echo $"Usage: $0 {start|stop|status|restart|reload}" -+ exit 1 - esac -+rc_exit +- fi +- ;; ++ _foreach_config stop $2 ++ ;; + ++ status) ++ _foreach_config status $2 ++ ;; ++ ++ restart) ++ $0 stop $2 ++ $0 start $2 ++ ;; ++ + *) +- echo "Please use start or stop as first argument" +- ;; ++ echo "Usage: $0 " ++ exit 1 ++ ;; + esac diff --git a/redis.changes b/redis.changes index 0175dac..143fbb4 100644 --- a/redis.changes +++ b/redis.changes @@ -1,3 +1,20 @@ +------------------------------------------------------------------- +Thu Nov 8 16:12:21 UTC 2012 - vjt@openssl.it + +- Implement a multi-instance setup + * Allow for multiple configuration files of named instances + under /etc/redis + * Each instance has its own data directory + under /var/lib/redis/$INSTANCE + * Each instance has its own PID file + under /var/run/redis/$INSTANCE.pid + * Each instance has its own log files + under /var/log/redis/$INSTANCE.log + * Instances may be started or stopped individually passing a + second argument to the init script + * Do not create an active default.conf, rather use an + .example suffix + ------------------------------------------------------------------- Mon Jul 23 18:11:50 UTC 2012 - mrueckert@suse.de diff --git a/redis.spec b/redis.spec index adec4c0..3dd03b9 100644 --- a/redis.spec +++ b/redis.spec @@ -18,6 +18,7 @@ %define _data_dir %{_localstatedir}/lib/%{name} %define _log_dir %{_localstatedir}/log/%{name} +%define _conf_dir %{_sysconfdir}/%{name} Name: redis Version: 2.4.15 @@ -68,14 +69,16 @@ different kind of sorting abilities. make %{?_smp_mflags} CFLAGS="%{optflags}" V=1 %install -install -d %{buildroot}%{_log_dir} %{buildroot}%{_data_dir} +install -d %{buildroot}%{_log_dir} %{buildroot}%{_data_dir} %{buildroot}%{_conf_dir} +install -d %{buildroot}%{_log_dir}/default %{buildroot}%{_data_dir}/default install -D -m 0755 src/redis-benchmark %{buildroot}%{_bindir}/redis-benchmark install -m 0755 src/redis-cli %{buildroot}%{_bindir}/redis-cli install -m 0755 src/redis-check-dump %{buildroot}%{_bindir}/redis-check-dump install -m 0755 src/redis-check-aof %{buildroot}%{_bindir}/redis-check-aof install -D -m 0755 src/redis-server %{buildroot}%{_sbindir}/redis-server -install -D -m 0640 redis.conf %{buildroot}%{_sysconfdir}/redis.conf + +install -D -m 0640 redis.conf %{buildroot}%{_conf_dir}/default.conf.example ## install -Dp -m 0755 %{SOURCE4} %{buildroot}%{_sysconfdir}/sysconfig/redis # @@ -107,7 +110,9 @@ make test && true %post %fillup_and_insserv %{name} %restart_on_update %{name} -echo "To start the database server, do:" +echo "To start the database server, create your configuration" +echo "starting from /etc/redis/default.conf.example, place it" +echo "in /etc/redis and do: " echo " sudo rcredis start; sudo insserv redis" %preun @@ -125,8 +130,10 @@ echo " sudo rcredis start; sudo insserv redis" %{_sbindir}/redis-* %{_sbindir}/rc%{name} %config(noreplace) %{_sysconfdir}/init.d/redis -%config(noreplace) %attr(0640, %{name}, %{name}) %{_sysconfdir}/redis.conf +%config(noreplace) %attr(0640, %{name}, %{name}) %{_conf_dir}/default.conf.example %dir %attr(0750, %{name}, %{name}) %{_data_dir} +%dir %attr(0750, %{name}, %{name}) %{_data_dir}/default %dir %attr(0750, %{name}, %{name}) %{_log_dir} +%dir %attr(0750, %{name}, %{name}) %{_conf_dir} %changelog From a2402683ee1ec39eddb7b029206beb080fbe98a158f87225069ff580a21a5f07 Mon Sep 17 00:00:00 2001 From: "Michal Hrusecky (old before rename to _miska_)" Date: Tue, 20 Nov 2012 12:11:57 +0000 Subject: [PATCH 2/4] little nicer OBS-URL: https://build.opensuse.org/package/show/server:database/redis?expand=0&rev=33 --- redis-initscript.patch | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/redis-initscript.patch b/redis-initscript.patch index d8397ac..a3153b8 100644 --- a/redis-initscript.patch +++ b/redis-initscript.patch @@ -50,7 +50,7 @@ + $command $2 + else + for file in /etc/redis/*.conf; do -+ $command `basename $file | sed 's#\.conf##'` # dirty ++ $command `basename -s .conf "$file"` + done + fi +} From 31395fb8ec803f7083297875e29f08f8a47946522198869d4f4055fe417064e2 Mon Sep 17 00:00:00 2001 From: "Michal Hrusecky (old before rename to _miska_)" Date: Tue, 20 Nov 2012 12:16:16 +0000 Subject: [PATCH 3/4] - Fix useradd invocation: -o is useless without -u and newer versions of pwdutils/shadowutils fail on this now. OBS-URL: https://build.opensuse.org/package/show/server:database/redis?expand=0&rev=34 --- redis.changes | 6 ++++++ redis.spec | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/redis.changes b/redis.changes index 143fbb4..a54ae2d 100644 --- a/redis.changes +++ b/redis.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Tue Nov 20 07:40:52 UTC 2012 - dimstar@opensuse.org + +- Fix useradd invocation: -o is useless without -u and newer + versions of pwdutils/shadowutils fail on this now. + ------------------------------------------------------------------- Thu Nov 8 16:12:21 UTC 2012 - vjt@openssl.it diff --git a/redis.spec b/redis.spec index 3dd03b9..64eb4fc 100644 --- a/redis.spec +++ b/redis.spec @@ -105,7 +105,7 @@ make test && true %pre /usr/sbin/groupadd -r %{name} &>/dev/null || : -/usr/sbin/useradd -o -g %{name} -s /bin/false -r -c "User for Redis key-value store" -d %{_data_dir} %{name} &>/dev/null || : +/usr/sbin/useradd -g %{name} -s /bin/false -r -c "User for Redis key-value store" -d %{_data_dir} %{name} &>/dev/null || : %post %fillup_and_insserv %{name} From 94c6b971e6df16fc8ac293dd064b4cefaf1df70802ecb2f51f14340faa7e69f9 Mon Sep 17 00:00:00 2001 From: "Michal Hrusecky (old before rename to _miska_)" Date: Tue, 20 Nov 2012 14:14:50 +0000 Subject: [PATCH 4/4] Accepting request 142125 from home:vjt:ifad Hi, the basename "-s" option is not available on OpenSUSE 11's coreutils. I have changed the initscript to use the historical basename NAME [SUFFIX] syntax, that works on both 11 and 12. Thanks! ~Marcello OBS-URL: https://build.opensuse.org/request/show/142125 OBS-URL: https://build.opensuse.org/package/show/server:database/redis?expand=0&rev=35 --- redis-initscript.patch | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/redis-initscript.patch b/redis-initscript.patch index a3153b8..9787890 100644 --- a/redis-initscript.patch +++ b/redis-initscript.patch @@ -1,5 +1,5 @@ --- utils/redis_init_script.orig 2012-07-31 16:48:33.000000000 +0200 -+++ utils/redis_init_script 2012-11-08 17:36:19.000000000 +0100 ++++ utils/redis_init_script 2012-11-20 15:05:55.000000000 +0100 @@ -1,42 +1,131 @@ #!/bin/sh + @@ -50,7 +50,7 @@ + $command $2 + else + for file in /etc/redis/*.conf; do -+ $command `basename -s .conf "$file"` ++ $command `basename "$file" .conf` + done + fi +}