fix negative upstream response time

This commit is contained in:
Igor Sysoev 2006-11-15 20:51:07 +00:00
parent c28473eef4
commit eb885fafd2

View File

@ -512,6 +512,7 @@ ngx_http_upstream_connect(ngx_http_request_t *r, ngx_http_upstream_t *u)
{ {
ngx_int_t rc; ngx_int_t rc;
ngx_time_t *tp; ngx_time_t *tp;
ngx_msec_int_t ms;
ngx_connection_t *c; ngx_connection_t *c;
r->connection->log->action = "connecting to upstream"; r->connection->log->action = "connecting to upstream";
@ -520,8 +521,8 @@ ngx_http_upstream_connect(ngx_http_request_t *r, ngx_http_upstream_t *u)
if (u->state && u->state->response_time) { if (u->state && u->state->response_time) {
tp = ngx_timeofday(); tp = ngx_timeofday();
u->state->response_time = tp->sec * 1000 + tp->msec ms = tp->sec * 1000 + tp->msec - u->state->response_time;
- u->state->response_time; u->state->response_time = (ms >= 0) ? ms : 0;
} }
u->state = ngx_array_push(&u->states); u->state = ngx_array_push(&u->states);
@ -2058,6 +2059,7 @@ ngx_http_upstream_finalize_request(ngx_http_request_t *r,
ngx_http_upstream_t *u, ngx_int_t rc) ngx_http_upstream_t *u, ngx_int_t rc)
{ {
ngx_time_t *tp; ngx_time_t *tp;
ngx_msec_int_t ms;
ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
"finalize http upstream request: %i", rc); "finalize http upstream request: %i", rc);
@ -2066,8 +2068,8 @@ ngx_http_upstream_finalize_request(ngx_http_request_t *r,
if (u->state->response_time) { if (u->state->response_time) {
tp = ngx_timeofday(); tp = ngx_timeofday();
u->state->response_time = tp->sec * 1000 + tp->msec ms = tp->sec * 1000 + tp->msec - u->state->response_time;
- u->state->response_time; u->state->response_time = (ms >= 0) ? ms : 0;
} }
u->finalize_request(r, rc); u->finalize_request(r, rc);