annotate src/http/modules/ngx_http_stub_status_module.c @ 570:8246d8a2c2be NGINX_0_8_37

nginx 0.8.37 *) Feature: the ngx_http_split_clients_module. *) Feature: the "map" directive supports keys more than 255 characters. *) Bugfix: nginx ignored the "private" and "no-store" values in the "Cache-Control" backend response header line. *) Bugfix: a "stub" parameter of an "include" SSI directive was not used, if empty response has 200 status code. *) Bugfix: if a proxied or FastCGI request was internally redirected to another proxied or FastCGI location, then a segmentation fault might occur in a worker process; the bug had appeared in 0.8.33. Thanks to Yichun Zhang. *) Bugfix: IMAP connections may hang until they timed out while talking to Zimbra server. Thanks to Alan Batie.
author Igor Sysoev <http://sysoev.ru>
date Mon, 17 May 2010 00:00:00 +0400
parents 10cc350ed8a1
children d0f7a625f27c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
1
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
2 /*
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
3 * Copyright (C) Igor Sysoev
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
4 */
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
5
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_http.h>
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 static char *ngx_http_set_status(ngx_conf_t *cf, ngx_command_t *cmd,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 void *conf);
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
14
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 static ngx_command_t ngx_http_status_commands[] = {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 { ngx_string("stub_status"),
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18 NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_FLAG,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 ngx_http_set_status,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 0,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21 0,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22 NULL },
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24 ngx_null_command
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
25 };
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
28
216
fa32d59d9a15 nginx 0.3.55
Igor Sysoev <http://sysoev.ru>
parents: 126
diff changeset
29 static ngx_http_module_t ngx_http_stub_status_module_ctx = {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
30 NULL, /* preconfiguration */
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
31 NULL, /* postconfiguration */
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33 NULL, /* create main configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 NULL, /* init main configuration */
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
35
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 NULL, /* create server configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37 NULL, /* merge server configuration */
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
38
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
39 NULL, /* create location configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 NULL /* merge location configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 };
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
42
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
43
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
44 ngx_module_t ngx_http_stub_status_module = {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
45 NGX_MODULE_V1,
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
46 &ngx_http_stub_status_module_ctx, /* module context */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47 ngx_http_status_commands, /* module directives */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48 NGX_HTTP_MODULE, /* module type */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
49 NULL, /* init master */
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 NULL, /* init module */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
51 NULL, /* init process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
52 NULL, /* init thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
53 NULL, /* exit thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
54 NULL, /* exit process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
55 NULL, /* exit master */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
56 NGX_MODULE_V1_PADDING
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57 };
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 static ngx_int_t ngx_http_status_handler(ngx_http_request_t *r)
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61 {
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
62 size_t size;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
63 ngx_int_t rc;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
64 ngx_buf_t *b;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
65 ngx_chain_t out;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
66 ngx_atomic_int_t ap, hn, ac, rq, rd, wr;
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
67
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68 if (r->method != NGX_HTTP_GET && r->method != NGX_HTTP_HEAD) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 return NGX_HTTP_NOT_ALLOWED;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
72 rc = ngx_http_discard_request_body(r);
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
74 if (rc != NGX_OK) {
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 return rc;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77
570
8246d8a2c2be nginx 0.8.37
Igor Sysoev <http://sysoev.ru>
parents: 340
diff changeset
78 ngx_str_set(&r->headers_out.content_type, "text/plain");
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 if (r->method == NGX_HTTP_HEAD) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 r->headers_out.status = NGX_HTTP_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83 rc = ngx_http_send_header(r);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85 if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 return rc;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
88 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
89
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
90 size = sizeof("Active connections: \n") + NGX_ATOMIC_T_LEN
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
91 + sizeof("server accepts handled requests\n") - 1
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
92 + 6 + 3 * NGX_ATOMIC_T_LEN
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
93 + sizeof("Reading: Writing: Waiting: \n") + 3 * NGX_ATOMIC_T_LEN;
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 44
diff changeset
95 b = ngx_create_temp_buf(r->pool, size);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 44
diff changeset
96 if (b == NULL) {
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 return NGX_HTTP_INTERNAL_SERVER_ERROR;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100 out.buf = b;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101 out.next = NULL;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 ap = *ngx_stat_accepted;
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
104 hn = *ngx_stat_handled;
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105 ac = *ngx_stat_active;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
106 rq = *ngx_stat_requests;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107 rd = *ngx_stat_reading;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
108 wr = *ngx_stat_writing;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
110 b->last = ngx_sprintf(b->last, "Active connections: %uA \n", ac);
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
111
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
112 b->last = ngx_cpymem(b->last, "server accepts handled requests\n",
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113 sizeof("server accepts handled requests\n") - 1);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
115 b->last = ngx_sprintf(b->last, " %uA %uA %uA \n", ap, hn, rq);
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
117 b->last = ngx_sprintf(b->last, "Reading: %uA Writing: %uA Waiting: %uA \n",
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 36
diff changeset
118 rd, wr, ac - (rd + wr));
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
119
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
120 r->headers_out.status = NGX_HTTP_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121 r->headers_out.content_length_n = b->last - b->pos;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123 b->last_buf = 1;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
124
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125 rc = ngx_http_send_header(r);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
126
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
127 if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
128 return rc;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
129 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
130
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
131 return ngx_http_output_filter(r, &out);
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
132 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
133
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
134
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
135 static char *ngx_http_set_status(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
136 {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
137 ngx_http_core_loc_conf_t *clcf;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
138
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
139 clcf = ngx_http_conf_get_module_loc_conf(cf, ngx_http_core_module);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
140 clcf->handler = ngx_http_status_handler;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
141
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
142 return NGX_CONF_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
143 }