linux下安裝nginx和配置
1、系統:centos7
2、安裝準備:
安裝nginx前,我們首先要確保系統安裝了g++、gcc、openssl-devel、pcre-devel和zlib-devel軟件,可通過如圖所示命令進行檢測,如果以安裝我們可以通過圖二所示卸載:
yum install gcc-c++ yum -y install zlib zlib-devel openssl openssl--devel pcre pcre-devel ## 如果已安裝,則remove掉 yum remove nginx
下載nginx:
wget https://nginx.org/download/nginx-1.11.3.tar.gz
3、我們一般安裝linux軟件都會在/usr/local目錄下,然後進行解壓編譯安裝:
tar -zxvf nginx-1.11.3.tar.gz mv nginx-1.11.3 /usr/local/nginx-1.11.3
此時開始安裝,註意,
/usr/local/nginx-1.11.3 --是nginx的解壓後的源碼包。
執行安裝:
./configure --prefix=/usr/local/nginx ## 安裝到/usr/local/nginx的nginx目錄下
make
make install
或直接 make && install 執行
此時安裝成功:
此時源碼包和安裝後的包都有了,進入到nginx目錄下,(一般要不要修改源碼包,再make make install,需要看修改什麽)
如上,進入到sbin/nginx,啟動即可。
4、配置和說明:
接下來介紹下啟動/停止/重啟的具體方法,進入目錄後我們可以用執行sbin/nginx來啟動,也可以通過conf/nginx.conf來啟動,停止我們可以查詢進程使用kill -9 進程號/pkill -9 nginx來結束nginx服務,重啟可以通過 sbin/nginx -s reload來重啟,具體命令大家請看如圖所示
nginx -h #幫助
nginx -v #顯示版本
nginx -V #顯示版本和配置信息
nginx -t #測試配置
nginx -q #測試配置時,只輸出錯誤信息
nginx -s stop #停止服務器
nginx -s reload #重新加載配置
配置nginx:
我們可以看到nginx啟動成功,現在訪問是直接進到nginx的目錄裏面了。
那麽這些實際上是在哪裏配置的。這就涉及到nginx的一個重要配置文件nginx.conf了。
2)我們可以看到nginx文件夾內有一個conf文件夾,其中有好幾個文件,其他先不管,我們打開nginx.conf,可以看到一段:
這段代碼在server裏面,相當於一個代理服務器,當然可以配置多個。
下面我們仔細來分析一下:
listen:表示當前的代理服務器監聽的端口,默認的是監聽80端口。註意,如果我們配置了多個server,這個listen要配置不一樣,不然就不能確定轉到哪裏去了。
server_name:表示監聽到之後需要轉到哪裏去,這時我們直接轉到本地,這時是直接到nginx文件夾內。
location:表示匹配的路徑,這時配置了/表示所有請求都被匹配到這裏
root:裏面配置了root這時表示當匹配這個請求的路徑時,將會在這個文件夾內尋找相應的文件,這裏對我們之後的靜態文件伺服很有用。
index:當沒有指定主頁時,默認會選擇這個指定的文件,它可以有多個,並按順序來加載,如果第一個不存在,則找第二個,依此類推。
下面的error_page是代表錯誤的頁面,這裏我們暫時不用,先不管它。
那我們知道了具體的配置了,怎麽讓它訪問localhost時轉到tomcat時。實際上就修改兩個地方:
Java代碼- server_name localhost:8080;
- location / {
- proxy_pass http://localhost:8080
- }
我們就修改了上面兩個地方,我的tomcat在8080端口,可以根據自己的需要修改。這裏有一個新元素proxy_pass,它表示代理路徑,相當於轉發,而不像之前說的root必須指定一個文件夾。
此時我們修改了文件,是不是就意思著必須先關了nginx再重新啟動了,其實不必,nginx可以重新加載文件的。
我們直接運行:
Html代碼- nginx -s reload
高興得太早了,我們發現有一個錯誤:
什麽來的,45行發現錯誤,不希望在那一行找到},於是我們仔細找,發現我們加入的proxy_pass很奇怪,沒有;號結尾,這就是問題了,直接修改,然後再運行一下,發現沒錯誤,OK了。
如果不想直接加載,而只是想看看自己的配置文件有沒有問題,可以直接輸入:
Xml代碼- nginx -t
這可以檢查配置文件中是否有錯。 下面我們所有的修改都假設我們修改完成後運行了nginx -s reload進行重新加載配置文件,請註意。
一切沒問題了,然後我們再重新打開http://localhost,我們看到下面的頁面:
這時,我們發現它並不是剛才的welcome頁面了,而是tomcat的管理頁面了,不管我們點擊什麽鏈接都是沒問題的,相當於直接訪問http://localhost:8080一樣。
3)上面我們直接試了一個小例子,讓nginx進行轉發,即所謂的反向代理。但實際上我們的需求不會是這樣的,我們需要分文件類型來進行過濾,比如jsp直接給tomcat處理,因為nginx並不是servlet容器,沒辦法處理JSP,而html,js,css這些不需要處理的,直接給nginx進行緩存。
下面我們來進行一下配置,讓JSP頁面直接給tomcat,而html,png等一些圖片和JS等直接給nginx進行緩存。
這時最主要用的還是location這個元素,並且涉及到一部分正則,但不難:
Xml代碼- location ~ \.jsp$ {
- proxy_pass http://localhost:8080;
- }
- location ~ \.(html|js|css|png|gif)$ {
- root D:/software/developerTools/server/apache-tomcat-7.0.8/webapps/ROOT;
- }
我們先要去掉之前配的location /,避免全部請求被攔截了。
然後我們再來看看http://localhost
當我們不指定jsp頁面的時候,它會出現找不到,因為,此時並沒有相應的location匹配,所以就會有404錯誤,這時就跳到了nginx自定義的error頁面去了。
而當我們用http://localhost/index.jsp去訪問時,我們看到了熟悉的頁面:
而且圖片那些都顯示正常,因為圖片是png的,所以直接在tomcat/webapps/ROOT目錄下直接查找,當然,如果我們點擊Manager Application HOW-TO這個鏈接,我們發現:
它還是找不到,為什麽呢?因為這是個html頁面,但它並不在ROOT目錄下,而是在docs目錄下,但當我們匹配html時,我們卻到ROOT目錄下去找,所以還是找不到這個頁面。
一般情況下,如果我們需要用nginx來進行靜態文件伺服,一般都會把所有靜態文件,html,htm,js,css等都放在同一個文件夾下,這樣就不會有tomcat這樣的情況了,因為tomcat下的是屬於不同的項目,這個我們就沒辦法了。
3)有些人會說,這些都只會找一臺服務器,但如果我們想在一臺服務器掛了的時候,自動去找另外一臺,這怎麽辦?這實際上nginx都考慮到了。
這時,我們之前用的proxy_pass就有大用途了。
我們把之前的第一個例子,即全部都代理的修改一下:
最後修改如下:
Xml代碼- upstream local_tomcat {
- server localhost:8080;
- }
- server{
- location / {
- proxy_pass http://local_tomcat;
- }
- #......其他省略
- }
我們在server外添加了一個upstream,而直接在proxy_pass裏面直接用http://+upstream的名稱來使用。
我們還是直接來http://localhost,還是和第一個一樣的效果,所有鏈接都沒問題,說明我們配置正確。
upstream中的server元素必須要註意,不能加http://,但proxy_pass中必須加。
我們剛才說可以在一個服務器掛了的情況下連到另外一個,那怎麽弄呢?
其實很簡單,在upstream中的local_tomcat中配置多一個server。比如我現在弄多一個jetty,端口在9999,所以我們配置如下:
Xml代碼- upstream local_tomcat {
- server localhost:8080;
- server localhost:9999;
- }
此時,我們關閉tomcat,而只開jetty。我們來運行http://localhost看看效果:
我們看到它請求到了jetty的頁面,但由於jetty的機制,這時沒有顯示jetty主頁,這個我們先不管。但我們的在一個服務器掛的情況下自動使用另外一個的功能實現了。
但有時我們就不想它掛的時候訪問另外一個,而只是希望一個服務器訪問的機會比另外一個大,這個可以在server最後加上一個weight=數字來指定,數字越大,表明請求到的機會越大。
Xml代碼- upstream local_tomcat {
- server localhost:8080 weight=1;
- server localhost:9999 weight=5;
- }
這時我們給了jetty一個更高的權值,讓它更有機會訪問到,實際上當我們刷新http://localhost訪問的時候發現jetty訪問機率大很多,tomcat幾乎沒機會訪問,一般情況下,如果我們必須這樣用,不要相關太大,以免一個服務器負載太大。
當然,server還有一些其他的元素,比如down表示暫時不用到該服務器等等。這些可以參考nginx的wiki。也許寫了一大堆,有人會有問題,那nginx怎麽關閉呢?這倒是個問題,其實直接運行nginx -s stop就可以關閉了。
基本上nginx的用法是這樣,深入的以後我們如果用到再學習。
linux下安裝nginx和配置