首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ngx_http_memcached_module

  • 示例配置
  • 指令
  • memcached_bind
  • memcached_buffer_size
  • memcached_connect_timeout
  • memcached_force_ranges
  • memcached_gzip_flag
  • memcached_next_upstream
  • memcached_next_upstream_timeout
  • memcached_next_upstream_tries
  • memcached_pass
  • memcached_read_timeout
  • memcached_send_timeout
  • 嵌入式变量

ngx_http_memcached_module模块用于从memcached服务器获取响应。密钥在$memcached_key变量中设置。应通过nginx之外的方式提前将响应放入memcached。

示例配置

代码语言:javascript
复制
server {
    location / {
        set            $memcached_key "$uri?$args";
        memcached_pass host:11211;
        error_page     404 502 504 = @fallback;
    }

    location @fallback {
        proxy_pass     http://backend;
    }
}

指令

句法:

memcached_bind address transparent | off;

默认:

语境:

http,服务器,位置

通过可选端口(1.11.2)从指定的本地IP地址发出到memcached服务器的传出连接。参数值可以包含变量(1.3.12)。特殊值off(1.3.12)取消了memcached_bind从前一个配置级别继承的指令的效果,这允许系统自动分配本地IP地址和端口。

transparent参数(1.11.0)允许分布式缓存服务器传出连接从一个非本地的IP地址发起,例如,来自客户端的实际IP地址:

代码语言:javascript
复制
memcached_bind $remote_addr transparent;

为了使此参数起作用,需要以超级用户权限运行nginx工作进程,并配置内核路由表以拦截来自memcached服务器的网络流量。

句法:

memcached_buffer_size size;

默认:

memcached_buffer_size 4k | 8k;

语境:

http,服务器,位置

设置用于读取从memcached服务器接收到的响应的缓冲区的大小。 一旦收到响应,响应便会同步传递给客户端。

句法:

memcached_connect_timeout时间;

默认:

memcached_connect_timeout 60s;

语境:

http,服务器,位置

定义与memcached服务器建立连接的超时时间。应该指出的是,这个超时通常不能超过75秒。

句法:

memcached_force_ranges开启| 关闭;

默认:

memcached_force_ranges off;

语境:

http,服务器,位置

无论这些响应中的“接受范围”字段如何,都可以对来自memcached服务器的缓存和未缓存的响应启用字节范围支持。

句法:

memcached_gzip_flag标志;

默认:

语境:

http,服务器,位置

启用对flagmemcached服务器响应中状态的测试,并在标志设置时将“ Content-Encoding”响应标题字段设置为“ gzip”。

句法:

memcached_next_upstream错误| 超时| invalid_response | not_found | 关闭...;

默认:

memcached_next_upstream错误超时;

语境:

http,服务器,位置

指定在哪些情况下请求应传递给下一台服务器:

error在与服务器建立连接,传递请求或读取响应头时发生错误; timeout在与服务器建立连接,传递请求或读取响应头时发生超时; invalid_response服务器返回了空的或无效的响应; not_found在服务器上未找到响应; off禁用将请求传递给下一个服务器。

人们应该记住,只有在没有任何内容发送给客户端的情况下,才能将请求传递到下一个服务器。也就是说,如果在响应传输过程中发生错误或超时,修复这是不可能的。

该指令还定义了与服务器进行通信的不成功尝试。 即使未在指令中指定错误,超时和invalid_response的情况,也总是被视为不成功尝试。 not_found的情况永远不会被视为不成功的尝试。

将请求传递给下一台服务器可能受到尝试次数和时间的限制。

句法:

memcached_next_upstream_timeout时间;

默认:

memcached_next_upstream_timeout 0;

语境:

http,服务器,位置

限制请求可以传递到下一个服务器的时间。该0值将关闭此限制。

句法:

memcached_next_upstream_tries数字;

默认:

memcached_next_upstream_tries 0;

语境:

http,服务器,位置

限制将请求传递到下一个服务器的可能尝试次数。该0值将关闭此限制。

句法:

memcached_pa??ss地址;

默认:

语境:

位置,如果在位置

设置memcached服务器地址。该地址可以指定为域名或IP地址,以及端口:

代码语言:javascript
复制
memcached_pass localhost:11211;

或者作为UNIX域套接字路径:

代码语言:javascript
复制
memcached_pass unix:/tmp/memcached.socket;

如果域名解析为多个地址,则所有这些地址都将以循环方式使用。另外,地址可以被指定为服务器组。

句法:

memcached_read_timeout时间;

默认:

memcached_read_timeout 60s;

语境:

http,服务器,位置

定义从memcached服务器读取响应的超时。超时只在两次连续的读操作之间设置,而不是用于传输整个响应。如果memcached服务器在此时间内没有传输任何内容,则连接将被关闭。

句法:

memcached_send_timeout时间;

默认:

memcached_send_timeout 60s;

语境:

http,服务器,位置

设置将请求传输到memcached服务器的超时时间。超时只在两次连续写入操作之间设置,而不是用于传输整个请求。如果memcached服务器在此时间内没有收到任何内容,则连接关闭。

嵌入式变量

$memcached_key 定义从memcached服务器获取响应的键值。

扫码关注腾讯云开发者

领取腾讯云代金券

http://www.vxiaotou.com