千家信息网

nginx+memcached直连memcached nginx第三方模块ngx_http_upstream_consistent_hash

发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,1、首先在https://www.nginx.com/resources/wiki/modules/consistent_hash/官网下载ngx_http_upstream_consistent_h
千家信息网最后更新 2025年12月01日nginx+memcached直连memcached nginx第三方模块ngx_http_upstream_consistent_hash

1、首先在https://www.nginx.com/resources/wiki/modules/consistent_hash/官网下载ngx_http_upstream_consistent_hash

2、解压unzip master.zip 得到ngx_http_consistent_hash-master文件夹

3、重新编译nginx

先用/Data/apps/nginx/sbin/nginx -V 看一下原来的编译选项 还用原来的编译选项进行安装先停掉nginx服务

./configure --prefix=/Data/apps/nginx --with-pcre=/usr/local/src/pcre-8.00 --with-zlib=/usr/local/src/zlib-1.2.11 --add-module=/usr/local/src/ngx_http_consistent_hash-master

加上ngx_http_consistent_hash的选项之后 make && make install


4、nginx 配置一组memcached上游服务器

通过memcached_pass指令指定服务器组

并且通过error_page 404 = /callback.php指定没有加载到缓存的时候的回调页面 在回调页面中也以一致性哈希的方式读取和设置缓存。如果装的是memcache扩展

upstream memcacheserver {

consistent_hash $request_uri;

server 127.0.0.1:11211;

server 127.0.0.1:11212;

server 127.0.0.1:11213;

}

server {

listen 7000;

server_name 47.93.5.10;

root /Data/sijunjie/web;

index index.html;


location / {

default_type text/html;

set $memcached_key "$uri?$args";

memcached_pass memcacheserver;

error_page 404 = /callback.php;

}

location ~ \.php$ {

root /Data/sijunjie/web;

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;

include fastcgi_params;

}

}


5、配置php

extension=/Data/apps/php/lib/php/extensions/no-debug-non-zts-20131226/memcache.so

memcache.hash_strategy=consistent(这个指令会使用一致性哈希方式分布key)这样就可以和nginx保持一致了


6、callback.php里面的处理存取 由于第5步配置了一致性哈希的分布 这里添加的三台服务器和nginx中保持一致。

$memcache = new Memcache();

$memcache->addServer('127.0.0.1', 11211);

$memcache->addServer('127.0.0.1', 11212);

$memcache->addServer('127.0.0.1', 11213);

0