network/etcd: Added (key value store for shared configuration).

Signed-off-by: David Spencer <idlemoor@slackbuilds.org>
This commit is contained in:
Thibaut Notteboom 2018-07-23 22:12:25 +01:00 committed by Willy Sudiarto Raharjo
parent a89d29f0f8
commit 819088b4aa
No known key found for this signature in database
GPG Key ID: 887B8374D7333381
8 changed files with 238 additions and 0 deletions

16
network/etcd/README Normal file
View File

@ -0,0 +1,16 @@
Etcd is a distributed reliable key-value store for the most critical
data of a distributed system, with a focus on being:
Simple: well-defined, user-facing API (gRPC)
Secure: automatic TLS with optional client cert authentication
Fast: benchmarked 10,000 writes/sec
Reliable: properly distributed using Raft
Groupname and Username
You must have the 'etcd' group and user to run this script,
for example:
groupadd -g 355 etcd
useradd -d /var/lib/etcd -s /bin/sh -u 355 -g etcd etcd
For some basic setup instructions, check the included 'README.SBo'.

16
network/etcd/README.SBo Normal file
View File

@ -0,0 +1,16 @@
README.SBo
==========
To start etcd automatically at system startup, add the following to
your /etc/rc.d/rc.local:
if [ -x /etc/rc.d/rc.etcd ]; then
/etc/rc.d/rc.etcd start
fi
To stop etcd automatically at system shutdown, add the following to
your /etc/rc.d/rc.local_shutdown:
if [ -x /etc/rc.d/rc.etcd ]; then
/etc/rc.d/rc.etcd stop
fi

27
network/etcd/doinst.sh Normal file
View File

@ -0,0 +1,27 @@
config() {
NEW="$1"
OLD="$(dirname $NEW)/$(basename $NEW .new)"
# If there's no config file by that name, mv it over:
if [ ! -r $OLD ]; then
mv $NEW $OLD
elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then
# toss the redundant copy
rm $NEW
fi
# Otherwise, we leave the .new copy for the admin to consider...
}
preserve_perms() {
NEW="$1"
OLD="$(dirname $NEW)/$(basename $NEW .new)"
if [ -e $OLD ]; then
cp -a $OLD ${NEW}.incoming
cat $NEW > ${NEW}.incoming
mv ${NEW}.incoming $NEW
fi
config $NEW
}
preserve_perms etc/rc.d/rc.etcd.new
config etc/etcd/etcd.conf.yml.new
config etc/logrotate.d/etcd.new

View File

