1
1

Second try at printing statistics when processes are interrupted.

When the client process gets interrupted, both the client and server
dump out accumulated interval statistics, as well as a partial set of
summary statistics (basically each side dumps what it has, but without
the exchange of information that usually happens at the end of a
normal run).

If the server process gets interrupted, the server dumps out its
accumulated interval and summary statistics as above.  The client does
this as well in the -R case, but exits with a "Broken pipe" in the non
-R case (this behavior was present all along; it was not introduced in
this change).  More investigation will be needed to understand the
client behavior.

Bump copyright dates in a few places.

Issue:		132 (signal handler for API calls)
Discussed with:	aaron@internet2.edu
Этот коммит содержится в:
Bruce A. Mah 2014-01-07 16:06:27 -08:00
родитель a898ff8b8e
Коммит c04bdcb9d0
3 изменённых файлов: 35 добавлений и 4 удалений

Просмотреть файл

@ -2317,14 +2317,27 @@ iperf_catch_sigend(void (*handler)(int))
void void
iperf_got_sigend(struct iperf_test *test) iperf_got_sigend(struct iperf_test *test)
{ {
/*
* If we're the client, or if we're a server and running a test,
* then dump out the accumulated stats so far.
*/
if (test->role == 'c' ||
(test->role == 's' && test->state == TEST_RUNNING)) {
test->done = 1;
cpu_util(test->cpu_util);
test->stats_callback(test);
test->state = DISPLAY_RESULTS; /* change local state only */
if (test->on_test_finish)
test->on_test_finish(test);
test->reporter_callback(test);
}
if (test->ctrl_sck >= 0) { if (test->ctrl_sck >= 0) {
test->state = (test->role == 'c') ? CLIENT_TERMINATE : SERVER_TERMINATE; test->state = (test->role == 'c') ? CLIENT_TERMINATE : SERVER_TERMINATE;
(void) Nwrite(test->ctrl_sck, (char*) &test->state, sizeof(signed char), Ptcp); (void) Nwrite(test->ctrl_sck, (char*) &test->state, sizeof(signed char), Ptcp);
} }
i_errno = (test->role == 'c') ? IECLIENTTERM : IESERVERTERM; i_errno = (test->role == 'c') ? IECLIENTTERM : IESERVERTERM;
/* If the client, then dump JSON output if any */
if (test->role == 'c')
iperf_client_end(test);
iperf_errexit(test, "interrupt - %s", iperf_strerror(i_errno)); iperf_errexit(test, "interrupt - %s", iperf_strerror(i_errno));
} }

Просмотреть файл

@ -221,6 +221,16 @@ iperf_handle_message_client(struct iperf_test *test)
break; break;
case SERVER_TERMINATE: case SERVER_TERMINATE:
i_errno = IESERVERTERM; i_errno = IESERVERTERM;
/*
* Temporarily be in DISPLAY_RESULTS phase so we can get
* ending summary statistics.
*/
signed char oldstate = test->state;
cpu_util(test->cpu_util);
test->state = DISPLAY_RESULTS;
test->reporter_callback(test);
test->state = oldstate;
return -1; return -1;
case ACCESS_DENIED: case ACCESS_DENIED:
i_errno = IEACCESSDENIED; i_errno = IEACCESSDENIED;

Просмотреть файл

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2009-2011, The Regents of the University of California, * Copyright (c) 2009-2014, The Regents of the University of California,
* through Lawrence Berkeley National Laboratory (subject to receipt of any * through Lawrence Berkeley National Laboratory (subject to receipt of any
* required approvals from the U.S. Dept. of Energy). All rights reserved. * required approvals from the U.S. Dept. of Energy). All rights reserved.
* *
@ -204,6 +204,14 @@ iperf_handle_message_server(struct iperf_test *test)
case CLIENT_TERMINATE: case CLIENT_TERMINATE:
i_errno = IECLIENTTERM; i_errno = IECLIENTTERM;
// Temporarily be in DISPLAY_RESULTS phase so we can get
// ending summary statistics.
signed char oldstate = test->state;
cpu_util(test->cpu_util);
test->state = DISPLAY_RESULTS;
test->reporter_callback(test);
test->state = oldstate;
// XXX: Remove this line below! // XXX: Remove this line below!
iperf_err(test, "the client has terminated"); iperf_err(test, "the client has terminated");
SLIST_FOREACH(sp, &test->streams, streams) { SLIST_FOREACH(sp, &test->streams, streams) {