2010-10-05 23:16:18 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# if we start up as ./init-ceph, assume everything else is in the
|
|
|
|
# current directory too.
|
|
|
|
if [ `dirname $0` = "." ] && [ $PWD != "/etc/init.d" ]; then
|
|
|
|
BINDIR=.
|
|
|
|
LIBDIR=.
|
|
|
|
ETCDIR=.
|
|
|
|
else
|
|
|
|
BINDIR=@bindir@
|
|
|
|
LIBDIR=@libdir@/ceph
|
2010-12-07 18:56:05 +00:00
|
|
|
ETCDIR=@sysconfdir@/ceph
|
2010-10-05 23:16:18 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
BINDBGDIR="/usr/lib/debug/usr/bin"
|
|
|
|
|
|
|
|
usage_exit() {
|
2010-10-07 16:31:13 +00:00
|
|
|
echo "usage: $0 [-c ceph.conf] <filename.tar.gz>"
|
2010-10-05 23:16:18 +00:00
|
|
|
exit
|
|
|
|
}
|
|
|
|
|
2010-10-07 03:04:38 +00:00
|
|
|
wait_pid_exit() {
|
|
|
|
pid=$1
|
|
|
|
|
2015-01-23 02:52:58 +00:00
|
|
|
for i in $(seq 10); do
|
2010-10-07 03:04:38 +00:00
|
|
|
[ -e /proc/$pid ] || return
|
|
|
|
sleep 1
|
|
|
|
done
|
2010-10-07 16:47:34 +00:00
|
|
|
if [ -e /proc/$pid ]; then
|
|
|
|
echo Killing pid $pid
|
|
|
|
kill $pid
|
|
|
|
fi
|
2010-10-07 03:04:38 +00:00
|
|
|
}
|
|
|
|
|
2010-10-05 23:16:18 +00:00
|
|
|
. $LIBDIR/ceph_common.sh
|
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
dest_tar=''
|
2010-10-05 23:16:18 +00:00
|
|
|
while [ $# -ge 1 ]; do
|
|
|
|
case $1 in
|
|
|
|
--conf | -c)
|
|
|
|
[ -z "$2" ] && usage_exit
|
|
|
|
shift
|
|
|
|
conf=$1
|
|
|
|
;;
|
|
|
|
*)
|
2012-10-09 21:10:48 +00:00
|
|
|
if [ -n "$dest_tar" ]; then
|
2010-10-05 23:16:18 +00:00
|
|
|
echo unrecognized option \'$1\'
|
|
|
|
usage_exit
|
|
|
|
fi
|
|
|
|
dest_tar=$1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
2010-10-07 16:47:34 +00:00
|
|
|
[ "$dest_tar" = "" ] && usage_exit
|
2010-10-05 23:16:18 +00:00
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
echo "$0: generating debugpack tarball..."
|
|
|
|
|
|
|
|
if [ -e $dest_tar ]; then
|
|
|
|
echo "$0: dest $dest_tar already exists, aborting"
|
|
|
|
exit 1
|
|
|
|
fi
|
2010-10-05 23:16:18 +00:00
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
# get absolute path for dest_tar
|
|
|
|
bins="ceph-mon ceph-mds ceph-osd radosgw"
|
2010-10-05 23:16:18 +00:00
|
|
|
core_paths="/ $BINDIR $BINDBGDIR"
|
2010-10-07 16:47:34 +00:00
|
|
|
[ "$conf" = "" ] && conf=$ETCDIR/ceph.conf
|
2010-10-05 23:16:18 +00:00
|
|
|
log_path=`$CCONF -c $conf "log dir"`
|
|
|
|
|
|
|
|
[ -z "$conf" ] && usage_exit
|
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
# all configs
|
|
|
|
files='/etc/ceph'
|
|
|
|
|
|
|
|
# binaries
|
|
|
|
for bin in bins; do
|
|
|
|
if [ -e "/usr/bin/$bin" ]; then
|
|
|
|
files="$files /usr/bin/$bin"
|
|
|
|
fi
|
|
|
|
if [ -e "/usr/lib/debug/usr/bin/$bin" ]; then
|
|
|
|
files="$files /usr/lib/debug/usr/bin/$bin"
|
|
|
|
fi
|
2010-10-05 23:16:18 +00:00
|
|
|
done
|
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
# logs (the non-rotated ones)
|
|
|
|
for f in `find $path -maxdepth 1 -name 'core*'`; do
|
|
|
|
files="$files $f"
|
|
|
|
done
|
2010-10-05 23:16:18 +00:00
|
|
|
|
|
|
|
# copy cores (if exist)
|
|
|
|
for path in $core_paths; do
|
2012-10-09 21:10:48 +00:00
|
|
|
if [ -d $path ]; then
|
|
|
|
for f in `find $path -maxdepth 1 -name 'core*'`; do
|
|
|
|
files="$files $f"
|
|
|
|
done
|
|
|
|
fi
|
2010-10-05 23:16:18 +00:00
|
|
|
done
|
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
# cluster state
|
|
|
|
tmp_path=`mktemp -d /tmp/ceph-debugpack.XXXXXXXXXX`
|
2010-10-07 03:04:38 +00:00
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
$BINDIR/ceph report > $tmp_path/ceph-report &
|
2010-10-07 03:30:11 +00:00
|
|
|
wait_pid_exit $!
|
2010-10-07 03:04:38 +00:00
|
|
|
|
2012-10-09 21:10:48 +00:00
|
|
|
files="$files $tmp_path"
|
2010-10-05 23:16:18 +00:00
|
|
|
|
|
|
|
# now create a tarball
|
2012-10-09 21:10:48 +00:00
|
|
|
tar cvfz $dest_tar $files
|
|
|
|
rm -rf $tmp_path
|
|
|
|
|
|
|
|
echo "$0: created debugpack tarball at $dest_tar"
|
2010-10-05 23:16:18 +00:00
|
|
|
|