溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Nginx 中怎么實現(xiàn)熱部署和日志切割

發(fā)布時間:2021-06-18 17:03:40 來源:億速云 閱讀:121 作者:Leah 欄目:大數(shù)據(jù)

Nginx 中怎么實現(xiàn)熱部署和日志切割,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

Nginx 命令行

  1. 格式:nginx -s stop

  2. 幫助:-? -h

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

  4. 指定配置指令:-g (用途是覆蓋配置文件中的指令)

  5. 指定運行目錄:-p

  6. 發(fā)送信號:-s(立刻停止服務(wù):stop,優(yōu)雅的停止服務(wù):quit,重新配置文件:reload,重新開始記錄日志文件:reopen)

  7. 測試配置文件是否有語法錯誤:-t -T

  8. 打印 nginx 的版本信息、編譯信息等:-v -V

Nginx 命令和大部分的 Linux 的命令很相似,都是 nginx 加基本指令,再加指令相關(guān)的參數(shù)。默認情況下 nginx 會去尋找之前執(zhí)行 configure 命令時指定位置的配置文件,但是可以通過 -c 來指定配置文件,并且可以通過 -g 來指定配置指令。

nginx 去操作運行中進程的方法一般是通過發(fā)送信號,可以通過 linux 通用的 kill 命令,也可以用 nginx 的 -s 命令來發(fā)送信號。

接下來,讓我們通過幾個栗子來熟悉 Nginx 的命令行操作。

重載配置文件

配置文件默認是在安裝目錄的 conf 文件下,文件名為 nginx.conf,我們可以打開看一下:

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    #tcp_nopush     on;
    keepalive_timeout  65;
    #gzip  on;

    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

假如我們需要開啟 gzip 壓縮,我們可以把它前面的注釋去掉,當我們在修改完 nginx 配置文件后,我們可以通過 nginx 的命令 ./nginx -s reload 重啟 nginx 服務(wù)。

Nginx 熱部署

當從老版本替換為新版本的 nginx 的時候,如果不熱部署的話,會需要取消 nginx 服務(wù)并重啟服務(wù)才能替換成功,這樣的話會使正在訪問的用戶在斷開連接,所以為了在不影響用戶的體驗下進行版本升級,就需要熱部署來升級版本。

接下來,讓我們一起進行一次熱部署吧。

因為進行升級主要是更換二進制文件,所以在升級前先備份舊的二進制文件。

# 備份舊版本的 nginx 二進制文件
mv /usr/local/nginx/sbin/nginx  /usr/local/nginx/sbin/nginx.old

然后下載最新版本的 nginx,解壓后進行編譯,再把編譯好的最新版本的 nginx 二進制文件拷貝到安裝目錄下的 sbin 目錄下。

# 到官網(wǎng)下載最新版本的 nginx
wget http://nginx.org/download/nginx-1.17.2.tar.gz
# 解壓
tar -xzvf nginx-1.17.2.tar.gz
cd nginx-1.17.2
./configure --prefix=/usr/local/nginx
# 編譯
make
# 替換舊的 nginx 的執(zhí)行程序
cp -r /usr/local/nginx-1.16.1/objs/nginx /usr/local/nginx/sbin/ -f

通過 ps -ef | grep nginx 來查看 nginx 運行狀況:

[root@wupx sbin]# ps -ef | grep nginx 
root      1752     1  0 20:39 ?        00:00:00 nginx: master process ./sbin/nginx
nobody    1783  1752  0 20:41 ?        00:00:00 nginx: worker process
root      1787     1  0 20:41 ?        00:00:00 wget http://nginx.org/download/nginx-1.17.2.tar.gz
root      4357  1708  0 21:00 pts/2    00:00:00 grep --color=auto nginx

可以看到目前啟動的 nginx 的 PID 為 1752,下面需要給正在運行的 nginx 的 master 進程發(fā)送信號,告訴它我們要進行熱部署了。

# 發(fā)送 USR2 信號給舊版本主進程號,使 nginx 的舊版本停止接收請求,用 nginx 新版本接替
kill -USR2 1752

再通過 ps -ef | grep nginx 來查看 nginx 運行狀況:

