annotate src/http/ngx_http_copy_filter_module.c @ 644:6f21ae02fb01 NGINX_1_1_6

nginx 1.1.6 *) Change in internal API: now module context data are cleared while internal redirect to named location. Requested by Yichun Zhang. *) Change: if a server in an upstream failed, only one request will be sent to it after fail_timeout; the server will be considered alive if it will successfully respond to the request. *) Change: now the 0x7F-0x1F characters are escaped as \xXX in an access_log. *) Feature: "proxy/fastcgi/scgi/uwsgi_ignore_headers" directives support the following additional values: X-Accel-Limit-Rate, X-Accel-Buffering, X-Accel-Charset. *) Feature: decrease of memory consumption if SSL is used. *) Bugfix: some UTF-8 characters were processed incorrectly. Thanks to Alexey Kuts. *) Bugfix: the ngx_http_rewrite_module directives specified at "server" level were executed twice if no matching locations were defined. *) Bugfix: a socket leak might occurred if "aio sendfile" was used. *) Bugfix: connections with fast clients might be closed after send_timeout if file AIO was used. *) Bugfix: in the ngx_http_autoindex_module. *) Bugfix: the module ngx_http_mp4_module did not support seeking on 32-bit platforms.
author Igor Sysoev <http://sysoev.ru>
date Mon, 17 Oct 2011 00:00:00 +0400
parents c5122335e41d
children d0f7a625f27c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_http.h>
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 typedef struct {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 ngx_bufs_t bufs;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14 } ngx_http_copy_filter_conf_t;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
17 #if (NGX_HAVE_FILE_AIO)
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
18 static void ngx_http_copy_aio_handler(ngx_output_chain_ctx_t *ctx,
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
19 ngx_file_t *file);
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
20 static void ngx_http_copy_aio_event_handler(ngx_event_t *ev);
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
21 #if (NGX_HAVE_AIO_SENDFILE)
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
22 static void ngx_http_copy_aio_sendfile_event_handler(ngx_event_t *ev);
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
23 #endif
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
24 #endif
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
25
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26 static void *ngx_http_copy_filter_create_conf(ngx_conf_t *cf);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27 static char *ngx_http_copy_filter_merge_conf(ngx_conf_t *cf,
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28 void *parent, void *child);
230
38e7b94d63ac nginx 0.4.0
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
29 static ngx_int_t ngx_http_copy_filter_init(ngx_conf_t *cf);
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 static ngx_command_t ngx_http_copy_filter_commands[] = {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 { ngx_string("output_buffers"),
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE2,
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 ngx_conf_set_bufs_slot,
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37 NGX_HTTP_LOC_CONF_OFFSET,
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38 offsetof(ngx_http_copy_filter_conf_t, bufs),
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
39 NULL },
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 ngx_null_command
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
42 };
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
43
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
44
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
45 static ngx_http_module_t ngx_http_copy_filter_module_ctx = {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
46 NULL, /* preconfiguration */
230
38e7b94d63ac nginx 0.4.0
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
47 ngx_http_copy_filter_init, /* postconfiguration */
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 NULL, /* create main configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 NULL, /* init main configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52 NULL, /* create server configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53 NULL, /* merge server configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55 ngx_http_copy_filter_create_conf, /* create location configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56 ngx_http_copy_filter_merge_conf /* merge location configuration */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57 };
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 ngx_module_t ngx_http_copy_filter_module = {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
61 NGX_MODULE_V1,
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 &ngx_http_copy_filter_module_ctx, /* module context */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 ngx_http_copy_filter_commands, /* module directives */
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64 NGX_HTTP_MODULE, /* module type */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
65 NULL, /* init master */
230
38e7b94d63ac nginx 0.4.0
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
66 NULL, /* init module */
90
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
67 NULL, /* init process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
68 NULL, /* init thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
69 NULL, /* exit thread */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
70 NULL, /* exit process */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
71 NULL, /* exit master */
71c46860eb55 nginx 0.1.45
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
72 NGX_MODULE_V1_PADDING
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73 };
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 static ngx_http_output_body_filter_pt ngx_http_next_filter;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79 static ngx_int_t
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 ngx_http_copy_filter(ngx_http_request_t *r, ngx_chain_t *in)
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 {
132
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
82 ngx_int_t rc;
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
83 ngx_connection_t *c;
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 ngx_output_chain_ctx_t *ctx;
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
85 ngx_http_core_loc_conf_t *clcf;
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 ngx_http_copy_filter_conf_t *conf;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87
132
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
88 c = r->connection;
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
89
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
90 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
91 "http copy filter: \"%V?%V\"", &r->uri, &r->args);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
92
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
93 ctx = ngx_http_get_module_ctx(r, ngx_http_copy_filter_module);
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95 if (ctx == NULL) {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
96 ctx = ngx_pcalloc(r->pool, sizeof(ngx_output_chain_ctx_t));
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 if (ctx == NULL) {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98 return NGX_ERROR;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101 ngx_http_set_ctx(r, ctx, ngx_http_copy_filter_module);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
103 conf = ngx_http_get_module_loc_conf(r, ngx_http_copy_filter_module);
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
104 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
105
132
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
106 ctx->sendfile = c->sendfile;
62
0790a8599248 nginx 0.1.31
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
107 ctx->need_in_memory = r->main_filter_need_in_memory
0790a8599248 nginx 0.1.31
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
108 || r->filter_need_in_memory;
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109 ctx->need_in_temp = r->filter_need_temporary;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
111 ctx->alignment = clcf->directio_alignment;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
112
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113 ctx->pool = r->pool;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114 ctx->bufs = conf->bufs;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115 ctx->tag = (ngx_buf_tag_t) &ngx_http_copy_filter_module;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
117 ctx->output_filter = (ngx_output_chain_filter_pt) ngx_http_next_filter;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
118 ctx->filter_ctx = r;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
119
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
120 #if (NGX_HAVE_FILE_AIO)
602
c5122335e41d nginx 0.8.53
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
121 if (ngx_file_aio) {
c5122335e41d nginx 0.8.53
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
122 if (clcf->aio) {
c5122335e41d nginx 0.8.53
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
123 ctx->aio_handler = ngx_http_copy_aio_handler;
c5122335e41d nginx 0.8.53
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
124 }
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
125 #if (NGX_HAVE_AIO_SENDFILE)
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
126 c->aio_sendfile = (clcf->aio == NGX_HTTP_AIO_SENDFILE);
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
127 #endif
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
128 }
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
129 #endif
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
130
570
8246d8a2c2be nginx 0.8.37
Igor Sysoev <http://sysoev.ru>
parents: 542
diff changeset
131 if (in && in->buf && ngx_buf_size(in->buf)) {
8246d8a2c2be nginx 0.8.37
Igor Sysoev <http://sysoev.ru>
parents: 542
diff changeset
132 r->request_output = 1;
8246d8a2c2be nginx 0.8.37
Igor Sysoev <http://sysoev.ru>
parents: 542
diff changeset
133 }
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
134 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
135
526
0161f3197817 nginx 0.8.15
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
136 #if (NGX_HAVE_FILE_AIO)
0161f3197817 nginx 0.8.15
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
137 ctx->aio = r->aio;
0161f3197817 nginx 0.8.15
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
138 #endif
0161f3197817 nginx 0.8.15
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
139
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
140 for ( ;; ) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
141 rc = ngx_output_chain(ctx, in);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
142
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
143 if (ctx->in == NULL) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
144 r->buffered &= ~NGX_HTTP_COPY_BUFFERED;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
145
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
146 } else {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
147 r->buffered |= NGX_HTTP_COPY_BUFFERED;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
148 }
254
f3ec44f4a53b nginx 0.4.12
Igor Sysoev <http://sysoev.ru>
parents: 230
diff changeset
149
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
150 ngx_log_debug3(NGX_LOG_DEBUG_HTTP, c->log, 0,
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
151 "http copy filter: %i \"%V?%V\"", rc, &r->uri, &r->args);
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
152
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
153 #if (NGX_HAVE_FILE_AIO && NGX_HAVE_AIO_SENDFILE)
254
f3ec44f4a53b nginx 0.4.12
Igor Sysoev <http://sysoev.ru>
parents: 230
diff changeset
154
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
155 if (c->busy_sendfile) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
156 ssize_t n;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
157 off_t offset;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
158 ngx_file_t *file;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
159 ngx_http_ephemeral_t *e;
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
160
644
6f21ae02fb01 nginx 1.1.6
Igor Sysoev <http://sysoev.ru>
parents: 602
diff changeset
161 if (r->aio) {
6f21ae02fb01 nginx 1.1.6
Igor Sysoev <http://sysoev.ru>
parents: 602
diff changeset
162 c->busy_sendfile = NULL;
6f21ae02fb01 nginx 1.1.6
Igor Sysoev <http://sysoev.ru>
parents: 602
diff changeset
163 return rc;
6f21ae02fb01 nginx 1.1.6
Igor Sysoev <http://sysoev.ru>
parents: 602
diff changeset
164 }
6f21ae02fb01 nginx 1.1.6
Igor Sysoev <http://sysoev.ru>
parents: 602
diff changeset
165
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
166 file = c->busy_sendfile->file;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
167 offset = c->busy_sendfile->file_pos;
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
168
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
169 if (file->aio) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
170 c->aio_sendfile = (offset != file->aio->last_offset);
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
171 file->aio->last_offset = offset;
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
172
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
173 if (c->aio_sendfile == 0) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
174 ngx_log_error(NGX_LOG_ALERT, c->log, 0,
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
175 "sendfile(%V) returned busy again",
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
176 &file->name);
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
177 }
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
178 }
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
179
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
180 c->busy_sendfile = NULL;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
181 e = (ngx_http_ephemeral_t *) &r->uri_start;
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
182
524
80f7156c2965 nginx 0.8.14
Igor Sysoev <http://sysoev.ru>
parents: 522
diff changeset
183 n = ngx_file_aio_read(file, &e->aio_preload, 1, offset, r->pool);
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
184
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
185 if (n > 0) {
526
0161f3197817 nginx 0.8.15
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
186 in = NULL;
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
187 continue;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
188 }
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
189
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
190 rc = n;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
191
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
192 if (file->aio) {
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
193 file->aio->data = r;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
194 file->aio->handler = ngx_http_copy_aio_sendfile_event_handler;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
195
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
196 r->main->blocked++;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
197 r->aio = 1;
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
198 }
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
199 }
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
200 #endif
132
91372f004adf nginx 0.3.13
Igor Sysoev <http://sysoev.ru>
parents: 118
diff changeset
201
522
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
202 return rc;
1bc8c12d80ec nginx 0.8.13
Igor Sysoev <http://sysoev.ru>
parents: 520
diff changeset
203 }
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
204 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
205
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
206
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
207 #if (NGX_HAVE_FILE_AIO)
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
208
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
209 static void
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
210 ngx_http_copy_aio_handler(ngx_output_chain_ctx_t *ctx, ngx_file_t *file)
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
211 {
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
212 ngx_http_request_t *r;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
213
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
214 r = ctx->filter_ctx;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
215
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
216 file->aio->data = r;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
217 file->aio->handler = ngx_http_copy_aio_event_handler;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
218
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
219 r->main->blocked++;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
220 r->aio = 1;
602
c5122335e41d nginx 0.8.53
Igor Sysoev <http://sysoev.ru>
parents: 570
diff changeset
221 ctx->aio = 1;
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
222 }
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
223
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
224
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
225 static void
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
226 ngx_http_copy_aio_event_handler(ngx_event_t *ev)
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
227 {
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
228 ngx_event_aio_t *aio;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
229 ngx_http_request_t *r;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
230
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
231 aio = ev->data;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
232 r = aio->data;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
233
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
234 r->main->blocked--;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
235 r->aio = 0;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
236
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
237 r->connection->write->handler(r->connection->write);
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
238 }
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
239
520
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
240
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
241 #if (NGX_HAVE_AIO_SENDFILE)
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
242
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
243 static void
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
244 ngx_http_copy_aio_sendfile_event_handler(ngx_event_t *ev)
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
245 {
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
246 ngx_event_aio_t *aio;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
247 ngx_http_request_t *r;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
248
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
249 aio = ev->data;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
250 r = aio->data;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
251
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
252 r->main->blocked--;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
253 r->aio = 0;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
254 ev->complete = 0;
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
255
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
256 r->connection->write->handler(r->connection->write);
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
257 }
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
258
d41628eb4d0a nginx 0.8.12
Igor Sysoev <http://sysoev.ru>
parents: 518
diff changeset
259 #endif
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
260 #endif
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
261
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 426
diff changeset
262
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
263 static void *
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
264 ngx_http_copy_filter_create_conf(ngx_conf_t *cf)
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
265 {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
266 ngx_http_copy_filter_conf_t *conf;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
267
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
268 conf = ngx_palloc(cf->pool, sizeof(ngx_http_copy_filter_conf_t));
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
269 if (conf == NULL) {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
270 return NULL;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
271 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
272
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
273 conf->bufs.num = 0;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
274
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
275 return conf;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
276 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
277
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
278
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
279 static char *
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
280 ngx_http_copy_filter_merge_conf(ngx_conf_t *cf, void *parent, void *child)
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
281 {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
282 ngx_http_copy_filter_conf_t *prev = parent;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
283 ngx_http_copy_filter_conf_t *conf = child;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
284
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
285 ngx_conf_merge_bufs_value(conf->bufs, prev->bufs, 1, 32768);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
286
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
287 return NULL;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
288 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
289
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
290
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
291 static ngx_int_t
230
38e7b94d63ac nginx 0.4.0
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
292 ngx_http_copy_filter_init(ngx_conf_t *cf)
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
293 {
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
294 ngx_http_next_filter = ngx_http_top_body_filter;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
295 ngx_http_top_body_filter = ngx_http_copy_filter;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
296
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
297 return NGX_OK;
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
298 }
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
299