zoukankan      html  css  js  c++  java
  • Nginx详解二十四:Nginx深度学习篇之灰度发布

    实战场景 - 灰度发布

    灰度发布的作用:按照一定的关系区别,分部分的代码进行上线,使代码的发布能平滑过渡上线
    实现方式:
      1、用户的信息cookie等信息区别
      2、根据用户的IP地址

    安装memcached:yum -y install memcached

    准备好两个tomcat,9090代表生产环境,8080代表预发布环境

    为避免冲突,修改tomcat9090的端口号

     

     这里分别在同个tomcat/webapp/ROOT/下放了同样内容的jsp文件

    把8080下的jsp问价内容改一下区别于9090

    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
    <HTML>
      <HEAD>
        <TITLE>JSP Test Page</TITLE>
      </HEAD>
      <BODY>
        <%
          Random rand = new Random();
          out.println("<h1>Test server:</h1>");
          out.println("<h1>Random number:</h1>");
          out.println(rand.nextInt(99)+100);
        %>
      </BODY>
    </HTML>

    启动两个tomcat

    查看进程

    查看端口

    启动memcached

    查看进程

    查看端口号

    安装lua调用memcache的模块

    写个脚本执行

    wget https://github.com/agentzh/lua-resty-memcached/archive/v0.11.tar.gz
    tar -zxvf v0.11.tar.gz
    mkdir /usr/local/share/lua
    mkdir /usr/local/share/lua/5.1/
    cp -r lua-resty-memcached-0.11/lib/resty /usr/local/share/lua/5.1/

    运行脚本,如果出现404,则手动去脚本里那个网站下载安装包并手动执行脚本里面的安装步骤

    准备好一个lua脚本,放在/opt/app/lua下

    clientIP = ngx.req.get_headers()["X-Real-IP"]
    if clientIP == nil then
      clientIP = ngx.req.get_headers()["x_forwarded_for"]
    end
    if clientIP == nil then
      clientIP = ngx.var.remote_addr
    end
      local memcached = require "resty.memcached"
      local memc, err = memcached:new()
      if not memc then
        ngx.say("failed to instantiate memc: ", err)
        return
      end
      local ok, err = memc:connect("127.0.0.1", 11211)
      if not ok then
        ngx.say("failed to connect: ", err)
        return
      end
      local res, flags, err = memc:get(clientIP)
      ngx.say("value key: ",res,clientIP)
      if err then
        ngx.say("failed to get clientIP ", err)
      return
      end
      if res == "1" then
        ngx.exec("@server_test")
      return
      end

      ngx.exec("@server")

     编辑配置文件

    把原来的location删掉,添加新的location

    location /hello {
      default_type 'text/plain';
      content_by_lua 'ngx.say("hello, lua")';
    }
    location /myip{
      default_type 'text/plain';
      content_by_lua '
        clientIP = ngx.req.get_headers()["x_forwarded_for"]
        ngx.say("IP:",clientIP)
        ';
    }
    location /{
      default_type "text/html";
      content_by_lua_file /opt/app/lua/dep.lua;
    }

    location @server{
      proxy_pass http://127.0.0.1:9090;
    }

    location @server_test{
      proxy_pass http://127.0.0.1:8080;
    }

    由于这里没有写后台代码,所以使用telnet命令手动setip到memcached里面,实现指定IP访问预发布环境

    如果出现以下问题

    解决方法: 安装telnet服务
    centos、ubuntu安装telnet命令的方法.
    yum list telnet* 列出telnet  相关的安装包
    yum install telnet-server    安装telnet服务
    yum install telnet.*    安装telnet客户端

    依次输入以下内容,即可把192.168.56.1加入到访问预发布环境的IP列表中 

    telnet 127.0.0.1 11211
    set 192.168.56.1 0 0 1
    1

    这里如果要退出的话,按ctrl+]
    再输入quit就可以了

    检查语法,并重载
    nginx -tc /etc/nginx/nginx.conf
    nginx -s reload -c /etc/nginx/nginx.conf

     

    访问location

     

    用前面set好的IP访问

    切换IP访问

  • 相关阅读:
    BZOJ4416 [Shoi2013]阶乘字符串 【序列自动机 + 状压dp】
    BZOJ2159 Crash 的文明世界 【第二类斯特林数 + 树形dp】
    快速求原根
    BZOJ2530 [Poi2011]Party 【贪心】
    BZOJ2213 [Poi2011]Difference 【乱搞】
    BZOJ2276 [Poi2011]Temperature 【单调队列】
    多项式除法
    loj2538 「PKUWC2018」Slay the Spire 【dp】
    loj2537 「PKUWC2018」Minimax 【概率 + 线段树合并】
    Java多线程之线程的暂停
  • 原文地址:https://www.cnblogs.com/zhongyehai/p/10544211.html
Copyright © 2011-2022 走看看