Nginx常用配置

ubuntu的目錄結(jié)構(gòu)和說明

ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡單說一下ubuntu的目錄結(jié)構(gòu)

如果是使用apt-get安裝的nginx,配置文件目錄在:

/etc/nginx/

cd到這個目錄之后,ls查看所有文件:

nginx.conf  
這個是nginx的主配置文件,里面包含了當前目錄的所有配置文件,
只不過有的是注釋狀態(tài),需要的時候自行開啟(后面幾個常用的)

conf.d
這是一個目錄,里面可以寫我們自己自定義的配置文件,文件結(jié)尾一
定是.conf才可以生效(當然也可以通過修改nginx.conf來取消這個限制)

sites-enabled
這里面的配置文件其實就是sites-available里面的配置文件的軟
連接,但是由于nginx.conf默認包含的是這個文件夾,所以我們在
sites-available里面建立了新的站點之后,還要建立個軟連接到sites-enabled里面才行

sites-available
這里是我們的虛擬主機的目錄,我們在在這里面可以創(chuàng)建多個虛擬主機

多站點配置

為什么要配置多站點:

當我們有了一個服務(wù)器之后,為了不浪費服務(wù)器的資源,我們可以在一個

服務(wù)器上放置多個網(wǎng)站項目,它們共同使用80端口,通過不同的servername

來區(qū)分不同的網(wǎng)站項目,在實際上線的項目中,這個servername就是我們的域名啦

具體配置(我們只舉例一個,多個重復(fù)操作就行):

默認已經(jīng)有一個站點了,就是defalt,在sites-available里面有
一個default文件,就是默認站點的配置,servername是localhost
不建議直接修改這個默認站點,我們可以復(fù)制一個:

cd /etc/nginx/sites-available/
cp default web1.com

別忘了建立個軟連接,不然新站點不會生效滴:
ln -s /etc/ngix/sites-available/web1.com /etc/nginx/sites-enabled/web1.com

現(xiàn)在就開始修改我們的新站點配置:
vim web1.com

找到21行的這句配置(:set nu可以顯示行號):
listen 80 default_server;

改成:
listen 80; //注意:default_server是設(shè)置默認站點的,我們新建立的站點不需要

找到24行:
root /usr/share/nginx/html

改成:
root /your server path  (寫你自己的網(wǎng)站目錄)

重啟nginx服務(wù):
/etc/init.d/nginx restart

OK,到這里一個新的站點已經(jīng)配置完成了,本機測試:

windows修改hosts文件:
文件在C:\Windows\System32\drivers\etc\hosts
會出現(xiàn)權(quán)限問題不讓修改,自行百度怎么修改這個文件的權(quán)限

mac os修改hosts文件
sudo /etc/hosts/

在文件中加入:
nginx服務(wù)器的ip 新站點的域名
192.168.1.222 web1.com

瀏覽器訪問web1.com測試結(jié)果

全部配置完成,多個站點的話,多重復(fù)操作幾次就行啦!

反向代理

正向代理:

正向代理 是一個位于客戶端和原始服務(wù)器(origin server)之間的服務(wù)器,為了從原始服務(wù)器取得內(nèi)容,客戶端向代理發(fā)送一個請求并指定目標(原始服務(wù)器),然后代理向原始服務(wù)器轉(zhuǎn)交請求并將獲得的內(nèi)容返回給客戶端。客戶端必須要進行一些特別的設(shè)置才能使用正向代理。
主要為了越過局域網(wǎng)內(nèi)的防火墻實現(xiàn)訪問網(wǎng)站

反向代理:

反向代理正好相反,對于客戶端而言它就像是原始服務(wù)器,并且客戶端不需要進行任何特別的設(shè)置??蛻舳讼蚍聪虼淼拿臻g(name-space)中的內(nèi)容發(fā)送普通請求,接著反向代理將判斷向何處(原始服務(wù)器)轉(zhuǎn)交請求,并將獲得的內(nèi)容返回給客戶端,就像這些內(nèi)容原本就是它自己的一樣。
為了將防火墻后面的服務(wù)器提供給Internet用戶訪問
也可以實現(xiàn)負載均衡,動靜分離,url策略

具體配置參考文章結(jié)尾附錄

負載均衡

前期準備:

nginx服務(wù)器 192.168.1.100
web服務(wù)器1  192.168.1.101
web服務(wù)器2  192.168.1.102

修改配置文件:

vim /etc/nginx/sites-available/default

這樣配置:

upstream a.com {
  server  192.168.1.101:80;  #有多少個服務(wù)器就添加多少個ip
  server  192.168.1.102:80;
}

server{
    listen 80;
    server_name a.com;
    location / {
        proxy_pass         http://a.com;   #這個地址一定是上面定義的負載均衡的名字
        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
    }
}

ps:nginx主服務(wù)器也可以當做一個負載均衡服務(wù)器,但是由于80端口已經(jīng)給負載均衡食用了,所有如果我們還使用80端口的話,就會造成一個死循環(huán),我們可以再給主服務(wù)器添加一個服務(wù)器,并使用不同的8080端口,這樣,主服務(wù)器也可以當做一個負載均衡的子服務(wù)器了,不會造成資源的浪費:

