我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

nginx+memcached直连memcachednginx第三方模块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);


分享标题:nginx+memcached直连memcachednginx第三方模块ngx_http_upstream_consistent_hash
文章网址:http://shouzuofang.com/article/gcpeio.html

其他资讯