Nginx命令行

  01 格式:nginx 参数 信号

  02 帮助: -?  -h

  03 使用指定的配置文件:-c

  04 指定配置指令: -g

  05 指定运行目录: -p

  06 发送信号: -s

    立刻停止服务: stop

    优雅地停止服务: quit

    重载配置文件: reload

    重新开始记录日志文件: reopen

  07 测试配置文件是否语法错误: -t  -T

  08 打印nginx的版本信息、编译信息等: -v  -V

重载配置文件

/usr/local/nginx/sbin/nginx -s reload

若执行重启时报:nginx: [error] invalid PID number "" in "/usr/local/nginx/logs/nginx.pid"
解决:
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

热部署

  • 即在不打断用户请求的情况下更新版本
  • Nginx 采用了高度模块化的设计思路,并且内部的进程主要有两类,master 进程 和 worker 进程。其中 master 进程只有一个,worker 进程可以有多个。
  • worker 进程才是真正 working 的进程,才是真正处理请求的进程。worker 进程全部都是 master 进程的子进程。worker 进程是以普通用户的身份进行运行的,这样就可以极大增加程序的安全性。就算是万一有一个进程被劫持,那也不会有管理员权限。
  • nginx 的热部署和其并发模型有着密不可分的关系。说白了,就是因为 master 进程的关系。当通知 ngnix 重读配置文件的时候,master 进程会进行语法错误的判断。如果存在语法错误的话,返回错误,不进行装载;如果配置文件没有语法错误,那么 ngnix 也不会将新的配置调整到所有 worker 中。而是,先不改变已经建立连接的 worker,等待 worker 将所有请求结束之后,将原先在旧的配置下启动的 worker 杀死,然后使用新的配置创建新的 worker。

操作:源码安装nginx新版本,执行至make

ps -ef | grep nginx 查看当前nginx master进程

重载nginx配置文件 nginx 重载_二进制文件

备份现有Ngxix的二进制文件,更新时只会更新二进制文件不会更新其他文件

cp nginx nginx.old

将编译好的最新版本的nginx二进制文件 拷贝到/usr/local/nginx/sbin/ 目录中 替换到正在运行的nginx二进制文件

给正在运行的nginx master进程发送一个信号,提示要开始热部署了

kill -USR2 master进程ID

重载nginx配置文件 nginx 重载_nginx_02

现在nginx master进程回新启一个nginx master进程,新的master进程使用的是刚刚复制过来的新的nginx二进制文件,老的work也在运行,新的master 会生成新的work,他们会平滑的将所有的请求过度到新的二进制文件启的nginx进程中,这样就实现了平滑过度,查看新的nginx 进程状况

重载nginx配置文件 nginx 重载_nginx_03

会看到新老master进程都在运行,老的master 不再监听80 443 端口,所以新的请求会进入新的二进制文件的master中,向老的nginx 发送WINCH信号,告诉他请优雅的关闭老的work进程

kill -WINCH 老master进程ID

重载nginx配置文件 nginx 重载_二进制文件_04

会看到老的master进程还在 但是没有老的work进程了,说明所有的请求已经切换到新的nginx中,但是有可能会出现一些问题需要将新版本退回到老版本,所以这时候还可以给老的master(13195)进程发送reload命令,让他重新把work进程拉起,在把新版本关掉,所以老的master不会自动退出,留在这里利于版本回退。

日志切割

1)将原日志备份之后执行命令:

/usr/local/nginx/sbin/nginx -s reopen

2)计划任务将日志分隔
思路:将日志mv为其他文件名,已年月日方式存储
向Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件

kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)

3)在单个站点配置文件中编辑access_log文件的命名方式,例如

server{
    if ($time_iso8601 ~ "^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})")
    {
        set $curyear $1;
        set $curmonth $2;
        set $curday $3;
        set $curhour $4;
        set $curminutes $5;
        set $curseconds $6;
    }
     access_log /data/logs/api_dev_xintong$curyear$curmonth$curday.log main;
}

计划任务执行,只保存近7天的日志内容
每天3点执行清理日志文件

0 3 * * * find /data/logs -iname "*.log" -mtime +7|xargs rm -f > /dev/null 2>&1