mirror of
https://github.com/openembedded/meta-openembedded.git
synced 2026-05-07 17:19:23 +00:00
collectd: add recipe for 5.2.2
Based on initial version by Koen Kooi <koen@beagleboard.org>. Initscript borrowed from Debian with some tweaks. Note that since collectd uses libltdl, building this successfully required OE-Core commit db84eaf851b22b262d9dc48eb55bd5224a00fdd2 or else you get an error about "config/compile" being missing. Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com> Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
This commit is contained in:
committed by
Martin Jansa
parent
9e7327e446
commit
2fc71a181e
@@ -0,0 +1,31 @@
|
|||||||
|
Don't pick up version string from parent git repository
|
||||||
|
|
||||||
|
If the collectd source is extracted from a tarball underneath a
|
||||||
|
directory structure that includes another git repository, that
|
||||||
|
repository will be picked up by "git describe" which is not
|
||||||
|
desirable. Check whether collectd itself is a git repository and just
|
||||||
|
use the default version if not.
|
||||||
|
|
||||||
|
Upstream-Status: Pending
|
||||||
|
|
||||||
|
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
|
||||||
|
|
||||||
|
diff --git a/version-gen.sh b/version-gen.sh
|
||||||
|
index e344541..d1c0929 100755
|
||||||
|
--- a/version-gen.sh
|
||||||
|
+++ b/version-gen.sh
|
||||||
|
@@ -2,7 +2,10 @@
|
||||||
|
|
||||||
|
DEFAULT_VERSION="5.2.2.git"
|
||||||
|
|
||||||
|
-VERSION="`git describe 2> /dev/null | sed -e 's/^collectd-//'`"
|
||||||
|
+VERSION=""
|
||||||
|
+if test -d .git ; then
|
||||||
|
+ VERSION="`git describe 2> /dev/null | sed -e 's/^collectd-//'`"
|
||||||
|
+fi
|
||||||
|
|
||||||
|
if test -z "$VERSION"; then
|
||||||
|
VERSION="$DEFAULT_VERSION"
|
||||||
|
--
|
||||||
|
1.7.10.4
|
||||||
|
|
||||||
@@ -0,0 +1,201 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# collectd - start and stop the statistics collection daemon
|
||||||
|
# http://collectd.org/
|
||||||
|
#
|
||||||
|
# Copyright (C) 2005-2006 Florian Forster <octo@verplant.org>
|
||||||
|
# Copyright (C) 2006-2009 Sebastian Harl <tokkee@debian.org>
|
||||||
|
#
|
||||||
|
|
||||||
|
### BEGIN INIT INFO
|
||||||
|
# Provides: collectd
|
||||||
|
# Required-Start: $local_fs $remote_fs
|
||||||
|
# Required-Stop: $local_fs $remote_fs
|
||||||
|
# Should-Start: $network $named $syslog $time cpufrequtils
|
||||||
|
# Should-Stop: $network $named $syslog
|
||||||
|
# Default-Start: 2 3 4 5
|
||||||
|
# Default-Stop: 0 1 6
|
||||||
|
# Short-Description: manage the statistics collection daemon
|
||||||
|
# Description: collectd is the statistics collection daemon.
|
||||||
|
# It is a small daemon which collects system information
|
||||||
|
# periodically and provides mechanisms to monitor and store
|
||||||
|
# the values in a variety of ways.
|
||||||
|
### END INIT INFO
|
||||||
|
|
||||||
|
. /etc/init.d/functions
|
||||||
|
|
||||||
|
export PATH=/sbin:/bin:/usr/sbin:/usr/bin
|
||||||
|
|
||||||
|
DISABLE=0
|
||||||
|
|
||||||
|
NAME=collectd
|
||||||
|
DAEMON=/usr/sbin/collectd
|
||||||
|
|
||||||
|
CONFIGFILE=/etc/collectd.conf
|
||||||
|
PIDFILE=/var/run/collectd.pid
|
||||||
|
|
||||||
|
USE_COLLECTDMON=1
|
||||||
|
COLLECTDMON_DAEMON=/usr/sbin/collectdmon
|
||||||
|
COLLECTDMON_PIDFILE=/var/run/collectdmon.pid
|
||||||
|
|
||||||
|
MAXWAIT=30
|
||||||
|
|
||||||
|
# Gracefully exit if the package has been removed.
|
||||||
|
test -x $DAEMON || exit 0
|
||||||
|
|
||||||
|
if [ -r /etc/default/$NAME ]; then
|
||||||
|
. /etc/default/$NAME
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$ENABLE_COREFILES" == 1; then
|
||||||
|
ulimit -c unlimited
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$USE_COLLECTDMON" == 1; then
|
||||||
|
_PIDFILE="$COLLECTDMON_PIDFILE"
|
||||||
|
else
|
||||||
|
_PIDFILE="$PIDFILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# return:
|
||||||
|
# 0 if config is fine
|
||||||
|
# 1 if there is a syntax error
|
||||||
|
# 2 if there is no configuration
|
||||||
|
check_config() {
|
||||||
|
if test ! -e "$CONFIGFILE"; then
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
if ! $DAEMON -t -C "$CONFIGFILE"; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# return:
|
||||||
|
# 0 if the daemon has been started
|
||||||
|
# 1 if the daemon was already running
|
||||||
|
# 2 if the daemon could not be started
|
||||||
|
# 3 if the daemon was not supposed to be started
|
||||||
|
d_start() {
|
||||||
|
if test "$DISABLE" != 0; then
|
||||||
|
# we get here during restart
|
||||||
|
echo "disabled by /etc/default/$NAME"
|
||||||
|
return 3
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test ! -e "$CONFIGFILE"; then
|
||||||
|
# we get here during restart
|
||||||
|
echo "disabled, no configuration ($CONFIGFILE) found"
|
||||||
|
return 3
|
||||||
|
fi
|
||||||
|
|
||||||
|
check_config
|
||||||
|
rc="$?"
|
||||||
|
if test "$rc" -ne 0; then
|
||||||
|
echo "not starting, configuration error"
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$USE_COLLECTDMON" == 1; then
|
||||||
|
start-stop-daemon --start --quiet --oknodo --pidfile "$_PIDFILE" \
|
||||||
|
--exec $COLLECTDMON_DAEMON -- -P "$_PIDFILE" -- -C "$CONFIGFILE" \
|
||||||
|
|| return 2
|
||||||
|
else
|
||||||
|
start-stop-daemon --start --quiet --oknodo --pidfile "$_PIDFILE" \
|
||||||
|
--exec $DAEMON -- -C "$CONFIGFILE" -P "$_PIDFILE" \
|
||||||
|
|| return 2
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
still_running_warning="
|
||||||
|
WARNING: $NAME might still be running.
|
||||||
|
In large setups it might take some time to write all pending data to
|
||||||
|
the disk. You can adjust the waiting time in /etc/default/collectd."
|
||||||
|
|
||||||
|
# return:
|
||||||
|
# 0 if the daemon has been stopped
|
||||||
|
# 1 if the daemon was already stopped
|
||||||
|
# 2 if daemon could not be stopped
|
||||||
|
d_stop() {
|
||||||
|
PID=$( cat "$_PIDFILE" 2> /dev/null ) || true
|
||||||
|
|
||||||
|
start-stop-daemon --stop --quiet --oknodo --pidfile "$_PIDFILE"
|
||||||
|
rc="$?"
|
||||||
|
|
||||||
|
if test "$rc" -eq 2; then
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
sleep 1
|
||||||
|
if test -n "$PID" && kill -0 $PID 2> /dev/null; then
|
||||||
|
i=0
|
||||||
|
while kill -0 $PID 2> /dev/null; do
|
||||||
|
i=$(( $i + 2 ))
|
||||||
|
echo -n " ."
|
||||||
|
|
||||||
|
if test $i -gt $MAXWAIT; then
|
||||||
|
echo "$still_running_warning"
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
sleep 2
|
||||||
|
done
|
||||||
|
return "$rc"
|
||||||
|
fi
|
||||||
|
return "$rc"
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
start)
|
||||||
|
echo -n "Starting $NAME"
|
||||||
|
d_start
|
||||||
|
case "$?" in
|
||||||
|
0|1) echo "." ;;
|
||||||
|
*) exit 1 ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
stop)
|
||||||
|
echo -n "Stopping $NAME"
|
||||||
|
d_stop
|
||||||
|
case "$?" in
|
||||||
|
0|1) echo "." ;;
|
||||||
|
*) exit 1 ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
status)
|
||||||
|
status_of_proc -p "$_PIDFILE" "$DAEMON" "$NAME" && exit 0 || exit $?
|
||||||
|
;;
|
||||||
|
restart|force-reload)
|
||||||
|
echo -n "Restarting $NAME"
|
||||||
|
check_config
|
||||||
|
rc="$?"
|
||||||
|
if test "$rc" -eq 1; then
|
||||||
|
echo "not restarting, configuration error"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
d_stop
|
||||||
|
rc="$?"
|
||||||
|
case "$rc" in
|
||||||
|
0|1)
|
||||||
|
sleep 1
|
||||||
|
d_start
|
||||||
|
rc2="$?"
|
||||||
|
case "$rc2" in
|
||||||
|
0|1) echo "." ;;
|
||||||
|
*) exit 1 ;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Usage: $0 {start|stop|restart|force-reload|status}" >&2
|
||||||
|
exit 3
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# vim: syntax=sh noexpandtab sw=4 ts=4 :
|
||||||
|
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
Disable defaulting of GCRYPT_LDFLAGS to -L/usr/lib
|
||||||
|
|
||||||
|
Prevents "unsafe for cross compilation" warnings that cause
|
||||||
|
do_qa_configure to fail.
|
||||||
|
|
||||||
|
Upstream-Status: Inappropriate [configuration]
|
||||||
|
|
||||||
|
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
|
||||||
|
|
||||||
|
diff --git a/configure.in b/configure.in
|
||||||
|
index 98395ed..81c3a2c 100644
|
||||||
|
--- a/configure.in
|
||||||
|
+++ b/configure.in
|
||||||
|
@@ -1777,11 +1777,11 @@ then
|
||||||
|
GCRYPT_CPPFLAGS=`"$with_libgcrypt_config" --cflags 2>/dev/null`
|
||||||
|
fi
|
||||||
|
|
||||||
|
- if test "x$GCRYPT_LDFLAGS" = "x"
|
||||||
|
- then
|
||||||
|
- gcrypt_exec_prefix=`"$with_libgcrypt_config" --exec-prefix 2>/dev/null`
|
||||||
|
- GCRYPT_LDFLAGS="-L$gcrypt_exec_prefix/lib"
|
||||||
|
- fi
|
||||||
|
+# if test "x$GCRYPT_LDFLAGS" = "x"
|
||||||
|
+# then
|
||||||
|
+# gcrypt_exec_prefix=`"$with_libgcrypt_config" --exec-prefix 2>/dev/null`
|
||||||
|
+# GCRYPT_LDFLAGS="-L$gcrypt_exec_prefix/lib"
|
||||||
|
+# fi
|
||||||
|
|
||||||
|
if test "x$GCRYPT_LIBS" = "x"
|
||||||
|
then
|
||||||
@@ -0,0 +1,45 @@
|
|||||||
|
SUMMARY = "Collects and summarises system performance statistics"
|
||||||
|
DESCRIPTION = "collectd is a daemon which collects system performance statistics periodically and provides mechanisms to store the values in a variety of ways, for example in RRD files."
|
||||||
|
LICENSE = "GPLv2"
|
||||||
|
LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe"
|
||||||
|
|
||||||
|
DEPENDS = "rrdtool curl mysql5 libpcap libxml2 yajl libgcrypt libtool"
|
||||||
|
|
||||||
|
SRC_URI = "http://collectd.org/files/collectd-${PV}.tar.bz2 \
|
||||||
|
file://no-gcrypt-badpath.patch \
|
||||||
|
file://collectd-version.patch \
|
||||||
|
file://collectd.init"
|
||||||
|
|
||||||
|
SRC_URI[md5sum] = "29e61411e51845d5ae71ab676078867e"
|
||||||
|
SRC_URI[sha256sum] = "7b8906d1c8866155b31820ef108be92abcee7fcd278d386bf0d449e704ba4696"
|
||||||
|
|
||||||
|
inherit autotools pythonnative update-rc.d
|
||||||
|
|
||||||
|
# Floatingpoint layout, architecture dependent
|
||||||
|
# 'nothing', 'endianflip' or 'intswap'
|
||||||
|
FPLAYOUT ?= "--with-fp-layout=nothing"
|
||||||
|
|
||||||
|
PACKAGECONFIG ??= ""
|
||||||
|
PACKAGECONFIG[snmp] = "--enable-snmp,--disable-snmp --with-libnetsnmp=no,net-snmp"
|
||||||
|
|
||||||
|
EXTRA_OECONF = " \
|
||||||
|
${FPLAYOUT} \
|
||||||
|
--disable-perl --with-libperl=no --with-perl-bindings=no \
|
||||||
|
--with-libgcrypt=${STAGING_BINDIR_CROSS}/libgcrypt-config \
|
||||||
|
"
|
||||||
|
|
||||||
|
do_install_append() {
|
||||||
|
install -d ${D}${sysconfdir}/init.d
|
||||||
|
install -m 0755 ${WORKDIR}/collectd.init ${D}${sysconfdir}/init.d/collectd
|
||||||
|
sed -i 's!/usr/sbin/!${sbindir}/!g' ${D}${sysconfdir}/init.d/collectd
|
||||||
|
sed -i 's!/etc/!${sysconfdir}/!g' ${D}${sysconfdir}/init.d/collectd
|
||||||
|
sed -i 's!/var/!${localstatedir}/!g' ${D}${sysconfdir}/init.d/collectd
|
||||||
|
sed -i 's!^PATH=.*!PATH=${base_sbindir}:${base_bindir}:${sbindir}:${bindir}!' ${D}${sysconfdir}/init.d/collectd
|
||||||
|
|
||||||
|
# Fix configuration file to allow collectd to start up
|
||||||
|
sed -i 's!^#FQDNLookup[ \t]*true!FQDNLookup false!g' ${D}${sysconfdir}/collectd.conf
|
||||||
|
}
|
||||||
|
|
||||||
|
INITSCRIPT_NAME = "collectd"
|
||||||
|
INITSCRIPT_PARAMS = "defaults"
|
||||||
|
|
||||||
Reference in New Issue
Block a user