forked from rsyslog/rsyslog
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgzipwr_hup_multi_file.sh
executable file
·46 lines (41 loc) · 1.23 KB
/
gzipwr_hup_multi_file.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/bin/bash
# This file is part of the rsyslog project, released under ASL 2.0
# Written 2019-06-12 by Rainer Gerhards
export TEST_MAX_RUNTIME=7200
. ${srcdir:=.}/diag.sh init
export NUMMESSAGES=100000
generate_conf
add_conf '
module(load="../plugins/imtcp/.libs/imtcp")
main_queue(queue.workerThreads="10" queue.workerThreadMinimumMessages="200")
input(type="imtcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port")
template(name="outfmt" type="string"
string="%msg:F,58:2%,%msg:F,58:3%,%msg:F,58:4%\n")
template(name="dynfile" type="string" string="'$RSYSLOG_OUT_LOG'.%$/file%")
:msg, contains, "msgnum:" action(type="omfile" template="outfmt"
zipLevel="9" ioBufferSize="16" flushOnTXEnd="on"
dynafile="dynfile" dynaFileCacheSize="5"
asyncWriting="on")
if $msg contains "msgnum" then {
set $/file = cnum($/file) + 1;
if $/file >= 10 then {
set $/file = 0;
}
}
'
startup
./tcpflood -p$TCPFLOOD_PORT -m$NUMMESSAGES & # TCPFlood needs to run async!
for i in $(seq 0 20); do
printf '\nsending HUP %d\n' $i
issue_HUP
./msleep 10
done
shutdown_when_empty
wait_shutdown
ls -l ${RSYSLOG_OUT_LOG}.*
for f in "${RSYSLOG_OUT_LOG}".*; do
echo unzipping $f
gunzip < "$f" >> $RSYSLOG_OUT_LOG
done
seq_check
exit_test