2011-07-28 14:50:43 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
. /lib/dracut-lib.sh
|
|
|
|
|
|
|
|
set -x
|
|
|
|
KDUMP_PATH="/var/crash"
|
2012-06-14 01:56:10 +00:00
|
|
|
CORE_COLLECTOR=""
|
|
|
|
DEFAULT_CORE_COLLECTOR="makedumpfile -c --message-level 1 -d 31"
|
2011-08-02 10:10:16 +00:00
|
|
|
DEFAULT_ACTION="dump_rootfs"
|
2011-07-28 14:50:43 +00:00
|
|
|
DATEDIR=`date +%d.%m.%y-%T`
|
|
|
|
DUMP_INSTRUCTION=""
|
2012-02-22 03:16:09 +00:00
|
|
|
SSH_KEY_LOCATION="/root/.ssh/kdump_id_rsa"
|
2012-04-28 10:01:18 +00:00
|
|
|
KDUMP_SCRIPT_DIR="/kdumpscripts"
|
|
|
|
DD_BLKSIZE=512
|
2012-06-12 01:42:39 +00:00
|
|
|
FINAL_ACTION="reboot -f"
|
|
|
|
DUMP_RETVAL=0
|
2012-06-14 01:55:54 +00:00
|
|
|
conf_file="/etc/kdump.conf"
|
2012-06-14 01:57:30 +00:00
|
|
|
KDUMP_PRE=""
|
|
|
|
KDUMP_POST=""
|
2012-04-28 10:01:18 +00:00
|
|
|
|
|
|
|
export PATH=$PATH:$KDUMP_SCRIPT_DIR
|
2012-02-22 03:16:09 +00:00
|
|
|
|
|
|
|
# we use manual setup nics in udev rules,
|
|
|
|
# so we need to test network is really ok
|
|
|
|
wait_for_net_ok() {
|
|
|
|
local ip=$(getarg ip)
|
|
|
|
local iface=`echo $ip|cut -d':' -f1`
|
|
|
|
return $(wait_for_route_ok $iface)
|
|
|
|
}
|
2011-07-28 14:50:43 +00:00
|
|
|
|
|
|
|
do_default_action()
|
|
|
|
{
|
|
|
|
wait_for_loginit
|
|
|
|
$DEFAULT_ACTION
|
|
|
|
}
|
|
|
|
|
2012-06-14 01:57:30 +00:00
|
|
|
do_kdump_pre()
|
|
|
|
{
|
|
|
|
if [ -n "$KDUMP_PRE" ]; then
|
|
|
|
"$KDUMP_PRE"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
do_kdump_post()
|
|
|
|
{
|
|
|
|
if [ -n "$KDUMP_POST" ]; then
|
|
|
|
"$KDUMP_POST" "$1"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2011-08-01 12:01:31 +00:00
|
|
|
add_dump_code()
|
2011-07-28 14:50:43 +00:00
|
|
|
{
|
2012-06-12 01:42:39 +00:00
|
|
|
DUMP_INSTRUCTION=$1
|
2011-07-28 14:50:43 +00:00
|
|
|
}
|
|
|
|
|
2012-01-25 07:25:39 +00:00
|
|
|
get_mp()
|
2011-08-01 14:53:00 +00:00
|
|
|
{
|
|
|
|
local _mp
|
2012-04-27 08:29:18 +00:00
|
|
|
local dev mp fs opts rest
|
2011-08-01 14:53:00 +00:00
|
|
|
while read dev mp fs opts rest; do
|
|
|
|
if [ "$dev" = "$1" ]; then
|
2012-01-25 07:25:39 +00:00
|
|
|
_mp="$mp"
|
2011-08-01 14:53:00 +00:00
|
|
|
break
|
|
|
|
fi
|
2012-01-25 07:25:39 +00:00
|
|
|
done < /proc/mounts
|
2011-08-01 14:53:00 +00:00
|
|
|
echo "$_mp"
|
|
|
|
}
|
|
|
|
|
2012-07-23 07:31:15 +00:00
|
|
|
dump_fs()
|
2011-08-01 12:01:31 +00:00
|
|
|
{
|
2012-09-20 03:03:04 +00:00
|
|
|
local _dev=$1
|
2012-01-25 07:25:39 +00:00
|
|
|
local _mp=`get_mp $_dev`
|
2012-07-23 07:31:08 +00:00
|
|
|
|
|
|
|
if [ -z "$_mp" ]; then
|
|
|
|
echo "kdump: error: Dump target $1 is not mounted."
|
|
|
|
return 1
|
|
|
|
fi
|
2012-01-25 07:25:39 +00:00
|
|
|
if [ "$_mp" = "$NEWROOT/" ] || [ "$_mp" = "$NEWROOT" ]
|
2011-08-02 10:10:16 +00:00
|
|
|
then
|
|
|
|
mount -o remount,rw $_mp || return 1
|
|
|
|
fi
|
2012-07-23 07:31:08 +00:00
|
|
|
mkdir -p $_mp/$KDUMP_PATH/$DATEDIR || return 1
|
2011-08-01 14:53:00 +00:00
|
|
|
$CORE_COLLECTOR /proc/vmcore $_mp/$KDUMP_PATH/$DATEDIR/vmcore || return 1
|
2011-08-02 06:00:50 +00:00
|
|
|
umount $_mp || return 1
|
2011-08-01 12:01:31 +00:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
dump_raw()
|
|
|
|
{
|
2012-04-28 10:01:18 +00:00
|
|
|
[ -b "$1" ] || return 1
|
|
|
|
|
|
|
|
echo "Saving to raw disk $1"
|
|
|
|
if $(echo -n $CORE_COLLECTOR|grep -q makedumpfile); then
|
|
|
|
_src_size_mb="Unknown"
|
|
|
|
else
|
|
|
|
_src_size=`ls -l /proc/vmcore | cut -d' ' -f5`
|
|
|
|
_src_size_mb=$(($_src_size / 1048576))
|
|
|
|
fi
|
|
|
|
|
|
|
|
monitor_dd_progress $_src_size_mb &
|
|
|
|
|
|
|
|
$CORE_COLLECTOR /proc/vmcore | dd of=$1 bs=$DD_BLKSIZE >> /tmp/dd_progress_file 2>&1 || return 1
|
2012-08-06 06:49:52 +00:00
|
|
|
return ${PIPESTATUS[0]}
|
2011-08-01 12:01:31 +00:00
|
|
|
}
|
|
|
|
|
2011-07-28 14:50:43 +00:00
|
|
|
dump_rootfs()
|
|
|
|
{
|
|
|
|
mount -o remount,rw $NEWROOT/ || return 1
|
|
|
|
mkdir -p $NEWROOT/$KDUMP_PATH/$DATEDIR
|
|
|
|
$CORE_COLLECTOR /proc/vmcore $NEWROOT/$KDUMP_PATH/$DATEDIR/vmcore || return 1
|
|
|
|
sync
|
|
|
|
}
|
|
|
|
|
|
|
|
dump_ssh()
|
|
|
|
{
|
2012-06-14 01:56:10 +00:00
|
|
|
local _opt="-i $1 -o BatchMode=yes -o StrictHostKeyChecking=yes"
|
|
|
|
local _dir="$KDUMP_PATH/$DATEDIR"
|
|
|
|
|
|
|
|
ssh -q $_opt $2 mkdir -p $_dir || return 1
|
|
|
|
|
|
|
|
if [ "${CORE_COLLECTOR%% *}" = "scp" ]; then
|
|
|
|
scp -q $_opt /proc/vmcore "$2:$_dir/vmcore-incomplete" || return 1
|
|
|
|
ssh $_opt $2 "mv $_dir/vmcore-incomplete $_dir/vmcore" || return 1
|
|
|
|
else
|
|
|
|
$CORE_COLLECTOR /proc/vmcore | ssh $_opt $2 "dd bs=512 of=$_dir/vmcore-incomplete" || return 1
|
|
|
|
ssh $_opt $2 "mv $_dir/vmcore-incomplete $_dir/vmcore.flat" || return 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
is_ssh_dump_target()
|
|
|
|
{
|
2012-07-23 07:31:28 +00:00
|
|
|
grep -q "^ssh.*@" $conf_file
|
2011-07-28 14:50:43 +00:00
|
|
|
}
|
|
|
|
|
2012-06-14 01:57:07 +00:00
|
|
|
is_raw_dump_target()
|
|
|
|
{
|
|
|
|
grep -q "^raw" $conf_file
|
|
|
|
}
|
|
|
|
|
2011-07-28 14:50:43 +00:00
|
|
|
read_kdump_conf()
|
|
|
|
{
|
2012-06-14 01:55:54 +00:00
|
|
|
if [ ! -f "$conf_file" ]; then
|
|
|
|
echo "$conf_file not found"
|
|
|
|
return
|
2011-07-28 14:50:43 +00:00
|
|
|
fi
|
2012-06-14 01:55:54 +00:00
|
|
|
|
|
|
|
# first get the necessary variables
|
|
|
|
while read config_opt config_val;
|
|
|
|
do
|
|
|
|
case "$config_opt" in
|
|
|
|
path)
|
|
|
|
KDUMP_PATH="$config_val"
|
|
|
|
;;
|
|
|
|
core_collector)
|
|
|
|
[ -n "$config_val" ] && CORE_COLLECTOR="$config_val"
|
|
|
|
;;
|
|
|
|
sshkey)
|
|
|
|
if [ -f "$config_val" ]; then
|
|
|
|
SSH_KEY_LOCATION=$config_val
|
|
|
|
fi
|
|
|
|
;;
|
2012-06-14 01:57:30 +00:00
|
|
|
kdump_pre)
|
|
|
|
KDUMP_PRE="$config_val"
|
|
|
|
;;
|
|
|
|
kdump_post)
|
|
|
|
KDUMP_POST="$config_val"
|
|
|
|
;;
|
2012-06-14 01:55:54 +00:00
|
|
|
default)
|
|
|
|
case $config_val in
|
|
|
|
shell)
|
2012-08-01 10:14:42 +00:00
|
|
|
DEFAULT_ACTION="_emergency_shell kdump"
|
2012-06-14 01:55:54 +00:00
|
|
|
;;
|
|
|
|
reboot)
|
|
|
|
DEFAULT_ACTION="reboot -f"
|
|
|
|
;;
|
|
|
|
halt)
|
|
|
|
DEFAULT_ACTION="halt -f"
|
|
|
|
;;
|
|
|
|
poweroff)
|
|
|
|
DEFAULT_ACTION="poweroff -f"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done < $conf_file
|
|
|
|
|
|
|
|
# rescan for add code for dump target
|
|
|
|
while read config_opt config_val;
|
|
|
|
do
|
|
|
|
case "$config_opt" in
|
2012-07-23 07:31:28 +00:00
|
|
|
ext[234]|xfs|btrfs|minix|nfs)
|
2012-07-23 07:31:15 +00:00
|
|
|
add_dump_code "dump_fs $config_val"
|
2012-06-14 01:55:54 +00:00
|
|
|
;;
|
|
|
|
raw)
|
|
|
|
add_dump_code "dump_raw $config_val"
|
|
|
|
;;
|
2012-07-23 07:31:28 +00:00
|
|
|
ssh)
|
2012-06-14 01:55:54 +00:00
|
|
|
wait_for_net_ok
|
2012-07-23 07:31:28 +00:00
|
|
|
add_dump_code "dump_ssh $SSH_KEY_LOCATION $config_val"
|
2012-06-14 01:55:54 +00:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done < $conf_file
|
2011-07-28 14:50:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
read_kdump_conf
|
|
|
|
|
2012-06-14 01:56:10 +00:00
|
|
|
if [ -z "$CORE_COLLECTOR" ];then
|
|
|
|
CORE_COLLECTOR=$DEFAULT_CORE_COLLECTOR
|
2012-06-14 01:57:07 +00:00
|
|
|
if is_ssh_dump_target || is_raw_dump_target; then
|
|
|
|
CORE_COLLECTOR="$CORE_COLLECTOR -F"
|
|
|
|
fi
|
2012-06-14 01:56:10 +00:00
|
|
|
fi
|
|
|
|
|
2012-06-12 01:42:29 +00:00
|
|
|
if [ -z "$DUMP_INSTRUCTION" ]; then
|
|
|
|
add_dump_code "dump_rootfs"
|
2011-07-28 14:50:43 +00:00
|
|
|
fi
|
|
|
|
|
2012-06-14 01:57:30 +00:00
|
|
|
do_kdump_pre
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "kdump_pre script exited with non-zero status!"
|
|
|
|
$FINAL_ACTION
|
|
|
|
fi
|
|
|
|
|
2012-06-12 01:42:39 +00:00
|
|
|
$DUMP_INSTRUCTION
|
|
|
|
DUMP_RETVAL=$?
|
2012-06-14 01:57:30 +00:00
|
|
|
|
|
|
|
do_kdump_post $DUMP_RETVAL
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "kdump_post script exited with non-zero status!"
|
|
|
|
fi
|
|
|
|
|
2012-06-12 01:42:39 +00:00
|
|
|
if [ $DUMP_RETVAL -ne 0 ]; then
|
|
|
|
do_default_action
|
|
|
|
fi
|
|
|
|
|
|
|
|
$FINAL_ACTION
|