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ǎng)站項目,它們共同使用80端口,通過不同的servername

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

名啦

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

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

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服務:

/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服務器的ip 新站點的域名192.168.1.222 web1.com

瀏覽器訪問web1.com測試結(jié)果
全部配置完成,多個站點的話,多重復操作幾次就行啦!
反向代理
正向代理:
正向代理 是一個位于客戶端和原始服務器(origin server)之間的服務器卫旱,為了從原始服務器取得內(nèi)容,客戶端向代理發(fā)送一個請求并指定目標(原始服務器)围段,然后代理向原始服務器轉(zhuǎn)交請求并將獲得的內(nèi)容返回給客戶端顾翼。客戶端必須要進行一些特別的設(shè)置才能使用正向代理蒜撮。主要為了越過局域網(wǎng)內(nèi)的防火墻實現(xiàn)訪問網(wǎng)站

反向代理:
反向代理正好相反暴构,對于客戶端而言它就像是原始服務器跪呈,并且客戶端不需要進行任何特別的設(shè)置段磨。客戶端向反向代理的命名空間(name-space)中的內(nèi)容發(fā)送普通請求耗绿,接著反向代理將判斷向何處(原始服務器)轉(zhuǎn)交請求苹支,并將獲得的內(nèi)容返回給客戶端,就像這些內(nèi)容原本就是它自己的一樣误阻。為了將防火墻后面的服務器提供給Internet用戶訪問也可以實現(xiàn)負載均衡,動靜分離,url策略

具體配置參考文章結(jié)尾附錄
負載均衡
前期準備:
nginx服務器 192.168.1.100web服務器1 192.168.1.101web服務器2 192.168.1.102

修改配置文件:
vim /etc/nginx/sites-available/default

這樣配置:

upstream a.com { server 192.168.1.101:80; #

有多少個服務器就添加多少個

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

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服務器就可以查看效果了:

/etc/init.d/nginx restart

擴展:
輪詢(默認方式)
每個請求按時間順序逐一分配到后端服務器,如果后端服務器down掉,能自動剔除

weight
指定輪詢幾率债蜜,weight和訪問比率成正比,用于后端服務器性能不均的情況究反。

upstream bakend { server 192.168.159.10 weight=10; server 192.168.159.11 weight=10; }

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

upstream resinserver{ ip_hash; server 192.168.159.10:8080; server 192.168.159.11:8080; }

fair(第三方)
按后端服務器的響應時間來分配請求狼速,響應時間短的優(yōu)先分配。

upstream resinserver{ server server1; server server2; fair; }

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ù)記錄到文件中用來做debugclient_body_temp_path 設(shè)置記錄文件的目錄 可以設(shè)置最多3層目錄location 對URL進行匹配.可以進行重定向或者進行新的代理 負載均衡

動靜分離

動靜分離也是利用負載均衡的原理來實現(xiàn)的,為了便于管理,我們把ip分配的配置
寫在conf.d這個文件夾里面

cd conf.dvim upstream.conf

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

upstream php { server 192.168.10.10:80 #php給這個服務器處理}upstream static { server 192.168.10.11:80 #html給這個服務器處理}

然后在server服務器里面這樣配置:

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)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市苟径,隨后出現(xiàn)的幾起案子案站,更是在濱河造成了極大的恐慌,老刑警劉巖棘街,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蟆盐,死亡現(xiàn)場離奇詭異,居然都是意外死亡遭殉,警方通過查閱死者的電腦和手機石挂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來险污,“玉大人奢赂,你說我怎么就攤上這事〗骼” “怎么了幌甘?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蚁飒。 經(jīng)常有香客問我动壤,道長,這世上最難降的妖魔是什么淮逻? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任琼懊,我火速辦了婚禮,結(jié)果婚禮上爬早,老公的妹妹穿的比我還像新娘哼丈。我一直安慰自己,他們只是感情好筛严,可當我...
    茶點故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布醉旦。 她就那樣靜靜地躺著,像睡著了一般脑漫。 火紅的嫁衣襯著肌膚如雪髓抑。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天优幸,我揣著相機與錄音吨拍,去河邊找鬼。 笑死网杆,一個胖子當著我的面吹牛羹饰,可吹牛的內(nèi)容都是我干的伊滋。 我是一名探鬼主播,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼队秩,長吁一口氣:“原來是場噩夢啊……” “哼笑旺!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起馍资,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤筒主,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鸟蟹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乌妙,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年建钥,在試婚紗的時候發(fā)現(xiàn)自己被綠了藤韵。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,688評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡熊经,死狀恐怖泽艘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情镐依,我是刑警寧澤匹涮,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站馋吗,受9級特大地震影響焕盟,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宏粤,卻給世界環(huán)境...
    茶點故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望灼卢。 院中可真熱鬧绍哎,春花似錦、人聲如沸鞋真。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涩咖。三九已至海诲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間檩互,已是汗流浹背特幔。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留闸昨,地道東北人蚯斯。 一個月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓薄风,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拍嵌。 傳聞我的和親對象是個殘疾皇子遭赂,可洞房花燭夜當晚...
    茶點故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容

  • ubuntu的目錄結(jié)構(gòu)和說明 ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡單說一下ubun...
    曹淵說創(chuàng)業(yè)閱讀 3,119評論 0 0
  • 第一章 Nginx簡介 Nginx是什么 沒有聽過Nginx?那么一定聽過它的“同行”Apache吧横辆!Ngi...
    JokerW閱讀 32,669評論 24 1,002
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理撇他,服務發(fā)現(xiàn),斷路器狈蚤,智...
    卡卡羅2017閱讀 134,651評論 18 139
  • ubuntu的目錄結(jié)構(gòu)和說明 ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡單說一下ubun...
    Luwnto閱讀 14,722評論 0 16
  • 上一篇《WEB請求處理一:瀏覽器請求發(fā)起處理》逆粹,我們講述了瀏覽器端請求發(fā)起過程,通過DNS域名解析服務器IP炫惩,并建...
    七寸知架構(gòu)閱讀 80,990評論 21 356