annotate src/http/modules/ngx_http_memcached_module.c @ 282:675a39fd14cd NGINX_0_5_11

nginx 0.5.11 *) Feature: now configure detects system PCRE library in MacPorts. Thanks to Chris McGrath. *) Bugfix: the response was incorrect if several ranges were requested; bug appeared in 0.5.6. *) Bugfix: the "create_full_put_path" directive could not create the intermediate directories if no "dav_access" directive was set. Thanks to Evan Miller. *) Bugfix: the "0" response code might be logged in the access_log instead of the "400" and "408" error codes. *) Bugfix: a segmentation fault might occur in worker process if nginx was built with -O2 optimization.
author Igor Sysoev <http://sysoev.ru>
date Mon, 05 Feb 2007 00:00:00 +0300
parents 704622b2528a
children 95d92ec39071
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
170 rc = ngx_http_discard_body(r);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
171
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
172 if (rc != NGX_OK && rc != NGX_AGAIN) {
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;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
229 ngx_buf_t *b;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
230 ngx_chain_t *cl;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
231 ngx_http_memcached_ctx_t *ctx;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
232 ngx_http_variable_value_t *vv;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
233 ngx_http_memcached_loc_conf_t *mlcf;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
234
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
235 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
236
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
237 vv = ngx_http_get_indexed_variable(r, mlcf->index);
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
238
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
239 if (vv == NULL || vv->not_found || vv->len == 0) {
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
240 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
241 "the \"$memcached_key\" variable is not set");
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
242 return NGX_ERROR;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
243 }
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
244
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
245 len = sizeof("get ") - 1 + vv->len + sizeof(CRLF) - 1;
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
246 if (vv->len) {
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
247 len += 1 + vv->len;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
248 }
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
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
271 b->last = ngx_copy(b->last, vv->data, vv->len);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
272
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
273 ctx->key.len = b->last - ctx->key.data;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
274
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
275 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
276 "http memcached request: \"%V\"", &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
277
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
278 *b->last++ = CR; *b->last++ = LF;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
279
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
280 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
281 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
282
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
283
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
284 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
285 ngx_http_memcached_reinit_request(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
286 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
287 return NGX_OK;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
291 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
292 ngx_http_memcached_process_header(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
293 {
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
294 u_char *p, *len;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
295 ngx_str_t line;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
296 ngx_http_upstream_t *u;
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
297 ngx_http_memcached_ctx_t *ctx;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
298
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
299 u = r->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
300
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
301 for (p = u->buffer.pos; p < u->buffer.last; p++) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
302 if (*p == LF) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
303 goto found;
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 }
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 return NGX_AGAIN;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
308
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
309 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 *p = '\0';
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 line.len = p - u->buffer.pos - 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
314 line.data = u->buffer.pos;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
315
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
316 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
317 "memcached: \"%V\"", &line);
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 p = u->buffer.pos;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
320
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
321 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
322
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
323 if (ngx_strncmp(p, "VALUE ", sizeof("VALUE ") - 1) == 0) {
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 += sizeof("VALUE ") - 1;
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 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
328 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
329 "memcached sent invalid key in response \"%V\" "
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
330 "for key \"%V\"",
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
331 &line, &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
332
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
333 return NGX_HTTP_UPSTREAM_INVALID_HEADER;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
334 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
335
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
336 p += ctx->key.len;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
337
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
338 if (*p++ != ' ') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
339 goto no_valid;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
342 /* skip flags */
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 while (*p) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
345 if (*p++ == ' ') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
346 goto length;
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 }
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 goto no_valid;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
351
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
352 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 len = p;
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 while (*p && *p++ != CR) { /* void */ }
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 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
359 if (r->headers_out.content_length_n == -1) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
360 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
361 "memcached sent invalid length in response \"%V\" "
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
362 "for key \"%V\"",
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 130
diff changeset
363 &line, &ctx->key);
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
364 return NGX_HTTP_UPSTREAM_INVALID_HEADER;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
365 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
366
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
367 u->headers_in.status_n = 200;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
368 u->buffer.pos = p + 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
369
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
370 return NGX_OK;
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 if (ngx_strcmp(p, "END\x0d") == 0) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
374 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
375 "key: \"%V\" was not found by memcached", &ctx->key);
130
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 u->headers_in.status_n = 404;
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 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
380 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
381
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
382 no_valid:
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 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
385 "memcached sent invalid response: \"%V\"", &line);
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_HTTP_UPSTREAM_INVALID_HEADER;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
391 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
392 ngx_http_memcached_filter_init(void *data)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
393 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
394 ngx_http_memcached_ctx_t *ctx = data;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
395
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
396 ngx_http_upstream_t *u;
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 u = ctx->request->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
399
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
400 u->length += NGX_HTTP_MEMCACHED_END;
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 return NGX_OK;
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
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 static ngx_int_t
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
407 ngx_http_memcached_filter(void *data, ssize_t bytes)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
408 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
409 ngx_http_memcached_ctx_t *ctx = data;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
410
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
411 u_char *last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
412 ngx_buf_t *b;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
413 ngx_chain_t *cl, **ll;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
414 ngx_http_upstream_t *u;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
415
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
416 u = ctx->request->upstream;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
417 b = &u->buffer;
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 if (u->length == ctx->rest) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
420
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
421 if (ngx_strncmp(b->last,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
422 ngx_http_memcached_end + NGX_HTTP_MEMCACHED_END
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
423 - ctx->rest,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
424 bytes) != 0)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
425 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
426 ngx_log_error(NGX_LOG_ERR, ctx->request->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
427 "memcached sent invalid trailer");
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
430 u->length -= bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
431 ctx->rest -= bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
432
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
433 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
434 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
435
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
436 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
437 ll = &cl->next;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
438 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
439
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
440 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
441 if (cl == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
442 return NGX_ERROR;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
445 cl->buf->flush = 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
446 cl->buf->memory = 1;
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 *ll = cl;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
449
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
450 cl->buf->pos = b->last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
451 b->last += bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
452 cl->buf->last = b->last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
453
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
454 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
455 "memcached filter bytes:%z size:%z length:%z rest:%z",
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
456 bytes, b->last - b->pos, u->length, ctx->rest);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
457
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
458 if (b->last - b->pos <= (ssize_t) (u->length - NGX_HTTP_MEMCACHED_END)) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
459 u->length -= bytes;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
460 return NGX_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
461 }
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
464 last = b->pos + u->length - NGX_HTTP_MEMCACHED_END;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
465
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
466 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
467 ngx_log_error(NGX_LOG_ERR, ctx->request->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
468 "memcached sent invalid trailer");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
469 }
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 ctx->rest = u->length - (b->last - b->pos);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
472 b->last = last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
473 cl->buf->last = last;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
474 u->length = ctx->rest;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
475
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
476 return NGX_OK;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
479
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
480 static void
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
481 ngx_http_memcached_abort_request(ngx_http_request_t *r)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
482 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
483 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
484 "abort http memcached request");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
485 return;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
489 static void
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
490 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
491 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
492 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
493 "finalize http memcached request");
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
494 return;
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
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
498 static void *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
499 ngx_http_memcached_create_loc_conf(ngx_conf_t *cf)
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
500 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
501 ngx_http_memcached_loc_conf_t *conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
502
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
503 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
504 if (conf == NULL) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
505 return NGX_CONF_ERROR;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
506 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
507
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 * set by ngx_pcalloc():
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->upstream.bufs.num = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
512 * conf->upstream.next_upstream = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
513 * conf->upstream.temp_path = NULL;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
514 * conf->upstream.schema = { 0, NULL };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
515 * conf->upstream.uri = { 0, NULL };
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
516 * conf->upstream.location = NULL;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
517 *
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
518 * conf->index = 0;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
519 */
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
520
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
521 conf->upstream.connect_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
522 conf->upstream.send_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
523 conf->upstream.read_timeout = NGX_CONF_UNSET_MSEC;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
524
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
525 conf->upstream.buffer_size = NGX_CONF_UNSET_SIZE;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
526
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
527 /* the hardcoded values */
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
528 conf->upstream.cyclic_temp_file = 0;
178
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
529 conf->upstream.buffering = 0;
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
530 conf->upstream.ignore_client_abort = 0;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
531 conf->upstream.send_lowat = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
532 conf->upstream.bufs.num = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
533 conf->upstream.busy_buffers_size = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
534 conf->upstream.max_temp_file_size = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
535 conf->upstream.temp_file_write_size = 0;
206
3866d57d9cfd nginx 0.3.50
Igor Sysoev <http://sysoev.ru>
parents: 198
diff changeset
536 conf->upstream.intercept_errors = 1;
224
9909a161eb28 nginx 0.3.59
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
537 conf->upstream.intercept_404 = 1;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
538 conf->upstream.pass_request_headers = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
539 conf->upstream.pass_request_body = 0;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
540
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
541 return conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
542 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
543
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
544
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
545 static char *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
546 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
547 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
548 ngx_http_memcached_loc_conf_t *prev = parent;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
549 ngx_http_memcached_loc_conf_t *conf = child;
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 ngx_conf_merge_msec_value(conf->upstream.connect_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
552 prev->upstream.connect_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
553
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
554 ngx_conf_merge_msec_value(conf->upstream.send_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
555 prev->upstream.send_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
556
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
557 ngx_conf_merge_msec_value(conf->upstream.read_timeout,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
558 prev->upstream.read_timeout, 60000);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
559
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
560 ngx_conf_merge_size_value(conf->upstream.buffer_size,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
561 prev->upstream.buffer_size,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
562 (size_t) ngx_pagesize);
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
563
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
564 ngx_conf_merge_bitmask_value(conf->upstream.next_upstream,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
565 prev->upstream.next_upstream,
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
566 (NGX_CONF_BITMASK_SET
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
567 |NGX_HTTP_UPSTREAM_FT_ERROR
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
568 |NGX_HTTP_UPSTREAM_FT_TIMEOUT));
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
569
214
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
570 if (conf->upstream.next_upstream & NGX_HTTP_UPSTREAM_FT_OFF) {
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
571 conf->upstream.next_upstream = NGX_CONF_BITMASK_SET
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
572 |NGX_HTTP_UPSTREAM_FT_OFF;
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
573 }
0ad9eeb6ac7f nginx 0.3.54
Igor Sysoev <http://sysoev.ru>
parents: 212
diff changeset
574
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
575 return NGX_CONF_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
576 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
577
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
578
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
579 static char *
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
580 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
581 {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
582 ngx_http_memcached_loc_conf_t *lcf = conf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
583
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
584 ngx_str_t *value;
252
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
585 ngx_url_t u;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
586 ngx_http_core_loc_conf_t *clcf;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
587
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
588 if (lcf->upstream.schema.len) {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
589 return "is duplicate";
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
590 }
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 value = cf->args->elts;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
593
252
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
594 ngx_memzero(&u, sizeof(ngx_url_t));
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
595
644510700914 nginx 0.4.11
Igor Sysoev <http://sysoev.ru>
parents: 224
diff changeset
596 u.url = value[1];
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
597 u.no_resolve = 1;
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
598 /* u.uri_part = 1; may be used as namespace */
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
599
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
600 lcf->upstream.upstream = ngx_http_upstream_add(cf, &u, 0);
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
601 if (lcf->upstream.upstream == NULL) {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
602 return NGX_CONF_ERROR;
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
603 }
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
604
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
605 lcf->upstream.schema.len = sizeof("memcached://") - 1;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
606 lcf->upstream.schema.data = (u_char *) "memcached://";
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
607
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
608 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
609
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
610 clcf->handler = ngx_http_memcached_handler;
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.location = clcf->name;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
613
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
614 if (clcf->name.data[clcf->name.len - 1] == '/') {
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
615 clcf->auto_redirect = 1;
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
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
618 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
619
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
620 if (lcf->index == NGX_ERROR) {
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
621 return NGX_CONF_ERROR;
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
622 }
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 266
diff changeset
623
130
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
624 return NGX_CONF_OK;
82d695e3d662 nginx 0.3.12
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
625 }
260
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
626
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
627
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
628 static char *
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
629 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
630 ngx_command_t *cmd, void *conf)
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
631 {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
632 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
633 "\"memcached_upstream_max_fails\" is not supported, "
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
634 "use the \"max_fails\" parameter of the \"server\" directive ",
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
635 "inside the \"upstream\" block");
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
636
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
637 return NGX_CONF_ERROR;
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
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
640
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
641 static char *
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
642 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
643 ngx_command_t *cmd, void *conf)
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
644 {
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
645 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
646 "\"memcached_upstream_fail_timeout\" is not supported, "
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
647 "use the \"fail_timeout\" parameter of the \"server\" directive ",
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
648 "inside the \"upstream\" block");
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
649
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
650 return NGX_CONF_ERROR;
0effe91f6083 nginx 0.5.0
Igor Sysoev <http://sysoev.ru>
parents: 252
diff changeset
651 }