Web服务不停机更新和灰度发布方案

Web服务不停机更新和灰度发布方案

当前情况

Web服务需要改造成使用jwt登陆访问。因此可以使用nginx进行不停机更新。

方案一 负载均衡:

image-20210326170212473

将新版本另起一个端口,nginx中配置负载均衡,并反向代理到新旧两个服务。若新服务功能正常,则可关闭旧版本,只使用新版本。

配置如图:

http {  
    upstream cluster {  
        server 192.168.1.210:80 weight=5;  
        server 192.168.1.211:80 weight=3;  
        server 192.168.1.212:80 weight=1;  
    }  
   
    server {  
      listen 80;  
  
      location / {  
        proxy_pass http://cluster;  
      }  
    }  
}  

问题:

怎么判断 新服务功能正常

一个可行的解决方案是 特定的测试人员测试新版本的功能,确认功能无误后,关闭旧版本启用新版本。这就涉及到灰度发布了。

方案二 灰度发布:

image-20210326172703312

使用nginx进行灰度发布。

我们可在nginx上根据请求来源ip或者cookie来判断当前请求是否来自测试人员,若判断为测试人员,则将请求直接导向至新服务。

用IF指令实现

https://www.jianshu.com/p/e89ad8748764

两台服务器分别定义为:

hilinux_01  192.168.1.100:8080
hilinux_02  192.168.1.200:8080

根据来源ip做判断

upstream hilinux_01 {
    server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}

upstream hilinux_02 {
    server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
}

upstream default {
    server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}

server {
  listen 80;
  server_name  www.hi-linux.com;
  access_log  logs/www.hi-linux.com.log  main;

  set $group default;
  if ($remote_addr ~ "211.118.119.11") {
      set $group hilinux_02;
  }

 location / {                       
    proxy_pass http://$group;
    proxy_set_header   Host             $host;
    proxy_set_header   X-Real-IP        $remote_addr;
    proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
    index  index.html index.htm;
  }
}

根据cookie做判断

upstream hilinux_01 {
    server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}

upstream hilinux_02 {
    server 192.168.1.200:8080 max_fails=1 fail_timeout=60;
}

upstream default {
    server 192.168.1.100:8080 max_fails=1 fail_timeout=60;
}

server {
  listen 80;
  server_name  www.akhack.com;
  access_log  logs/www.akhack.com.log  main;

  #match cookie
  set $group "default";
    if ($http_cookie ~* "version=V1"){
        set $group hilinux_01;
    }

    if ($http_cookie ~* "version=V2"){
        set $group hilinux_02;
    }

  location / {                       
    proxy_pass http://$group;
    proxy_set_header   Host             $host;
    proxy_set_header   X-Real-IP        $remote_addr;
    proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
    index  index.html index.htm;
  }
 }

使用lua写脚本实现

参考: https://my.oschina.net/ososchina/blog/905378

使用nginx+lua实现web项目的灰度发布

location / {
	content_by_lua '
            myIP = ngx.req.get_headers()["X-Real-IP"]
            if myIP == nil then
                myIP = ngx.req.get_headers()["x_forwarded_for"]
            end
            if myIP == nil then
                myIP = ngx.var.remote_addr
            end
            if myIP == "公司出口IP" then
                ngx.exec("@client")
            else
                ngx.exec("@client_test")
            end
        ';
} 

location @client{
    proxy_next_upstream     error timeout;
    proxy_redirect          off;
    proxy_set_header        Host $host;
    #proxy_set_header        X-Real-IP $remote_addr;
    proxy_set_header        X-Real-IP $http_x_forwarded_for;
    proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
    client_max_body_size    100m;
    client_body_buffer_size 256k;
    proxy_connect_timeout   180;
    proxy_send_timeout      180;
    proxy_read_timeout      180;
    proxy_buffer_size       8k;
    proxy_buffers           8 64k;
    proxy_busy_buffers_size 128k;
    proxy_temp_file_write_size 128k;
    proxy_pass http://client;

}
location @client_test{
    proxy_next_upstream     error timeout;
    proxy_redirect          off;
    proxy_set_header        Host $host;
    #proxy_set_header        X-Real-IP $remote_addr;
    proxy_set_header        X-Real-IP $http_x_forwarded_for;
    proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
    client_max_body_size    100m;
    client_body_buffer_size 256k;
    proxy_connect_timeout   180;
    proxy_send_timeout      180;
    proxy_read_timeout      180;
    proxy_buffer_size       8k;
    proxy_buffers           8 64k;
    proxy_busy_buffers_size 128k;
    proxy_temp_file_write_size 128k;
    proxy_pass http://client_test;
} 

由于使用了nginx+lua模块,这种方式适合很多场景,非常强大,但是问题是你可能需要学习很多lua的语法。

在Kubernetes中,我们可以通过滚动更新来实现零停机不停服发布服务。滚动更新是一种逐步替换Pod的方法,它允许我们在不停机的情况下将新版本的应用程序逐步引入生产环境。 以下是实现零停机不停服发布服务的步骤: 1. 创建Deployment资源 首先,我们需要创建一个Deployment资源,用于管理我们的应用程序。Deployment资源可以自动创建和管理Pod,确保我们的应用程序在任何时候都有指定数量的Pod在运行。 2. 更新应用程序镜像 接下来,我们需要更新应用程序的镜像,以便将新版本的应用程序引入生产环境。我们可以通过修改Deployment资源的镜像字段来更新应用程序镜像。 3. 逐步替换Pod 当我们更新Deployment资源的镜像字段时,Kubernetes会自动创建新的Pod,并逐步替换旧的Pod。默认情况下,每次更新会替换25%的Pod,直到所有Pod都被替换为止。 4. 检查更新状态 在进行滚动更新时,我们可以使用kubectl rollout status命令来检查更新状态。该命令将显示Deployment的更新进度,以及新旧Pod的状态。 5. 回滚更新 如果在滚动更新过程中发生了问题,我们可以使用kubectl rollout undo命令来回滚更新。该命令将自动将Deployment回滚到上一个版本,并重新创建旧版本的Pod。 通过上述步骤,我们可以实现零停机不停服发布服务,确保我们的应用程序在更新过程中始终可用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值