Skip to main content
您好,欢迎光临IDC汇,需要什么服务器直接咨询客服,方便快捷。客服QQ 点击这里给我发消息
首页 > 服务器技术 »正文

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

服务器技术 webadmin 2020-06-25 08:46:44 查看评论 加入收藏

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);

广告06

微信