• Nginx--平滑升级


    在不中断服务的情况下,新的请求也不会丢失,使用新的 nginx 可执行程序替换旧的

    1 查看老版本的编译选项

    [root@localhost ~]# nginx -V
    nginx version: nginx/1.16.0
    built by gcc 4.8.5 20150623 (Red Hat 4.8.5-44) (GCC) 
    built with OpenSSL 1.0.2k-fips  26 Jan 2017
    TLS SNI support enabled
    configure arguments: --with-http_realip_module --user=nginx --group=nginx --with-http_stub_status_module --with-http_ssl_module

    2 编译新版

    [root@localhost ~]# cd nginx-1.18.0/
    [root@localhost nginx-1.18.0]# ./ configure --with-http_realip_module --user=nginx --group=nginx --with-http_stub_status_module --with-http_ssl_module
    [root@localhost nginx-1.18.0]# make && make install

    3 用新编译的命令替换原来的命令

    [root@localhost nginx-1.18.0]# mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak
    [root@localhost nginx-1.18.0]# cp objs/nginx /usr/local/nginx/sbin/

    4 启用新的 关闭旧的

    [root@localhost nginx-1.18.0]# kill -USR2 \`cat /usr/local/nginx/logs/nginx.pid`
    #主进程将重命名它的.pid文件为.oldbin 然后执行新的可执行程序,依次启动新的主进程和新的工作进程
    
    [root@localhost nginx-1.18.0]# kill -WINCH \`cat /usr/local/nginx/logs/nginx.pid.oldbin`
    #给旧的主进发WINCH信号,把旧的主进程关闭,把所有请求转到新的主进程,但是原有的请求不会中断,有新请求的时候发到新进程
    
    #这时,因为旧的服务器还尚未关闭它监听的套接字,所以,通过下面的几步,仍可以恢复旧的服务器: 
        1.发送 HUP 信号给旧的主进程 - 它将在不重载配置文件的情况下启动它的工作进程 
        2.发送 QUIT 信号给新的主进程,要求其从容关闭其工作进程 
        3.发送 TERM 信号给新的主进程,迫使其退出 
        4.如果因为某些原因新的工作进程不能退出,向其发送 KILL 信号 
    #新的主进程退出后,旧的主进程会由移除 .oldbin 前缀,恢复为它的 .pid 文件,这样,一切就都恢复到升级之前了
    
    #如果尝试升级成功,但也希望保留新的服务器时,发送 QUIT 信号给旧的主进程使其退出而只留下新的服务器运行
    [root@localhost nginx-1.18.0]# kill -QUIT \`cat /usr/local/nginx/logs/nginx.pid.oldbin`

     kill 信号

    TERM, INT 快速关闭 
    QUIT 从容关闭,关闭主进程顺便关闭工作子进程
    HUP 重载配置用新的配置开始新的工作进程从容关闭旧的工作进程 
    USR1 重新打开日志文件 
    USR2 平滑升级可执行程序
    WINCH 从容关闭工作进程,不会立即关闭子进程
  • 相关阅读:
    background-position 使用方法具体介绍
    Android平台上直接物理内存读写漏洞的那些事
    自己编写高负荷測试的工具
    String,StringBuffer与StringBuilder的差别??
    shell之here文档
    心跳检测的思路及代码
    高可用架构篇--MyCat在MySQL主从复制基础上实现读写分离
    MySQL主从复制之Mycat简单配置和高可用
    Mycat 读写分离+分库分表
    MyCat:对MySQL数据库进行分库分表
  • 原文地址:https://www.cnblogs.com/Xinenhui/p/14130583.html
Copyright © 2020-2023  润新知