diff options
author | Yagnesh Mistry <ysh@live.in> | 2015-10-22 01:32:34 +0530 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2015-11-04 09:48:58 +0000 |
commit | 14113e0aa36b56f220344b668d9e49ac13627455 (patch) | |
tree | 0509053c9f71cbbd92119ca874e8e88deaaab91f /testing/twemproxy | |
parent | b87e908ccb951a69a50e22b433816a01f6ba0ee4 (diff) | |
download | aports-14113e0aa36b56f220344b668d9e49ac13627455.tar.bz2 aports-14113e0aa36b56f220344b668d9e49ac13627455.tar.xz |
testing/twemproxy: new aport
https://github.com/twitter/twemproxy
A fast, light-weight proxy for memcached and redis
Diffstat (limited to 'testing/twemproxy')
-rw-r--r-- | testing/twemproxy/APKBUILD | 85 | ||||
-rw-r--r-- | testing/twemproxy/nutcracker.confd | 5 | ||||
-rw-r--r-- | testing/twemproxy/nutcracker.initd | 42 | ||||
-rw-r--r-- | testing/twemproxy/use-system-libyaml.patch | 60 |
4 files changed, 192 insertions, 0 deletions
diff --git a/testing/twemproxy/APKBUILD b/testing/twemproxy/APKBUILD new file mode 100644 index 0000000000..fc829d63ce --- /dev/null +++ b/testing/twemproxy/APKBUILD @@ -0,0 +1,85 @@ +# Maintainer: Yagnesh Mistry <ysh@live.in> + +pkgname=twemproxy +akaname=nutcracker +pkgver=0.4.1 +pkgrel=0 +pkgdesc="A fast, light-weight proxy for memcached and redis" +url="https://github.com/twitter/twemproxy" +arch="all" +license="ASL 2.0" +depends="yaml" +depends_dev="" +makedepends="automake autoconf libtool yaml-dev" +subpackages="$pkgname-doc" +source="saveas-https://github.com/twitter/twemproxy/archive/v$pkgver.tar.gz/$pkgname-$pkgver.tar.gz + nutcracker.initd + nutcracker.confd + use-system-libyaml.patch + " + +_builddir="$srcdir"/$pkgname-$pkgver +_logdir=/var/log/$akaname +_rundir=/var/run/$akaname + +prepare() { + local i + cd "$_builddir" + for i in $source; do + case $i in + *.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;; + esac + done +} + +build() { + cd "$_builddir" + autoreconf -vif + ./configure \ + --build=$CBUILD \ + --host=$CHOST \ + --prefix=/usr \ + || return 1 + make || return 1 +} + +package() { + cd "$_builddir" + make DESTDIR="$pkgdir" install || return 1 + install -m644 -D "$srcdir"/$pkgname-$pkgver/conf/nutcracker.yml \ + "$pkgdir"/etc/$akaname/nutcracker.yml || return 1 + install -m644 -D "$srcdir"/$pkgname-$pkgver/conf/nutcracker.leaf.yml \ + "$pkgdir"/etc/$akaname/nutcracker.leaf.yml || return 1 + install -m644 -D "$srcdir"/$pkgname-$pkgver/conf/nutcracker.root.yml \ + "$pkgdir"/etc/$akaname/nutcracker.root.yml || return 1 + install -m755 -D "$srcdir"/$akaname.initd \ + "$pkgdir"/etc/init.d/$akaname || return 1 + install -m644 -D "$srcdir"/$akaname.confd \ + "$pkgdir"/etc/conf.d/$akaname || return 1 + + install -m0755 -d "$pkgdir"/$_rundir || return 1 + install -m0755 -d "$pkgdir"/$_logdir || return 1 + + _docs="README.md NOTICE ChangeLog" + for _doc in $_docs; do + install -m644 -D "$srcdir"/$pkgname-$pkgver/$_doc \ + "$pkgdir"/usr/share/doc/$akaname/$_doc || return 1 + done + + install -m644 -D "$srcdir"/$pkgname-$pkgver/LICENSE \ + "$pkgdir"/usr/share/licenses/$akaname/LICENSE || return 1 + +} + +md5sums="6b27455285f81e4335d00983076cf4b8 twemproxy-0.4.1.tar.gz +531b2ded35c9f9e3c53388ceb9da9e9d nutcracker.initd +5fcf33052bb7ddd286e58fcdef5335db nutcracker.confd +521837066110c2d0248c11620bf66e15 use-system-libyaml.patch" +sha256sums="00c2940f91947bea9457a348316aac1aa1d4e757238aafbefc9d51057da8ede0 twemproxy-0.4.1.tar.gz +f6531c2bbb085e70e4de4b51a01e4b2a6fe6cec41ba4924cc7ac56d51393fdfd nutcracker.initd +ff28c0ffb1aa82e7bcd19c79f76cdb05641b4181f6668349fe9ed87044ce0d3e nutcracker.confd +718fe0cf3a48f51f5b8a2b6ef8120068b1604c7588b33e5db27de8301e77fdf4 use-system-libyaml.patch" +sha512sums="581fae1d12feb983ed25b22cd6f597fd28b7070906ac29d3990669ae5c626a468914021cee152a6a2299a2838c838ad907e4c911b911ef04166ac7bbb2982da1 twemproxy-0.4.1.tar.gz +56bc051eac972cc1e4cfb334673f8e4c8a5f0855fb4f0b66e05a148855dae34870d949a5d19c111d072a0405b2014a334151ad9414a40fdc67e559ff37d68093 nutcracker.initd +e69e6d7b48a360b8b7b7ec7d7d46e2c736c4e30e6d6a22ed5b01d64ccb3ec701537545b2b6e5c1cbf2ba9f657f86e7a94686e3dc8a43dcba9688695717d62f12 nutcracker.confd +beadf407de53378bfe0ee12bbdf2315bde220a322aa13fc1993b487e1503f8825280408c500c902db683ee35b255e304acfe2cb011a6e9ffe02cdbfcfb1d2bf5 use-system-libyaml.patch" diff --git a/testing/twemproxy/nutcracker.confd b/testing/twemproxy/nutcracker.confd new file mode 100644 index 0000000000..95efa6b189 --- /dev/null +++ b/testing/twemproxy/nutcracker.confd @@ -0,0 +1,5 @@ +CONFFILE=/etc/nutcracker/nutcracker.yml +PIDFILE=/var/run/nutcracker/nutcracker.pid +LOGFILE=/var/log/nutcracker/nutcracker.log + +DAEMON_ARGS="-c $CONFFILE -o $LOGFILE -p $PIDFILE -d" diff --git a/testing/twemproxy/nutcracker.initd b/testing/twemproxy/nutcracker.initd new file mode 100644 index 0000000000..76d120a779 --- /dev/null +++ b/testing/twemproxy/nutcracker.initd @@ -0,0 +1,42 @@ +#!/sbin/openrc-run + +NAME="nutcracker" +DAEMON=/usr/sbin/nutcracker +USER="${USER:-nobody}" +CONFFILE="${CONFFILE:-/etc/nutcracker/nutcracker.yml}" + +DAEMON_ARGS=${DAEMON_ARGS:-"-c $CONFFILE -o $LOGFILE -p $PIDFILE -d"} + +depend() { + need net + after firewall +} + +checkconf() { + ebegin "Testing configuration: " + ${DAEMON} --test-conf \ + --conf-file=${CONFFILE} \ + >/dev/null 2>&1 + eend $? +} + + +start() { + checkconf || exit 1 + ebegin "Starting ${NAME}: " + start-stop-daemon --start --quiet \ + --pidfile ${PIDFILE} \ + --chuid ${USER}:${USER} \ + --exec ${DAEMON} -- ${DAEMON_ARGS} + eend $? +} + +stop() { + ebegin "Stopping ${NAME}: " + start-stop-daemon --stop --quiet \ + --pidfile ${PIDFILE} \ + --exec ${DAEMON} + eend $? +} + + diff --git a/testing/twemproxy/use-system-libyaml.patch b/testing/twemproxy/use-system-libyaml.patch new file mode 100644 index 0000000000..e3ec54a15a --- /dev/null +++ b/testing/twemproxy/use-system-libyaml.patch @@ -0,0 +1,60 @@ +--- twemproxy-0.4.1/Makefile.am ++++ twemproxy/src/twemproxy-0.4.1/Makefile.am +@@ -2,7 +2,7 @@ + + ACLOCAL_AMFLAGS = -I m4 + +-SUBDIRS = contrib src ++SUBDIRS = src + + dist_man_MANS = man/nutcracker.8 + +--- twemproxy-0.4.1/configure.ac ++++ twemproxy/src/twemproxy-0.4.1/configure.ac +@@ -75,6 +75,14 @@ + # Checks for libraries + AC_CHECK_LIB([m], [pow]) + AC_CHECK_LIB([pthread], [pthread_create]) ++AC_CHECK_LIB([yaml], [yaml_get_version_string],,LIBYAML="no") ++if test "$LIBYAML" = "no"; then ++ echo ++ echo " Error: libyaml library not found." ++ echo " Run apk add yaml-dev" ++ echo ++ exit 1 ++fi + + # Checks for library functions + AC_FUNC_FORK +@@ -196,15 +204,8 @@ + [AC_DEFINE([HAVE_STATS], [1], [Define to 1 if stats is not disabled])]) + AC_MSG_RESULT($disable_stats) + +-# Untar the yaml-0.1.4 in contrib/ before config.status is rerun +-AC_CONFIG_COMMANDS_PRE([tar xvfz contrib/yaml-0.1.4.tar.gz -C contrib]) +- +-# Call yaml-0.1.4 ./configure recursively +-AC_CONFIG_SUBDIRS([contrib/yaml-0.1.4]) +- + # Define Makefiles + AC_CONFIG_FILES([Makefile +- contrib/Makefile + src/Makefile + src/hashkit/Makefile + src/proto/Makefile +--- twemproxy-0.4.1/src/Makefile.am ++++ twemproxy/src/twemproxy-0.4.1/src/Makefile.am +@@ -21,7 +21,7 @@ + AM_CFLAGS += -Wstrict-prototypes -Wmissing-prototypes -Wredundant-decls -Wmissing-declarations + + AM_LDFLAGS = +-AM_LDFLAGS += -lm -lpthread -rdynamic ++AM_LDFLAGS += -lm -lpthread -lyaml -rdynamic + if OS_SOLARIS + AM_LDFLAGS += -lnsl -lsocket + endif +@@ -57,4 +57,3 @@ + nutcracker_LDADD = $(top_builddir)/src/hashkit/libhashkit.a + nutcracker_LDADD += $(top_builddir)/src/proto/libproto.a + nutcracker_LDADD += $(top_builddir)/src/event/libevent.a +-nutcracker_LDADD += $(top_builddir)/contrib/yaml-0.1.4/src/.libs/libyaml.a |