annotate src/http/modules/ngx_http_memcached_module.c @ 340:10cc350ed8a1 NGINX_0_6_14

nginx 0.6.14 *) Change: now by default the "echo" SSI command uses entity encoding. *) Feature: the "encoding" parameter in the "echo" SSI command. *) Feature: the "access_log" directive may be used inside the "limit_except" block. *) Bugfix: if all upstream servers were failed, then all servers had got weight the was equal one until servers became alive; bug appeared in 0.6.6. *) Bugfix: a segmentation fault occurred in worker process if $date_local and $date_gmt were used outside the ngx_http_ssi_filter_module. *) Bugfix: a segmentation fault might occur in worker process if debug log was enabled. Thanks to Andrei Nigmatulin. *) Bugfix: ngx_http_memcached_module did not set $upstream_response_time. Thanks to Maxim Dounin. *) Bugfix: a worker process may got caught in an endless loop, if the memcached was used. *) Bugfix: nginx supported low case only "close" and "keep-alive" values in the "Connection" request header line; bug appeared in 0.6.11. *) Bugfix: sub_filter did not work with empty substitution. *) Bugfix: in sub_filter parsing.
author Igor Sysoev <http://sysoev.ru>
date Mon, 15 Oct 2007 00:00:00 +0400
parents 9fc4ab6673f9
children e10168d6e371
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_event.h>
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10 #include <ngx_http.h>
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13 typedef struct {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14 ngx_http_upstream_conf_t upstream;
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
15 ngx_int_t index;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16 } ngx_http_memcached_loc_conf_t;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 typedef struct {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 size_t rest;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21 ngx_http_request_t *request;
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
22 ngx_str_t key;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23 } ngx_http_memcached_ctx_t;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26 static ngx_int_t ngx_http_memcached_create_request(ngx_http_request_t *r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27 static ngx_int_t ngx_http_memcached_reinit_request(ngx_http_request_t *r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28 static ngx_int_t ngx_http_memcached_process_header(ngx_http_request_t *r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29 static ngx_int_t ngx_http_memcached_filter_init(void *data);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30 static ngx_int_t ngx_http_memcached_filter(void *data, ssize_t bytes);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31 static void ngx_http_memcached_abort_request(ngx_http_request_t *r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 static void ngx_http_memcached_finalize_request(ngx_http_request_t *r,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33 ngx_int_t rc);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 static void *ngx_http_memcached_create_loc_conf(ngx_conf_t *cf);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 static char *ngx_http_memcached_merge_loc_conf(ngx_conf_t *cf,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37 void *parent, void *child);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
39 static char *ngx_http_memcached_pass(ngx_conf_t *cf, ngx_command_t *cmd,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 void *conf);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
42 static char *ngx_http_memcached_upstream_max_fails_unsupported(ngx_conf_t *cf,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
43 ngx_command_t *cmd, void *conf);
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
44 static char *ngx_http_memcached_upstream_fail_timeout_unsupported(ngx_conf_t *cf,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
45 ngx_command_t *cmd, void *conf);
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
46
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
47
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48 static ngx_conf_bitmask_t ngx_http_memcached_next_upstream_masks[] = {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 { ngx_string("error"), NGX_HTTP_UPSTREAM_FT_ERROR },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 { ngx_string("timeout"), NGX_HTTP_UPSTREAM_FT_TIMEOUT },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51 { ngx_string("invalid_response"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52 { ngx_string("not_found"), NGX_HTTP_UPSTREAM_FT_HTTP_404 },
214
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
53 { ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF },
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54 { ngx_null_string, 0 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55 };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 static ngx_command_t ngx_http_memcached_commands[] = {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 { ngx_string("memcached_pass"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61 NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 ngx_http_memcached_pass,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
65 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
66
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
67 { ngx_string("memcached_connect_timeout"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 ngx_conf_set_msec_slot,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 offsetof(ngx_http_memcached_loc_conf_t, upstream.connect_timeout),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74 { ngx_string("memcached_send_timeout"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76 ngx_conf_set_msec_slot,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78 offsetof(ngx_http_memcached_loc_conf_t, upstream.send_timeout),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 { ngx_string("memcached_buffer_size"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83 ngx_conf_set_size_slot,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85 offsetof(ngx_http_memcached_loc_conf_t, upstream.buffer_size),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
88 { ngx_string("memcached_read_timeout"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
89 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
90 ngx_conf_set_msec_slot,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
91 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 offsetof(ngx_http_memcached_loc_conf_t, upstream.read_timeout),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
93 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95 { ngx_string("memcached_next_upstream"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
96 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_1MORE,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 ngx_conf_set_bitmask_slot,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98 NGX_HTTP_LOC_CONF_OFFSET,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 offsetof(ngx_http_memcached_loc_conf_t, upstream.next_upstream),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100 &ngx_http_memcached_next_upstream_masks },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102 { ngx_string("memcached_upstream_max_fails"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
104 ngx_http_memcached_upstream_max_fails_unsupported,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
105 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
106 0,
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
108
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109 { ngx_string("memcached_upstream_fail_timeout"),
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110 NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1,
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
111 ngx_http_memcached_upstream_fail_timeout_unsupported,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
112 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
113 0,
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114 NULL },
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116 ngx_null_command
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
117 };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
118
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
119
216
fa32d59d9a15 nginx 0.3.55
Igor Sysoev <http://sysoev.ru>
parents: 214
diff changeset
120 static ngx_http_module_t ngx_http_memcached_module_ctx = {
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121 NULL, /* preconfiguration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122 NULL, /* postconfiguration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
124 NULL, /* create main configuration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125 NULL, /* init main configuration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
126
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
127 NULL, /* create server configuration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
128 NULL, /* merge server configuration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
129
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
130 ngx_http_memcached_create_loc_conf, /* create location configration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
131 ngx_http_memcached_merge_loc_conf /* merge location configration */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
132 };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
133
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
134
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
135 ngx_module_t ngx_http_memcached_module = {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
136 NGX_MODULE_V1,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
137 &ngx_http_memcached_module_ctx, /* module context */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
138 ngx_http_memcached_commands, /* module directives */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
139 NGX_HTTP_MODULE, /* module type */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
140 NULL, /* init master */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
141 NULL, /* init module */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
142 NULL, /* init process */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
143 NULL, /* init thread */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
144 NULL, /* exit thread */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
145 NULL, /* exit process */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
146 NULL, /* exit master */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
147 NGX_MODULE_V1_PADDING
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
148 };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
149
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
150
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
151 static ngx_str_t ngx_http_memcached_key = ngx_string("memcached_key");
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
152
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
153
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
154 #define NGX_HTTP_MEMCACHED_END (sizeof(ngx_http_memcached_end) - 1)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
155 static u_char ngx_http_memcached_end[] = CRLF "END" CRLF;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
156
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
157
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
158 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
159 ngx_http_memcached_handler(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
160 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
161 ngx_int_t rc;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
162 ngx_http_upstream_t *u;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
163 ngx_http_memcached_ctx_t *ctx;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
164 ngx_http_memcached_loc_conf_t *mlcf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
165
194
003bd800ec2a nginx 0.3.44
Igor Sysoev <http://sysoev.ru>
parents: 178
diff changeset
166 if (!(r->method & (NGX_HTTP_GET|NGX_HTTP_HEAD))) {
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
167 return NGX_HTTP_NOT_ALLOWED;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
168 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
169
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 322
diff changeset
170 rc = ngx_http_discard_request_body(r);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
171
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 322
diff changeset
172 if (rc != NGX_OK) {
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
173 return rc;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
174 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
175
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
176 if (ngx_http_set_content_type(r) != NGX_OK) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
177 return NGX_HTTP_INTERNAL_SERVER_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
178 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
179
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
180 mlcf = ngx_http_get_module_loc_conf(r, ngx_http_memcached_module);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
181
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
182 u = ngx_pcalloc(r->pool, sizeof(ngx_http_upstream_t));
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
183 if (u == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
184 return NGX_HTTP_INTERNAL_SERVER_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
185 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
186
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
187 u->peer.log = r->connection->log;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
188 u->peer.log_error = NGX_ERROR_ERR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
189 #if (NGX_THREADS)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
190 u->peer.lock = &r->connection->lock;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
191 #endif
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
192
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
193 u->output.tag = (ngx_buf_tag_t) &ngx_http_memcached_module;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
194
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
195 u->conf = &mlcf->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
196
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
197 u->create_request = ngx_http_memcached_create_request;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
198 u->reinit_request = ngx_http_memcached_reinit_request;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
199 u->process_header = ngx_http_memcached_process_header;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
200 u->abort_request = ngx_http_memcached_abort_request;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
201 u->finalize_request = ngx_http_memcached_finalize_request;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
202
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
203 r->upstream = u;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
204
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
205 ctx = ngx_palloc(r->pool, sizeof(ngx_http_memcached_ctx_t));
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
206 if (ctx == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
207 return NGX_HTTP_INTERNAL_SERVER_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
208 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
209
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
210 ctx->rest = NGX_HTTP_MEMCACHED_END;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
211 ctx->request = r;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
212
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
213 ngx_http_set_ctx(r, ctx, ngx_http_memcached_module);
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
214
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
215 u->input_filter_init = ngx_http_memcached_filter_init;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
216 u->input_filter = ngx_http_memcached_filter;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
217 u->input_filter_ctx = ctx;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
218
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
219 ngx_http_upstream_init(r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
220
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
221 return NGX_DONE;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
222 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
223
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
224
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
225 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
226 ngx_http_memcached_create_request(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
227 {
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
228 size_t len;
322
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
229 uintptr_t escape;
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
230 ngx_buf_t *b;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
231 ngx_chain_t *cl;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
232 ngx_http_memcached_ctx_t *ctx;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
233 ngx_http_variable_value_t *vv;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
234 ngx_http_memcached_loc_conf_t *mlcf;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
235
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
236 mlcf = ngx_http_get_module_loc_conf(r, ngx_http_memcached_module);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
237
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
238 vv = ngx_http_get_indexed_variable(r, mlcf->index);
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
239
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
240 if (vv == NULL || vv->not_found || vv->len == 0) {
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
241 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
242 "the \"$memcached_key\" variable is not set");
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
243 return NGX_ERROR;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
244 }
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
245
322
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
246 escape = 2 * ngx_escape_uri(NULL, vv->data, vv->len, NGX_ESCAPE_MEMCACHED);
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
247
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
248 len = sizeof("get ") - 1 + vv->len + escape + sizeof(CRLF) - 1;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
249
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
250 b = ngx_create_temp_buf(r->pool, len);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
251 if (b == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
252 return NGX_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
253 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
254
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
255 cl = ngx_alloc_chain_link(r->pool);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
256 if (cl == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
257 return NGX_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
258 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
259
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
260 cl->buf = b;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
261 cl->next = NULL;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
262
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
263 r->upstream->request_bufs = cl;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
264
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
265 *b->last++ = 'g'; *b->last++ = 'e'; *b->last++ = 't'; *b->last++ = ' ';
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
266
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
267 ctx = ngx_http_get_module_ctx(r, ngx_http_memcached_module);
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
268
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
269 ctx->key.data = b->last;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
270
322
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
271 if (escape == 0) {
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
272 b->last = ngx_copy(b->last, vv->data, vv->len);
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
273
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
274 } else {
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
275 b->last = (u_char *) ngx_escape_uri(b->last, vv->data, vv->len,
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
276 NGX_ESCAPE_MEMCACHED);
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 310
diff changeset
277 }
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
278
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
279 ctx->key.len = b->last - ctx->key.data;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
280
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
281 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
282 "http memcached request: \"%V\"", &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
283
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
284 *b->last++ = CR; *b->last++ = LF;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
285
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
286 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
287 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
288
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
289
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
290 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
291 ngx_http_memcached_reinit_request(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
292 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
293 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
294 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
295
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
296
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
297 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
298 ngx_http_memcached_process_header(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
299 {
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
300 u_char *p, *len;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
301 ngx_str_t line;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
302 ngx_http_upstream_t *u;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
303 ngx_http_memcached_ctx_t *ctx;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
304
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
305 u = r->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
306
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
307 for (p = u->buffer.pos; p < u->buffer.last; p++) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
308 if (*p == LF) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
309 goto found;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
310 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
311 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
312
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
313 return NGX_AGAIN;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
314
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
315 found:
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
316
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
317 *p = '\0';
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
318
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
319 line.len = p - u->buffer.pos - 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
320 line.data = u->buffer.pos;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
321
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
322 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
323 "memcached: \"%V\"", &line);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
324
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
325 p = u->buffer.pos;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
326
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
327 ctx = ngx_http_get_module_ctx(r, ngx_http_memcached_module);
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
328
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
329 if (ngx_strncmp(p, "VALUE ", sizeof("VALUE ") - 1) == 0) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
330
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
331 p += sizeof("VALUE ") - 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
332
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
333 if (ngx_strncmp(p, ctx->key.data, ctx->key.len) != 0) {
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
334 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
335 "memcached sent invalid key in response \"%V\" "
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
336 "for key \"%V\"",
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
337 &line, &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
338
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
339 return NGX_HTTP_UPSTREAM_INVALID_HEADER;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
340 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
341
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
342 p += ctx->key.len;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
343
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
344 if (*p++ != ' ') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
345 goto no_valid;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
346 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
347
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
348 /* skip flags */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
349
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
350 while (*p) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
351 if (*p++ == ' ') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
352 goto length;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
353 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
354 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
355
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
356 goto no_valid;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
357
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
358 length:
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
359
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
360 len = p;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
361
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
362 while (*p && *p++ != CR) { /* void */ }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
363
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
364 r->headers_out.content_length_n = ngx_atoof(len, p - len - 1);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
365 if (r->headers_out.content_length_n == -1) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
366 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
367 "memcached sent invalid length in response \"%V\" "
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
368 "for key \"%V\"",
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
369 &line, &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
370 return NGX_HTTP_UPSTREAM_INVALID_HEADER;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
371 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
372
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
373 u->headers_in.status_n = 200;
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
374 u->state->status = 200;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
375 u->buffer.pos = p + 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
376
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
377 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
378 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
379
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
380 if (ngx_strcmp(p, "END\x0d") == 0) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
381 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
382 "key: \"%V\" was not found by memcached", &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
383
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
384 u->headers_in.status_n = 404;
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
385 u->state->status = 404;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
386
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
387 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
388 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
389
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
390 no_valid:
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
391
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
392 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
393 "memcached sent invalid response: \"%V\"", &line);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
394
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
395 return NGX_HTTP_UPSTREAM_INVALID_HEADER;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
396 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
397
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
398
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
399 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
400 ngx_http_memcached_filter_init(void *data)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
401 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
402 ngx_http_memcached_ctx_t *ctx = data;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
403
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
404 ngx_http_upstream_t *u;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
405
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
406 u = ctx->request->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
407
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
408 u->length += NGX_HTTP_MEMCACHED_END;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
409
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
410 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
411 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
412
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
413
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
414 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
415 ngx_http_memcached_filter(void *data, ssize_t bytes)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
416 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
417 ngx_http_memcached_ctx_t *ctx = data;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
418
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
419 u_char *last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
420 ngx_buf_t *b;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
421 ngx_chain_t *cl, **ll;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
422 ngx_http_upstream_t *u;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
423
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
424 u = ctx->request->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
425 b = &u->buffer;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
426
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
427 if (u->length == ctx->rest) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
428
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
429 if (ngx_strncmp(b->last,
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
430 ngx_http_memcached_end + NGX_HTTP_MEMCACHED_END - ctx->rest,
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
431 ctx->rest)
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
432 != 0)
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
433 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
434 ngx_log_error(NGX_LOG_ERR, ctx->request->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
435 "memcached sent invalid trailer");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
436 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
437
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
438 u->length = 0;
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
439 ctx->rest = 0;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
440
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
441 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
442 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
443
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
444 for (cl = u->out_bufs, ll = &u->out_bufs; cl; cl = cl->next) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
445 ll = &cl->next;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
446 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
447
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
448 cl = ngx_chain_get_free_buf(ctx->request->pool, &u->free_bufs);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
449 if (cl == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
450 return NGX_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
451 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
452
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
453 cl->buf->flush = 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
454 cl->buf->memory = 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
455
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
456 *ll = cl;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
457
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
458 last = b->last;
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
459 cl->buf->pos = last;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
460 b->last += bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
461 cl->buf->last = b->last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
462
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
463 ngx_log_debug4(NGX_LOG_DEBUG_HTTP, ctx->request->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
464 "memcached filter bytes:%z size:%z length:%z rest:%z",
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
465 bytes, b->last - b->pos, u->length, ctx->rest);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
466
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
467 if (bytes <= (ssize_t) (u->length - NGX_HTTP_MEMCACHED_END)) {
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
468 u->length -= bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
469 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
470 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
471
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
472 last += u->length - NGX_HTTP_MEMCACHED_END;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
473
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
474 if (ngx_strncmp(last, ngx_http_memcached_end, b->last - last) != 0) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
475 ngx_log_error(NGX_LOG_ERR, ctx->request->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
476 "memcached sent invalid trailer");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
477 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
478
340
10cc350ed8a1 nginx 0.6.14
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
479 ctx->rest -= b->last - last;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
480 b->last = last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
481 cl->buf->last = last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
482 u->length = ctx->rest;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
483
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
484 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
485 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
486
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
487
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
488 static void
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
489 ngx_http_memcached_abort_request(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
490 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
491 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
492 "abort http memcached request");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
493 return;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
494 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
495
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
496
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
497 static void
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
498 ngx_http_memcached_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
499 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
500 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
501 "finalize http memcached request");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
502 return;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
503 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
504
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
505
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
506 static void *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
507 ngx_http_memcached_create_loc_conf(ngx_conf_t *cf)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
508 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
509 ngx_http_memcached_loc_conf_t *conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
510
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
511 conf = ngx_pcalloc(cf->pool, sizeof(ngx_http_memcached_loc_conf_t));
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
512 if (conf == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
513 return NGX_CONF_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
514 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
515
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
516 /*
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
517 * set by ngx_pcalloc():
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
518 *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
519 * conf->upstream.bufs.num = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
520 * conf->upstream.next_upstream = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
521 * conf->upstream.temp_path = NULL;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
522 * conf->upstream.schema = { 0, NULL };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
523 * conf->upstream.uri = { 0, NULL };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
524 * conf->upstream.location = NULL;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
525 *
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
526 * conf->index = 0;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
527 */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
528
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
529 conf->upstream.connect_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
530 conf->upstream.send_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
531 conf->upstream.read_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
532
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
533 conf->upstream.buffer_size = NGX_CONF_UNSET_SIZE;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
534
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
535 /* the hardcoded values */
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
536 conf->upstream.cyclic_temp_file = 0;
178
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
537 conf->upstream.buffering = 0;
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
538 conf->upstream.ignore_client_abort = 0;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
539 conf->upstream.send_lowat = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
540 conf->upstream.bufs.num = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
541 conf->upstream.busy_buffers_size = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
542 conf->upstream.max_temp_file_size = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
543 conf->upstream.temp_file_write_size = 0;
206
3866d57d9cfd nginx 0.3.50
Igor Sysoev <http://sysoev.ru>
parents: 198
diff changeset
544 conf->upstream.intercept_errors = 1;
224
9909a161eb28 nginx 0.3.59
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
545 conf->upstream.intercept_404 = 1;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
546 conf->upstream.pass_request_headers = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
547 conf->upstream.pass_request_body = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
548
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
549 return conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
550 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
551
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
552
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
553 static char *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
554 ngx_http_memcached_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
555 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
556 ngx_http_memcached_loc_conf_t *prev = parent;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
557 ngx_http_memcached_loc_conf_t *conf = child;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
558
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
559 ngx_conf_merge_msec_value(conf->upstream.connect_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
560 prev->upstream.connect_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
561
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
562 ngx_conf_merge_msec_value(conf->upstream.send_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
563 prev->upstream.send_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
564
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
565 ngx_conf_merge_msec_value(conf->upstream.read_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
566 prev->upstream.read_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
567
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
568 ngx_conf_merge_size_value(conf->upstream.buffer_size,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
569 prev->upstream.buffer_size,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
570 (size_t) ngx_pagesize);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
571
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
572 ngx_conf_merge_bitmask_value(conf->upstream.next_upstream,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
573 prev->upstream.next_upstream,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
574 (NGX_CONF_BITMASK_SET
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
575 |NGX_HTTP_UPSTREAM_FT_ERROR
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
576 |NGX_HTTP_UPSTREAM_FT_TIMEOUT));
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
577
214
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
578 if (conf->upstream.next_upstream & NGX_HTTP_UPSTREAM_FT_OFF) {
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
579 conf->upstream.next_upstream = NGX_CONF_BITMASK_SET
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
580 |NGX_HTTP_UPSTREAM_FT_OFF;
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
581 }
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
582
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
583 return NGX_CONF_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
584 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
585
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
586
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
587 static char *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
588 ngx_http_memcached_pass(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
589 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
590 ngx_http_memcached_loc_conf_t *lcf = conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
591
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
592 ngx_str_t *value;
252
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
593 ngx_url_t u;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
594 ngx_http_core_loc_conf_t *clcf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
595
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
596 if (lcf->upstream.schema.len) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
597 return "is duplicate";
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
598 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
599
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
600 value = cf->args->elts;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
601
252
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
602 ngx_memzero(&u, sizeof(ngx_url_t));
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
603
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
604 u.url = value[1];
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
605 u.no_resolve = 1;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
606
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
607 lcf->upstream.upstream = ngx_http_upstream_add(cf, &u, 0);
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
608 if (lcf->upstream.upstream == NULL) {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
609 return NGX_CONF_ERROR;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
610 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
611
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
612 lcf->upstream.schema.len = sizeof("memcached://") - 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
613 lcf->upstream.schema.data = (u_char *) "memcached://";
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
614
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
615 clcf = ngx_http_conf_get_module_loc_conf(cf, ngx_http_core_module);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
616
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
617 clcf->handler = ngx_http_memcached_handler;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
618
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
619 lcf->upstream.location = clcf->name;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
620
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
621 if (clcf->name.data[clcf->name.len - 1] == '/') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
622 clcf->auto_redirect = 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
623 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
624
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
625 lcf->index = ngx_http_get_variable_index(cf, &ngx_http_memcached_key);
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
626
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
627 if (lcf->index == NGX_ERROR) {
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
628 return NGX_CONF_ERROR;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
629 }
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
630
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
631 return NGX_CONF_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
632 }
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
633
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
634
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
635 static char *
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
636 ngx_http_memcached_upstream_max_fails_unsupported(ngx_conf_t *cf,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
637 ngx_command_t *cmd, void *conf)
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
638 {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
639 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
640 "\"memcached_upstream_max_fails\" is not supported, "
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
641 "use the \"max_fails\" parameter of the \"server\" directive ",
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
642 "inside the \"upstream\" block");
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
643
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
644 return NGX_CONF_ERROR;
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
645 }
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
646
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
647
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
648 static char *
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
649 ngx_http_memcached_upstream_fail_timeout_unsupported(ngx_conf_t *cf,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
650 ngx_command_t *cmd, void *conf)
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
651 {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
652 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
653 "\"memcached_upstream_fail_timeout\" is not supported, "
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
654 "use the \"fail_timeout\" parameter of the \"server\" directive ",
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
655 "inside the \"upstream\" block");
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
656
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
657 return NGX_CONF_ERROR;
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
658 }