mirror of
https://github.com/rsyslog/rsyslog.git
synced 2025-12-15 10:30:40 +01:00
55 lines
1.7 KiB
Bash
Executable File
55 lines
1.7 KiB
Bash
Executable File
#!/bin/bash
|
|
# Test for queue data persisting at shutdown. The
|
|
# plan is to start an instance, emit some data, do a relatively
|
|
# fast shutdown and then re-start the engine to process the
|
|
# remaining data.
|
|
# added 2009-05-27 by Rgerhards
|
|
# This file is part of the rsyslog project, released under ASL 2.0
|
|
# uncomment for debugging support:
|
|
. ${srcdir:=.}/diag.sh init
|
|
generate_conf
|
|
add_conf '
|
|
$ModLoad ../plugins/imtcp/.libs/imtcp
|
|
$MainMsgQueueTimeoutShutdown 1
|
|
$MainMsgQueueSaveOnShutdown on
|
|
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port")
|
|
|
|
$ModLoad ../plugins/omtesting/.libs/omtesting
|
|
|
|
# set spool locations and switch queue to disk-only mode
|
|
$WorkDirectory '$RSYSLOG_DYNNAME'.spool
|
|
$MainMsgQueueFilename mainq
|
|
$IncludeConfig '${RSYSLOG_DYNNAME}'work-queuemode.conf
|
|
|
|
$template outfmt,"%msg:F,58:2%\n"
|
|
template(name="dynfile" type="string" string=`echo $RSYSLOG_OUT_LOG`) # trick to use relative path names!
|
|
:msg, contains, "msgnum:" ?dynfile;outfmt
|
|
|
|
$IncludeConfig '${RSYSLOG_DYNNAME}'work-delay.conf
|
|
'
|
|
|
|
#export RSYSLOG_DEBUG="debug nologfuncflow nostdout noprintmutexaction"
|
|
#export RSYSLOG_DEBUGLOG="log"
|
|
|
|
# prepare config
|
|
echo \$MainMsgQueueType $1 > ${RSYSLOG_DYNNAME}work-queuemode.conf
|
|
echo "*.* :omtesting:sleep 0 1000" > ${RSYSLOG_DYNNAME}work-delay.conf
|
|
|
|
# inject 10000 msgs, so that DO hit the high watermark
|
|
startup
|
|
injectmsg 0 10000
|
|
shutdown_immediate
|
|
wait_shutdown
|
|
check_mainq_spool
|
|
|
|
echo "Enter phase 2, rsyslogd restart"
|
|
|
|
# restart engine and have rest processed
|
|
#remove delay
|
|
echo "#" > ${RSYSLOG_DYNNAME}work-delay.conf
|
|
startup
|
|
shutdown_when_empty # shut down rsyslogd when done processing messages
|
|
wait_shutdown
|
|
seq_check 0 9999
|
|
exit_test
|