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);
标题名称:nginx+memcached直连memcachednginx第三方模块ngx_http_upstream_consistent_hash
转载注明:http://scpingwu.com/article/gcpeio.html