@ -0,0 +1,106 @@
#!/bin/sh
# Slackware build script for etcd
# Copyright 2018 Thibaut Notteboom, Paris, FRANCE
# All rights reserved.
#
# Redistribution and use of this script, with or without modification, is
# permitted provided that the following conditions are met:
#
# 1. Redistributions of this script must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
PRGNAM=etcd
VERSION=${VERSION:-3.3.8}
BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
if [ -z "$ARCH" ]; then
case "$( uname -m )" in
i?86) ARCH=i586 ;;
arm*) ARCH=arm ;;
*) ARCH=$( uname -m ) ;;
esac
fi
CWD=$(pwd)
TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp}
if [ "$ARCH" = "i586" ]; then
SLKCFLAGS="-O2 -march=i586 -mtune=i686"
LIBDIRSUFFIX=""
elif [ "$ARCH" = "i686" ]; then
SLKCFLAGS="-O2 -march=i686 -mtune=i686"
LIBDIRSUFFIX=""
elif [ "$ARCH" = "x86_64" ]; then
SLKCFLAGS="-O2 -fPIC"
LIBDIRSUFFIX="64"
else
SLKCFLAGS="-O2"
LIBDIRSUFFIX=""
fi
set -e
if [ "$(grep ^etcd /etc/passwd)" = "" -o "$(grep ^etcd /etc/group)" = "" ] ; then
printf "\nYou must have a etcd user and group.\n\nExample:\n"
printf "\t# groupadd -g 355 etcd\n"
printf "\t# useradd -d /var/lib/etcd -s /bin/sh -u 355 -g etcd etcd\n\n"
exit 1
fi
rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
cd $TMP
rm -rf $PRGNAM-$VERSION
tar xvf $CWD/$PRGNAM-$VERSION.tar.gz
cd $PRGNAM-$VERSION
chown -R root:root .
find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
-o -perm 511 \) -exec chmod 755 {} \; -o \
\( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
-o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
./build
install -Dm755 bin/etcd $PKG/usr/bin/etcd
install -Dm755 bin/etcdctl $PKG/usr/bin/etcdctl
install -Dm644 etcd.conf.yml.sample $PKG/etc/etcd/etcd.conf.yml.new
install -Dm644 $CWD/rc.etcd $PKG/etc/rc.d/rc.etcd.new
install -Dm644 $CWD/etcd.logrotate $PKG/etc/logrotate.d/etcd.new
install -o etcd -g etcd -d $PKG/var/lib/etcd
install -o etcd -g etcd -d $PKG/var/log/etcd
find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
cp -a \
LICENSE Documentation/* \
$PKG/usr/doc/$PRGNAM-$VERSION
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
cat $CWD/README.SBo > $PKG/usr/doc/$PRGNAM-$VERSION/README.SBo
mkdir -p $PKG/install
cat $CWD/slack-desc > $PKG/install/slack-desc
cat $CWD/doinst.sh > $PKG/install/doinst.sh
cd $PKG
/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}

10
network/etcd/etcd.info Normal file
View File

@ -0,0 +1,10 @@
PRGNAM="etcd"
VERSION="3.3.8"
HOMEPAGE="https://github.com/coreos/etcd"
DOWNLOAD="https://github.com/coreos/etcd/archive/v3.3.8/etcd-3.3.8.tar.gz"
MD5SUM="f300d08cbb6ebe6572eee9191127547a"
DOWNLOAD_x86_64=""
MD5SUM_x86_64=""
REQUIRES="google-go-lang"
MAINTAINER="Thibaut Notteboom"
EMAIL="thibaut.notteboom@gmail.com"

View File

@ -0,0 +1,7 @@
/var/log/etcd/etcd.log {
copytruncate
daily
rotate 7
compress
missingok
}

37
network/etcd/rc.etcd Normal file
View File

@ -0,0 +1,37 @@
#!/bin/sh
ETCD_USER=etcd
ETCD_BIN=/usr/bin/etcd
ETCD_LOG_FILE=/var/log/etcd/etcd.log
ETCD_CONFIG_FILE=/etc/etcd/etcd.conf.yml
etcd_start() {
echo "Starting the etcd service: $ETCD_BIN"
su - $ETCD_USER -c "$ETCD_BIN --config-file $ETCD_CONFIG_FILE >> $ETCD_LOG_FILE 2>&1 &"
}
etcd_stop() {
echo "Stoping the etcd service: $ETCD_BIN"
killall etcd
}
etcd_restart() {
etcd_stop
sleep 1
etcd_start
}
case "$1" in
'start')
etcd_start
;;
'stop')
etcd_stop
;;
'restart')
etcd_restart
;;
*)
echo "Usage: $0 start|stop|restart"
;;
esac

19
network/etcd/slack-desc Normal file
View File

@ -0,0 +1,19 @@
# HOW TO EDIT THIS FILE:
# The "handy ruler" below makes it easier to edit a package description.
# Line up the first '|' above the ':' following the base package name, and
# the '|' on the right side marks the last column you can put a character in.
# You must make exactly 11 lines for the formatting to be correct. It's also
# customary to leave one space after the ':' except on otherwise blank lines.
|-----handy-ruler------------------------------------------------------|
etcd: etcd (key value store for shared configuration and service discovery)
etcd:
etcd: Etcd is a distributed reliable key-value store for the most critical
etcd: data of a distributed system, with a focus on being:
etcd: Simple: well-defined, user-facing API (gRPC)
etcd: Secure: automatic TLS with optional client cert authentication
etcd: Fast: benchmarked 10,000 writes/sec
etcd: Reliable: properly distributed using Raft
etcd:
etcd:
etcd: