Nginx 中怎么實現(xiàn)熱部署和日志切割,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、成都微信小程序、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了資陽免費建站歡迎大家使用!
格式:nginx -s stop
幫助:-? -h
使用指定的配置文件:-c
指定配置指令:-g (用途是覆蓋配置文件中的指令)
指定運行目錄:-p
發(fā)送信號:-s(立刻停止服務(wù):stop,優(yōu)雅的停止服務(wù):quit,重新配置文件:reload,重新開始記錄日志文件:reopen)
測試配置文件是否有語法錯誤:-t -T
打印 nginx 的版本信息、編譯信息等:-v -V
Nginx 命令和大部分的 Linux 的命令很相似,都是 nginx 加基本指令,再加指令相關(guān)的參數(shù)。默認(rèn)情況下 nginx 會去尋找之前執(zhí)行 configure 命令時指定位置的配置文件,但是可以通過 -c 來指定配置文件,并且可以通過 -g 來指定配置指令。
nginx 去操作運行中進(jìn)程的方法一般是通過發(fā)送信號,可以通過 linux 通用的 kill 命令,也可以用 nginx 的 -s 命令來發(fā)送信號。
接下來,讓我們通過幾個栗子來熟悉 Nginx 的命令行操作。
配置文件默認(rèn)是在安裝目錄的 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 壓縮,我們可以把它前面的注釋去掉,當(dāng)我們在修改完 nginx 配置文件后,我們可以通過 nginx 的命令 ./nginx -s reload
重啟 nginx 服務(wù)。
當(dāng)從老版本替換為新版本的 nginx 的時候,如果不熱部署的話,會需要取消 nginx 服務(wù)并重啟服務(wù)才能替換成功,這樣的話會使正在訪問的用戶在斷開連接,所以為了在不影響用戶的體驗下進(jìn)行版本升級,就需要熱部署來升級版本。
接下來,讓我們一起進(jìn)行一次熱部署吧。
因為進(jìn)行升級主要是更換二進(jìn)制文件,所以在升級前先備份舊的二進(jìn)制文件。
# 備份舊版本的 nginx 二進(jìn)制文件 mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.old
然后下載最新版本的 nginx,解壓后進(jìn)行編譯,再把編譯好的最新版本的 nginx 二進(jìn)制文件拷貝到安裝目錄下的 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 進(jìn)程發(fā)送信號,告訴它我們要進(jìn)行熱部署了。
# 發(fā)送 USR2 信號給舊版本主進(jìn)程號,使 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 進(jìn)程。
# 發(fā)送 WINCH 信號到舊的主進(jìn)程,它會通知舊的 worker 進(jìn)程優(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 進(jìn)程還存在,它的意義是:如果存在問題,需要退回到老版本中,我們可以給它發(fā)送 reload 命令,讓他重新把 worker 進(jìn)程拉起來、把新版本關(guān)掉。保留在這里方便我們做版本回退。
如果要退出保留的 master 進(jìn)程,可以通過 kill -QUIT
命令來完成:
# 發(fā)送 QUIT 信號到舊的主進(jìn)程,它會退出保留的 master 進(jìn)程 kill -QUIT 1752
執(zhí)行完后,1752 進(jìn)程退出,通過 netstat lntup 可以看到 80 端口已經(jīng)被 4391 進(jìn)程監(jiān)聽了(新版本 nginx 的進(jìn)程)。
到此為止,我們就完成了 nginx 的熱部署。
為了避免日志文件過大不方便查看,因此需要對日志切割。首先將原先的日志進(jìn)行備份:
# 備份原日志 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
接下來進(jìn)行日志切割:
# 日志切割 /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 主進(jìn)程發(fā)送 USR1 信號。USR1 信號是重新打開日志文件 kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)
這篇文章主要介紹了 Nginx 命令行相關(guān)知識,并介紹了重載配置文件、Nginx 熱部署、日志切割等操作,還是需要多實踐操作,實踐出真知。
看完上述內(nèi)容,你們掌握Nginx 中怎么實現(xiàn)熱部署和日志切割的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
當(dāng)前標(biāo)題:Nginx中怎么實現(xiàn)熱部署和日志切割
當(dāng)前URL:http://jinyejixie.com/article42/ipjsec.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、微信小程序、網(wǎng)站導(dǎo)航、品牌網(wǎng)站建設(shè)、移動網(wǎng)站建設(shè)、動態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)