您好,登錄后才能下訂單哦!
Nginx 中怎么實現熱部署和日志切割,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
格式:nginx -s stop
幫助:-? -h
使用指定的配置文件:-c
指定配置指令:-g (用途是覆蓋配置文件中的指令)
指定運行目錄:-p
發送信號:-s(立刻停止服務:stop,優雅的停止服務:quit,重新配置文件:reload,重新開始記錄日志文件:reopen)
測試配置文件是否有語法錯誤:-t -T
打印 nginx 的版本信息、編譯信息等:-v -V
Nginx 命令和大部分的 Linux 的命令很相似,都是 nginx 加基本指令,再加指令相關的參數。默認情況下 nginx 會去尋找之前執行 configure 命令時指定位置的配置文件,但是可以通過 -c 來指定配置文件,并且可以通過 -g 來指定配置指令。
nginx 去操作運行中進程的方法一般是通過發送信號,可以通過 linux 通用的 kill 命令,也可以用 nginx 的 -s 命令來發送信號。
接下來,讓我們通過幾個栗子來熟悉 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 服務。
當從老版本替換為新版本的 nginx 的時候,如果不熱部署的話,會需要取消 nginx 服務并重啟服務才能替換成功,這樣的話會使正在訪問的用戶在斷開連接,所以為了在不影響用戶的體驗下進行版本升級,就需要熱部署來升級版本。
接下來,讓我們一起進行一次熱部署吧。
因為進行升級主要是更換二進制文件,所以在升級前先備份舊的二進制文件。
# 備份舊版本的 nginx 二進制文件 mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.old
然后下載最新版本的 nginx,解壓后進行編譯,再把編譯好的最新版本的 nginx 二進制文件拷貝到安裝目錄下的 sbin 目錄下。
# 到官網下載最新版本的 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 的執行程序 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 進程發送信號,告訴它我們要進行熱部署了。
# 發送 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 發送信號,告訴老的 nginx 請優雅的關閉所有的 worker 進程。
# 發送 WINCH 信號到舊的主進程,它會通知舊的 worker 進程優雅的關閉,然后退出 kill -WINCH 1752
重新在查看 nginx 狀態:
[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
也可以發現老的 nginx maser 進程還存在,它的意義是:如果存在問題,需要退回到老版本中,我們可以給它發送 reload 命令,讓他重新把 worker 進程拉起來、把新版本關掉。保留在這里方便我們做版本回退。
如果要退出保留的 master 進程,可以通過 kill -QUIT
命令來完成:
# 發送 QUIT 信號到舊的主進程,它會退出保留的 master 進程 kill -QUIT 1752
執行完后,1752 進程退出,通過 netstat lntup 可以看到 80 端口已經被 4391 進程監聽了(新版本 nginx 的進程)。
到此為止,我們就完成了 nginx 的熱部署。
為了避免日志文件過大不方便查看,因此需要對日志切割。首先將原先的日志進行備份:
# 備份原日志 mv error.log old_error.log
查看日志大小:
[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
經過上面的操作,我們就完成了日志的切割,以上操作只是為了了解日志切割的操作流程,不建議直接生產這么使用。推薦先寫成一個 shell 腳本,通過 shell 腳本去定時執行。
示例腳本:
#!/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 主進程發送 USR1 信號。USR1 信號是重新打開日志文件 kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)
這篇文章主要介紹了 Nginx 命令行相關知識,并介紹了重載配置文件、Nginx 熱部署、日志切割等操作,還是需要多實踐操作,實踐出真知。
看完上述內容,你們掌握Nginx 中怎么實現熱部署和日志切割的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。