[root@wupx sbin]# ps -ef | grep nginx 
root      1752     1  0 20:39 ?        00:00:00 nginx: master process ./sbin/nginx
nobody    1783  1752  0 20:41 ?        00:00:00 nginx: worker process
root      1787     1  0 20:41 ?        00:00:00 wget http://nginx.org/download/nginx-1.17.2.tar.gz
root      4391  1752  0 21:02 ?        00:00:00 nginx: master process ./sbin/nginx
nobody    4392  4391  0 21:02 ?        00:00:00 nginx: worker process
root      4394  1708  0 21:07 pts/2    00:00:00 grep --color=auto nginx

這個時候我們需要給老的 nginx 發(fā)送信號,告訴老的 nginx 請優(yōu)雅的關(guān)閉所有的 worker 進程。

# 發(fā)送 WINCH 信號到舊的主進程,它會通知舊的 worker 進程優(yōu)雅的關(guān)閉,然后退出
kill -WINCH 1752

重新在查看 nginx 狀態(tài):

[root@wupx sbin]# ps -ef | grep nginx 
root      1752     1  0 20:39 ?        00:00:00 nginx: master process ./sbin/nginx
root      1787     1  0 20:41 ?        00:00:00 wget http://nginx.org/download/nginx-1.17.2.tar.gz
root      4391  1752  0 21:02 ?        00:00:00 nginx: master process ./sbin/nginx
nobody    4392  4391  0 21:02 ?        00:00:00 nginx: worker process
root      4402  1708  0 21:08 pts/2    00:00:00 grep --color=auto nginx

也可以發(fā)現(xiàn)老的 nginx maser 進程還存在,它的意義是:如果存在問題,需要退回到老版本中,我們可以給它發(fā)送 reload 命令,讓他重新把 worker 進程拉起來、把新版本關(guān)掉。保留在這里方便我們做版本回退。

如果要退出保留的 master 進程,可以通過 kill -QUIT 命令來完成:

# 發(fā)送 QUIT 信號到舊的主進程,它會退出保留的 master 進程
kill -QUIT 1752

執(zhí)行完后,1752 進程退出,通過 netstat lntup 可以看到 80 端口已經(jīng)被 4391 進程監(jiān)聽了(新版本 nginx 的進程)。

到此為止,我們就完成了 nginx 的熱部署。

日志切割

為了避免日志文件過大不方便查看,因此需要對日志切割。首先將原先的日志進行備份:

# 備份原日志
mv error.log old_error.log

查看日志大?。?/p>

[root@wupx logs]# ll
total 20
-rw-r--r-- 1 root root 6789 Nov  6 22:28 access.log
-rw-r--r-- 1 root root    5 Nov  6 22:16 nginx.pid
-rw-r--r-- 1 root root 7831 Nov  6 22:28 old_error.log

接下來進行日志切割:

# 日志切割
/usr/local/nginx/sbin/nginx -s reopen

再次查看:

[root@wupx logs]# ll
total 24
-rw-r--r-- 1 nobody root 6789 Nov  6 22:28 access.log
-rw-r--r-- 1 nobody root   60 Nov  6 22:30 error.log
-rw-r--r-- 1 root   root    5 Nov  6 22:16 nginx.pid
-rw-r--r-- 1 root   root 7831 Nov  6 22:28 old_error.log

經(jīng)過上面的操作,我們就完成了日志的切割,以上操作只是為了了解日志切割的操作流程,不建議直接生產(chǎn)這么使用。推薦先寫成一個 shell 腳本,通過 shell 腳本去定時執(zhí)行。

示例腳本:

#!/bin/bash
LOGS_PATH=/usr/local/nginx/logs/history
CUR_LOGS_PATH=/usr/local/nginx/logs
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
mv ${CUR_LOGS_PATH}/access.log ${LOGS_PATH}/old_access_${YESTERDAY}.log
mv ${CUR_LOGS_PATH}/error.log ${LOGS_PATH}/old_error_${YESTERDAY}.log
## 向 NGINX 主進程發(fā)送 USR1 信號。USR1 信號是重新打開日志文件
kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)

總結(jié)

這篇文章主要介紹了 Nginx 命令行相關(guān)知識,并介紹了重載配置文件、Nginx 熱部署、日志切割等操作,還是需要多實踐操作,實踐出真知。

Nginx 中怎么實現(xiàn)熱部署和日志切割

看完上述內(nèi)容,你們掌握Nginx 中怎么實現(xiàn)熱部署和日志切割的方法了嗎?如果還想學到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI