Linux中安裝Nginx的正確步驟
前言
如果你和我一樣,作為一個苦逼的Java后臺除了實現(xiàn)實現(xiàn)一大堆項目功能,還要兼顧項目的部署,運維工作。在新的服務(wù)器上安裝新Nginx,在安裝之前看下網(wǎng)上的教程,面對五花八門的教程,各式各樣的安裝方法,心里總會嘀咕什么方式才是最好的,或者說什么方法才是最適合自己的?下面我們一起來分析Nginx各種安裝方式,分別適合于那種情況。
使用系統(tǒng)二進(jìn)制源方式安裝
在Ubuntu/Debian系
sudo apt-get install nginx
或者RedHat/CentOS系
sudo yum install nginx
這種方式最簡單的,最快捷的方式,但是不是最好的方式,下面我們來說這種主要問題。
優(yōu)點
- 所有安裝二進(jìn)制依賴已經(jīng)處理好了,不用擔(dān)心兼容性問題,開箱即用
- Nginx的連接配置,用戶權(quán)限這個都不用處理,已經(jīng)幫你寫好這塊了
- 不用擔(dān)心Nginx Bug維護(hù)升級問題,直接獲取最新系統(tǒng)就可以了
- 卸載簡單,直接一個命令即可
- 日志維護(hù)簡單,自動截斷當(dāng)天日志,壓縮保存
缺點
- 不能自主選擇安裝版本
- 不能自主選擇編譯的模塊
- 擴(kuò)展功能變得很麻煩,需要重新編譯
- 目類結(jié)構(gòu)復(fù)雜,配置文件在/etc/下,部署文件在/var/www
- 重啟服務(wù),修改配置都需要root權(quán)限
- 性能差一點編譯安裝
如果你是一個Linux新手,絕對推薦使用這中方式安裝,不用考慮編譯依賴問題,直接安裝完就可以使用。但是如果你這個服務(wù)器是用于生產(chǎn)環(huán)境正在開發(fā)逐步完善的過程,不推薦使用這種方式。將來可能會添加第三方模塊,到時肯定要編譯安裝(下面會說到)。在重啟服務(wù)器的時候,不要使用root用戶,而是使用sudo短暫獲取root。如果你這條服務(wù)器都是用來部署一些靜態(tài)文件,主要做一些web空間,平常主要用ftp工具部署文件,用這種方式肯定沒什么問題的。
編譯安裝
優(yōu)缺點,我就不寫了,基本就是上面的顛倒過來就可以了。使用這種方法安裝,都必須懂一點Linux編譯知識,Linux中度用戶才可以駕馭。我看見網(wǎng)上大多數(shù)教程,都是將編譯依賴直接裝在/usr/local/這種方式并不好。如果將來我們要卸載這些依賴,發(fā)現(xiàn)非常麻煩。并不是直接在目類下直接刪除就可以完事的,有些Linux發(fā)行版本,會將安裝文件,寫入配置文件中,這些配置文件有不知道哪里找。如果依賴版本影響到其他軟件,怎么處理版本問題。我們只想安裝Nginx,結(jié)果延申出一大堆問題。
編譯環(huán)境準(zhǔn)備
在開始之前,保證你的Linux準(zhǔn)備了gcc、make、wget,g++ 這些軟件。
創(chuàng)建一個目類用來存放下載文件,進(jìn)入目錄中下載依賴庫源文件
下載openssl主要用于ssl模塊加密,支持htps
wget https://www.openssl.org/source/openssl-1.0.2s.tar.gz
下載pcre來實現(xiàn)對地址重定向,地址重寫功能和localtion指令以及正則表達(dá)式的支持
wget https://ftp.pcre.org/pub/pcre/pcre-8.43.tar.gz
下載zlib gzip壓縮模塊
wget https://zlib.net/zlib-1.2.11.tar.gz
下載Nginx
wget http://nginx.org/download/nginx-1.17.1.tar.gz
使用tar 解壓所有的文件
ls *.tar.gz | xargs -n1 tar xzvf
編譯選項
使用./configure設(shè)置各種Nginx參數(shù)的腳本,包括源和配置文件的路徑,編譯器選項,連接處理方法和模塊列表。該腳本通過創(chuàng)建編譯代碼和安裝Nginx開源所需的Makefile來完成。
參數(shù) | 描述 |
---|---|
–prefix=<PATH> | Nginx安裝目錄,以及有其他配置腳本選項的路徑設(shè)置的所有相對路徑的基本位置。默認(rèn)值/usr/local/nginx |
–sbin-path=<PATH | Nginx二進(jìn)制執(zhí)行文件的名稱,默認(rèn)值:<prefix>/sbin/nginx |
–conf-path=<PATH> | Nginx配置文件的名稱。但是,您可以通過在nginx命令行上使用選項指定其他文件來始終在啟動時覆蓋此值。默認(rèn)值:<prefix> conf / nginx.conf-c <FILENAME> |
–pid-path=<PATH> | nginx.pid文件的名稱,用于存儲nginx主進(jìn)程的進(jìn)程ID 。安裝后,可以使用Nginx配置文件中的pid指令更改文件名的路徑。默認(rèn)值:<prefix> /logs/nginx.pid |
–error-log-path=<PATH> | error,warn和診斷數(shù)據(jù)的日志文件的名稱。安裝后,可以使用Nginx配置文件中的error_log指令更改文件名。默認(rèn)值:<prefix> /logs/error.log |
–http-log-path=<PATH> | HTTP服務(wù)器請求的主日志文件的名稱。安裝后,始終可以使用Nginx配置文件中的access_log指令更改文件名。默認(rèn)值:<prefix> /logs/access.log |
–user=<NAME> | Nginx運行進(jìn)程的擁有者。安裝后,可以使用Nginx配置文件中的user指令更改名稱。默認(rèn):nobody |
–group=name | nginx運行進(jìn)程的擁有者用戶組。安裝后,可以使用NGINX配置文件中的user指令更改名稱。默認(rèn)值:–user選項設(shè)置的值 |
–with-pcre=<PATH> | PCRE庫源代碼的路徑,這是位置指令和Rewrite模塊中正則表達(dá)式支持所必需的 |
–with-pcre-jit | 使用“即時編譯”支持(pcre_jit指令)構(gòu)建PCRE庫 |
–with-zlib=<PATH> | zlib庫的源代碼路徑,Gzip模塊需要該路徑 |
–with-http_ssl_modul | 啟用HTTPS支持 |
–with-http_v2_module | 開啟 HTTP/2請求支持 |
還要太多編譯參數(shù)我就不一一列舉,有興趣的同學(xué)可以自己去
編譯安裝
./configure \ --with-openssl=../openssl-1.0.2s \ --with-pcre=../pcre-8.43 \ --with-zlib=../zlib-1.2.11 \ --with-pcre-jit --user=admin \ --prefix=/home/admin/nginx \ --with-http_ssl_module \ --with-http_v2_module
輸出以下信息,說明依賴沒問題
Configuration summary + using PCRE library: ../pcre-8.43 + using OpenSSL library: ../openssl-1.0.2s + using zlib library: ../zlib-1.2.11 nginx path prefix: "/home/admin/nginx" nginx binary file: "/home/admin/nginx/sbin/nginx" nginx modules path: "/home/admin/nginx/modules" nginx configuration prefix: "/home/admin/nginx/conf" nginx configuration file: "/home/admin/nginx/conf/nginx.conf" nginx pid file: "/home/admin/nginx/logs/nginx.pid" nginx error log file: "/home/admin/nginx/logs/error.log" nginx http access log file: "/home/admin/nginx/logs/access.log" nginx http client request body temporary files: "client_body_temp" nginx http proxy temporary files: "proxy_temp" nginx http fastcgi temporary files: "fastcgi_temp" nginx http uwsgi temporary files: "uwsgi_temp" nginx http scgi temporary files: "scgi_temp"
編譯
make
安裝
make install
設(shè)置權(quán)限
因為Linux設(shè)置普通用戶,不能占用1024一下的端口,直接啟動nginx會出現(xiàn)權(quán)限不足的錯誤。將nginx分配給root用戶,在分配特殊權(quán)限。
sudo chown root nginx sudo chmod u+s nginx
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
Windows設(shè)置nginx開機(jī)自啟動的方法
這篇文章主要介紹了Windows設(shè)置nginx開機(jī)自啟動的方法,通過兩種方式實現(xiàn)nginx的開機(jī)自啟動:winws和window計劃程序,每種方式給大家介紹的非常詳細(xì)需要的朋友可以參考下2022-11-11NGINX報錯413 Request Entity Too Large的問題解決
Nginx 413錯誤表示請求實體太大,本文主要介紹了NGINX報錯413 Request Entity Too Large的問題解決,具有一定的參考價值,感興趣的可以了解一下2024-08-08關(guān)于Nginx配置ssl證書實現(xiàn)https安全訪問
這篇文章主要介紹了關(guān)于Nginx配置ssl證書實現(xiàn)https安全訪問,前題條件是擁有服務(wù)器與可以解析到該服務(wù)器的自己的域名,需要的朋友可以參考下2023-04-04nginx經(jīng)過多層代理后獲取真實來源ip過程詳解
這篇文章主要介紹了nginx經(jīng)過多層代理后獲取真實來源ip過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09docker nginx實現(xiàn)一個主機(jī)部署多個站點操作
這篇文章主要介紹了docker nginx實現(xiàn)一個主機(jī)部署多個站點操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11