annotate src/http/modules/ngx_http_stub_status_module.c @ 660:d0f7a625f27c NGINX_1_1_14

nginx 1.1.14 *) Feature: multiple "limit_req" limits may be used simultaneously. *) Bugfix: in error handling while connecting to a backend. Thanks to Piotr Sikora. *) Bugfix: in AIO error handling on FreeBSD. *) Bugfix: in the OpenSSL library initialization. *) Bugfix: the "proxy_redirect" directives might not be correctly inherited. *) Bugfix: memory leak during reconfiguration if the "pcre_jit" directive was used.
author Igor Sysoev <http://sysoev.ru>
date Mon, 30 Jan 2012 00:00:00 +0400
parents 8246d8a2c2be
children 4dcaf40cc702
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
660
d0f7a625f27c nginx 1.1.14
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
4 * Copyright (C) Nginx, Inc.
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
5 */
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
6
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10 #include <ngx_http.h>
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
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 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
14 void *conf);
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
15
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16 static ngx_command_t ngx_http_status_commands[] = {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18 { ngx_string("stub_status"),
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_FLAG,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 ngx_http_set_status,
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 0,
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23 NULL },
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25 ngx_null_command
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
26 };
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
29
216
fa32d59d9a15 nginx 0.3.55
Igor Sysoev <http://sysoev.ru>
parents: 126
diff changeset
30 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
31 NULL, /* preconfiguration */
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
32 NULL, /* postconfiguration */
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 NULL, /* create main configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 NULL, /* init main configuration */
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
36
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37 NULL, /* create server configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38 NULL, /* merge server configuration */
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 90
diff changeset
39
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 NULL, /* create location configuration */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 NULL /* merge location configuration */
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
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
45 ngx_module_t ngx_http_stub_status_module = {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
46 NGX_MODULE_V1,
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47 &ngx_http_stub_status_module_ctx, /* module context */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48 ngx_http_status_commands, /* module directives */
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 NGX_HTTP_MODULE, /* module type */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
50 NULL, /* init master */
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51 NULL, /* init module */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
52 NULL, /* init process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
53 NULL, /* init thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
54 NULL, /* exit thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
55 NULL, /* exit process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
56 NULL, /* exit master */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
57 NGX_MODULE_V1_PADDING
36
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
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61 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
62 {
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
63 size_t size;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
64 ngx_int_t rc;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
65 ngx_buf_t *b;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
66 ngx_chain_t out;
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
67 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
68
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 if (r->method != NGX_HTTP_GET && r->method != NGX_HTTP_HEAD) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 return NGX_HTTP_NOT_ALLOWED;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
73 rc = ngx_http_discard_request_body(r);
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
75 if (rc != NGX_OK) {
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 return rc;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78
570
8246d8a2c2be nginx 0.8.37
Igor Sysoev <http://sysoev.ru>
parents: 340
diff changeset
79 ngx_str_set(&r->headers_out.content_type, "text/plain");
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 if (r->method == NGX_HTTP_HEAD) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82 r->headers_out.status = NGX_HTTP_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 rc = ngx_http_send_header(r);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87 return rc;
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 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
90
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
91 size = sizeof("Active connections: \n") + NGX_ATOMIC_T_LEN
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 + sizeof("server accepts handled requests\n") - 1
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
93 + 6 + 3 * NGX_ATOMIC_T_LEN
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
94 + sizeof("Reading: Writing: Waiting: \n") + 3 * NGX_ATOMIC_T_LEN;
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 44
diff changeset
96 b = ngx_create_temp_buf(r->pool, size);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 44
diff changeset
97 if (b == NULL) {
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98 return NGX_HTTP_INTERNAL_SERVER_ERROR;
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
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101 out.buf = b;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102 out.next = NULL;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104 ap = *ngx_stat_accepted;
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
105 hn = *ngx_stat_handled;
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
106 ac = *ngx_stat_active;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107 rq = *ngx_stat_requests;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
108 rd = *ngx_stat_reading;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109 wr = *ngx_stat_writing;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
111 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
112
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113 b->last = ngx_cpymem(b->last, "server accepts handled requests\n",
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114 sizeof("server accepts handled requests\n") - 1);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
116 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
117
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
118 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
119 rd, wr, ac - (rd + wr));
36
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
120
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121 r->headers_out.status = NGX_HTTP_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122 r->headers_out.content_length_n = b->last - b->pos;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
124 b->last_buf = 1;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
126 rc = ngx_http_send_header(r);
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
127
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
128 if (rc == NGX_ERROR || rc > NGX_OK || r->header_only) {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
129 return rc;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
130 }
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
131
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
132 return ngx_http_output_filter(r, &out);
36
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
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
136 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
137 {
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
138 ngx_http_core_loc_conf_t *clcf;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
139
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
140 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
141 clcf->handler = ngx_http_status_handler;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
142
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
143 return NGX_CONF_OK;
a39d1b793287 nginx 0.1.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
144 }