server{
    listen 8080;
    server_name a.com;
    index index.html;
    root /data0/htdocs/www;
}

upstream a.com {
  server  192.168.5.126:80;
  server  192.168.5.27:80;
  server  127.0.0.1:8080;
}

重啟nginx服務(wù)器就可以查看效果了:

/etc/init.d/nginx restart

擴展:

  1. 輪詢(默認方式)

    每個請求按時間順序逐一分配到后端服務(wù)器,如果后端服務(wù)器down掉,能自動剔除

  2. weight

    指定輪詢幾率,weight和訪問比率成正比,用于后端服務(wù)器性能不均的情況。

     upstream bakend {
         server 192.168.159.10 weight=10;
         server 192.168.159.11 weight=10;
     }
    
  3. ip_hash

    每個請求按訪問ip的hash結(jié)果分配,這樣每個訪客固定訪問一個后端服務(wù)器,可以解決session的問題。

     upstream resinserver{
         ip_hash;
         server 192.168.159.10:8080;
         server 192.168.159.11:8080;
     }
    
  4. fair(第三方)

    按后端服務(wù)器的響應(yīng)時間來分配請求,響應(yīng)時間短的優(yōu)先分配。

     upstream resinserver{
         server server1;
         server server2;
         fair;
     }
    
  5. url_hash(第三方

    例:在upstream中加入hash語句,server語句中不能寫入weight等其他的參數(shù),hash_method是使用的hash算法

     upstream resinserver{
         server squid1:3128;
         server squid2:3128;
         hash $request_uri;
         hash_method crc32;
     }
    

注意:

# 定義負載均衡設(shè)備的Ip及設(shè)備狀態(tài)
upstream resinserver{
    ip_hash;
    server 127.0.0.1:8000 down;
    server 127.0.0.1:8080 weight=2;
    server 127.0.0.1:6801;
    server 127.0.0.1:6802 backup;
}

在需要使用負載均衡的server中增加
proxy_pass http://resinserver/;

每個設(shè)備的狀態(tài)設(shè)置為:
1.down 表示單前的server暫時不參與負載
2.weight 默認為1.weight越大,負載的權(quán)重就越大。
3.max_fails :允許請求失敗的次數(shù)默認為1.當超過最大次數(shù)時,返回proxy_next_upstream 模塊定義的錯誤
4.fail_timeout:max_fails次失敗后,暫停的時間。
5.backup: 其它所有的非backup機器down或者忙的時候,請求backup機器。所以這臺機器壓力會最輕。

nginx支持同時設(shè)置多組的負載均衡,用來給不用的server來使用。

client_body_in_file_only 設(shè)置為On 可以講client post過來的數(shù)據(jù)記錄到文件中用來做debug
client_body_temp_path 設(shè)置記錄文件的目錄 可以設(shè)置最多3層目錄
location 對URL進行匹配.可以進行重定向或者進行新的代理 負載均衡

動靜分離

動靜分離也是利用負載均衡的原理來實現(xiàn)的,為了便于管理,我們把ip分配的配置

寫在conf.d這個文件夾里面:

cd conf.d

vim upstream.conf

里面寫上動靜分離的分配(以PHP和靜態(tài)文件為例子):

upstream php {
    server 192.168.10.10:80  #php給這個服務(wù)器處理
}

upstream static {
    server 192.168.10.11:80 #html給這個服務(wù)器處理
}

然后在server服務(wù)器里面這樣配置:

server{
    listen 80;
    server_name a.com;
    location / { #匹配所有靜態(tài)資源文件用這個代理
        proxy_pass         http://static;   #這個地址一定是上面定義的負載均衡的名字
        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
    }

    location ~ \.php$ { #匹配php文件用這個代理
        proxy_pass         http://php;   #這個地址一定是上面定義的負載均衡的名字
        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • ubuntu的目錄結(jié)構(gòu)和說明 ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡單說一下ubun...
    曹淵說創(chuàng)業(yè)閱讀 365評論 0 0
  • ubuntu的目錄結(jié)構(gòu)和說明 ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡單說一下ubun...
    曹淵說創(chuàng)業(yè)閱讀 3,191評論 0 0
  • 上一篇《WEB請求處理一:瀏覽器請求發(fā)起處理》,我們講述了瀏覽器端請求發(fā)起過程,通過DNS域名解析服務(wù)器IP,并建...
    七寸知架構(gòu)閱讀 81,757評論 21 356
  • 第一章 Nginx簡介 Nginx是什么 沒有聽過Nginx?那么一定聽過它的“同行”Apache吧!Ngi...
    JokerW閱讀 33,019評論 24 1,002
  • 我和爸爸性格當中最相似的部分大概就是太內(nèi)斂了吧。明天就是父親節(jié),所以提前送上祝福,希望他在睡前可以開心的入夢。因為...
    非寧靜無以致遠_淵寧閱讀 324評論 4 3

友情鏈接更多精彩內(nèi)容