设为首页 收藏本站
查看: 883|回复: 0

[经验分享] nginx重载配置文件及平滑升级

[复制链接]

尚未签到

发表于 2018-11-10 14:03:09 | 显示全部楼层 |阅读模式
  Nginx命令行选项
  启动、停止、重启nginx命令
  如何重新加载nginx配置文件
  nginx程序不重启平滑升级可执行文件
  一、Nginx命令行选项
  不像许多其他软件系统,Nginx 仅有几个命令行参数,完全通过配置文件来配置
  -c  为 Nginx 指定一个配置文件,来代替缺省的。
  -t 不运行,而仅仅测试配置文件。nginx 将检查配置文件的语法的正确性,并尝试打开配置文件中所引用到的文件。
  -v 显示 nginx 的版本。
  -V 显示 nginx 的版本,编译器版本和配置参数。
nginx控制信号
  可以使用信号系统来控制主进程。默认,nginx 将其主进程的 pid 写入到 /usr/local/nginx/nginx.pid 文件中。通过传递参数给 ./configure 或使用 pid 指令,来改变该文件的位置。
  主进程可以处理以下的信号:
TERM, INT快速关闭QUIT从容关闭HUP重载配置  用新的配置开始新的工作进程
  从容关闭旧的工作进程
USR1重新打开日志文件USR2平滑升级可执行程序。WINCH从容关闭工作进程  尽管你不必自己操作工作进程,但是,它们也支持一些信号:
TERM, INT快速关闭QUIT从容关闭USR1重新打开日志文件二、nginx 启动、停止、重启命令
  nginx启动
  sudo /usr/local/nginx/nginx     (nginx二进制文件绝对路径,可以根据自己安装路径实际决定)
  nginx从容停止命令,等所有请求结束后关闭服务
  ps -ef |grep nginx
  kill -QUIT  nginx主进程号
  nginx 快速停止命令,立刻关闭nginx进程
  ps -ef |grep nginx
  kill -TERM nginx主进程号
  如果以上命令不管用,可以强制停止
  kill -9 nginx主进程号
  如果嫌麻烦可以不用查看进程号,直接使用命令进行操作
  其中/usr/local/nginx/nginx.pid 为nginx.conf中pid命令设置的参数,用来存放nginx主进程号的文件
  kill -信号类型(HUP|TERM|QUIT) `cat /usr/local/nginx/nginx.pid`
  例如
kill -QUIT `cat /usr/local/nginx/nginx.pid`  nginx重启命令
  nginx重启可以分成几种类型
  1.简单型,先关闭进程,修改你的配置后,重启进程。
  kill -QUIT `cat /usr/local/nginx/nginx.pid`
  sudo /usr/local/nginx/nginx
  2.重新加载配置文件,不重启进程,不会停止处理请求
  3.平滑更新nginx二进制,不会停止处理请求
三、使用信号加载新的配置
  Nginx 支持几个信号,能在它运行时控制其操作。其中最普通的是 15 ,用来中止运行的进程:
# ps aux | egrep '(PID|nginx)'  
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
  
root      2213  0.0  0.0   6784  2036 ?        Ss   03:01   0:00 nginx: master process /usr/sbin/nginx
  
-c /etc/nginx/nginx.conf
  
# kill -15 2213
  而最有趣的是能平滑改变 nginx 配置的选项(请注意,在重载前,要先测试一下配置文件):
#nginx -t -c /etc/nginx/nginx.conf  
[info] 15686#0: the configuration file /etc/nginx/nginx.conf syntax is ok
  
[info] 15686#0: the configuration file /etc/nginx/nginx.conf was tested successfully
  
#ps aux | egrep '(PID|nginx)'
  
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
  
root      2213  0.0  0.0   6784  2036 ?        Ss   03:01   0:00 nginx: master process /usr/sbin/nginx
  
-c /etc/nginx/nginx.conf# kill -HUP 2213
  当 nginx 接收到 HUP 信号,它会尝试先解析配置文件(如果指定配置文件,就使用指定的,否则使用默认的),成功的话,就应用新的配置文件(例如:重新打开日志文件或监听的套接 字)。之后,nginx 运行新的工作进程并从容关闭旧的工作进程。通知工作进程关闭监听套接字但是继续为当前连接的客户提供服务。所有客户端的服务完成后,旧的工作进程被关闭。 如果新的配置文件应用失败,nginx 将继续使用旧的配置进行工作。
四、平滑升级到新的二进制代码
  你可以在不中断服务的情况下 - 新的请求也不会丢失,使用新的 nginx 可执行程序替换旧的(当升级新版本或添加/删除服务器模块时)。
  首先,使用新的可执行程序替换旧的(最好做好备份),然后,发送 USR2 (kill -USR2 pid)信号给主进程。主进程将重命名它的 .pid 文件为 .oldbin (比如:/usr/local/nginx/logs/nginx.pid.oldbin),然后执行新的可执行程序,依次启动新的主进程和新的工作进程:
  PID  PPID USER    %CPU   VSZ WCHAN  COMMAND  
  33126    1 root     0.0  1164 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  33134 33126 nobody   0.0  1368 kqread nginx: worker process (nginx)
  
  33135 33126 nobody   0.0  1380 kqread nginx: worker process (nginx)
  
  33136 33126 nobody   0.0  1368 kqread nginx: worker process (nginx)
  
  36264 33126 root     0.0  1148 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  36265 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36266 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36267 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  在这时,两个 nginx 实例会同时运行,一起处理输入的请求。要逐步停止旧的实例,你必须发送 WINCH 信号给旧的主进程,然后,它的工作进程就将开始从容关闭:
  PID  PPID USER    %CPU   VSZ WCHAN  COMMAND  
  33126     1 root     0.0  1164 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  33135 33126 nobody   0.0  1380 kqread nginx: worker process is shutting down (nginx)
  
  36264 33126 root     0.0  1148 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  36265 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36266 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36267 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  一段时间后,旧的工作进程处理了所有已连接的请求后退出,就仅由新的工作进程来处理输入的请求了:
  PID  PPID USER    %CPU   VSZ WCHAN  COMMAND  
  33126     1 root     0.0  1164 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  36264 33126 root     0.0  1148 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
  36265 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36266 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
  36267 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  这时,因为旧的服务器还尚未关闭它监听的套接字,所以,通过下面的几步,你仍可以恢复旧的服务器:

  •   发送 HUP 信号给旧的主进程 - 它将在不重载配置文件的情况下启动它的工作进程
  •   发送 QUIT 信号给新的主进程,要求其从容关闭其工作进程
  •   发送 TERM 信号给新的主进程,迫使其退出
  •   如果因为某些原因新的工作进程不能退出,向其发送 KILL 信号
  新的主进程退出后,旧的主进程会由移除 .oldbin 前缀,恢复为它的 .pid 文件,这样,一切就都恢复到升级之前了。
  如果尝试升级成功,而你也希望保留新的服务器时,发送 QUIT 信号给旧的主进程使其退出而只留下新的服务器运行:
      PID  PPID USER    %CPU   VSZ WCHAN  COMMAND  
    36264     1 root     0.0  1148 pause  nginx: master process /usr/local/nginx/sbin/nginx
  
    36265 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
    36266 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  
    36267 36264 nobody   0.0  1364 kqread nginx: worker process (nginx)
  



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-633331-1-1.html 上篇帖子: 1.9Nginx配置(二)web部署 下篇帖子: 详解Linux下安装配置Nginx
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表