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);
转载于:https://blog.51cto.com/11826969/1951923