ubuntu的目錄結(jié)構(gòu)和說明
ps:其他系統(tǒng)目錄結(jié)構(gòu)可能不一樣,但是配置文件都是一樣通用的,這里簡(jiǎn)單說一下ubuntu的目錄結(jié)構(gòu)
如果是使用apt-get安裝的nginx,配置文件目錄在:
/etc/nginx/
cd到這個(gè)目錄之后,ls
查看所有文件:
nginx.conf
這個(gè)是nginx的主配置文件,里面包含了當(dāng)前目錄的所有配置文件,
只不過有的是注釋狀態(tài),需要的時(shí)候自行開啟(后面幾個(gè)常用的)
conf.d
這是一個(gè)目錄,里面可以寫我們自己自定義的配置文件,文件結(jié)尾一
定是.conf才可以生效(當(dāng)然也可以通過修改nginx.conf來取消這個(gè)限制)
sites-enabled
這里面的配置文件其實(shí)就是sites-available里面的配置文件的軟
連接,但是由于nginx.conf默認(rèn)包含的是這個(gè)文件夾,所以我們?cè)?sites-available里面建立了新的站點(diǎn)之后,還要建立個(gè)軟連接到sites-enabled里面才行
sites-available
這里是我們的虛擬主機(jī)的目錄季春,我們?cè)谠谶@里面可以創(chuàng)建多個(gè)虛擬主機(jī)
多站點(diǎn)配置
為什么要配置多站點(diǎn):
當(dāng)我們有了一個(gè)服務(wù)器之后,為了不浪費(fèi)服務(wù)器的資源,我們可以在一個(gè)
服務(wù)器上放置多個(gè)網(wǎng)站項(xiàng)目,它們共同使用80端口,通過不同的servername
來區(qū)分不同的網(wǎng)站項(xiàng)目,在實(shí)際上線的項(xiàng)目中,這個(gè)servername就是我們的域名啦
具體配置(我們只舉例一個(gè),多個(gè)重復(fù)操作就行):
默認(rèn)已經(jīng)有一個(gè)站點(diǎn)了,就是defalt,在sites-available里面有
一個(gè)default文件,就是默認(rèn)站點(diǎn)的配置,servername是localhost
不建議直接修改這個(gè)默認(rèn)站點(diǎn),我們可以復(fù)制一個(gè):
cd /etc/nginx/sites-available/
cp default web1.com
別忘了建立個(gè)軟連接,不然新站點(diǎn)不會(huì)生效滴:
ln -s /etc/ngix/sites-available/web1.com /etc/nginx/sites-enabled/web1.com
現(xiàn)在就開始修改我們的新站點(diǎn)配置:
vim web1.com
找到21行的這句配置(:set nu可以顯示行號(hào)):
listen 80 default_server;
改成:
listen 80; //注意:default_server是設(shè)置默認(rèn)站點(diǎn)的,我們新建立的站點(diǎn)不需要
找到24行:
root /usr/share/nginx/html
改成:
root /your server path (寫你自己的網(wǎng)站目錄)
重啟nginx服務(wù):
/etc/init.d/nginx restart
OK,到這里一個(gè)新的站點(diǎn)已經(jīng)配置完成了,本機(jī)測(cè)試:
windows修改hosts文件:
文件在C:\Windows\System32\drivers\etc\hosts
會(huì)出現(xiàn)權(quán)限問題不讓修改,自行百度怎么修改這個(gè)文件的權(quán)限
mac os修改hosts文件
sudo /etc/hosts/
在文件中加入:
nginx服務(wù)器的ip 新站點(diǎn)的域名
192.168.1.222 web1.com
瀏覽器訪問web1.com測(cè)試結(jié)果
全部配置完成,多個(gè)站點(diǎn)的話,多重復(fù)操作幾次就行啦!
反向代理
正向代理:
正向代理 是一個(gè)位于客戶端和原始服務(wù)器(origin server)之間的服務(wù)器蠢护,為了從原始服務(wù)器取得內(nèi)容坟募,客戶端向代理發(fā)送一個(gè)請(qǐng)求并指定目標(biāo)(原始服務(wù)器)冶伞,然后代理向原始服務(wù)器轉(zhuǎn)交請(qǐng)求并將獲得的內(nèi)容返回給客戶端。客戶端必須要進(jìn)行一些特別的設(shè)置才能使用正向代理。
主要為了越過局域網(wǎng)內(nèi)的防火墻實(shí)現(xiàn)訪問網(wǎng)站
反向代理:
反向代理正好相反落追,對(duì)于客戶端而言它就像是原始服務(wù)器,并且客戶端不需要進(jìn)行任何特別的設(shè)置涯肩〗文疲客戶端向反向代理的命名空間(name-space)中的內(nèi)容發(fā)送普通請(qǐng)求,接著反向代理將判斷向何處(原始服務(wù)器)轉(zhuǎn)交請(qǐng)求病苗,并將獲得的內(nèi)容返回給客戶端疗垛,就像這些內(nèi)容原本就是它自己的一樣。
為了將防火墻后面的服務(wù)器提供給Internet用戶訪問
也可以實(shí)現(xiàn)負(fù)載均衡,動(dòng)靜分離,url策略
具體配置參考文章結(jié)尾附錄
負(fù)載均衡
前期準(zhǔn)備:
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; #有多少個(gè)服務(wù)器就添加多少個(gè)ip
server 192.168.1.102:80;
}
server{
listen 80;
server_name a.com;
location / {
proxy_pass http://a.com; #這個(gè)地址一定是上面定義的負(fù)載均衡的名字
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ù)器也可以當(dāng)做一個(gè)負(fù)載均衡服務(wù)器,但是由于80端口已經(jīng)給負(fù)載均衡食用了,所有如果我們還使用80端口的話,就會(huì)造成一個(gè)死循環(huán),我們可以再給主服務(wù)器添加一個(gè)服務(wù)器,并使用不同的8080端口,這樣,主服務(wù)器也可以當(dāng)做一個(gè)負(fù)載均衡的子服務(wù)器了,不會(huì)造成資源的浪費(fèi):
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
擴(kuò)展:
-
輪詢(默認(rèn)方式)
每個(gè)請(qǐng)求按時(shí)間順序逐一分配到后端服務(wù)器,如果后端服務(wù)器down掉,能自動(dòng)剔除
-
weight
指定輪詢幾率硫朦,weight和訪問比率成正比贷腕,用于后端服務(wù)器性能不均的情況。
upstream bakend { server 192.168.159.10 weight=10; server 192.168.159.11 weight=10; }
-
ip_hash
每個(gè)請(qǐng)求按訪問ip的hash結(jié)果分配,這樣每個(gè)訪客固定訪問一個(gè)后端服務(wù)器泽裳,可以解決session的問題瞒斩。
upstream resinserver{ ip_hash; server 192.168.159.10:8080; server 192.168.159.11:8080; }
-
fair(第三方)
按后端服務(wù)器的響應(yīng)時(shí)間來分配請(qǐng)求,響應(yīng)時(shí)間短的優(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; }
注意:
# 定義負(fù)載均衡設(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;
}
在需要使用負(fù)載均衡的server中增加
proxy_pass http://resinserver/;
每個(gè)設(shè)備的狀態(tài)設(shè)置為:
1.down 表示單前的server暫時(shí)不參與負(fù)載
2.weight 默認(rèn)為1.weight越大妹卿,負(fù)載的權(quán)重就越大旺矾。
3.max_fails :允許請(qǐng)求失敗的次數(shù)默認(rèn)為1.當(dāng)超過最大次數(shù)時(shí)蔑鹦,返回proxy_next_upstream 模塊定義的錯(cuò)誤
4.fail_timeout:max_fails次失敗后夺克,暫停的時(shí)間。
5.backup: 其它所有的非backup機(jī)器down或者忙的時(shí)候嚎朽,請(qǐng)求backup機(jī)器铺纽。所以這臺(tái)機(jī)器壓力會(huì)最輕。
nginx支持同時(shí)設(shè)置多組的負(fù)載均衡哟忍,用來給不用的server來使用狡门。
client_body_in_file_only 設(shè)置為On 可以講client post過來的數(shù)據(jù)記錄到文件中用來做debug
client_body_temp_path 設(shè)置記錄文件的目錄 可以設(shè)置最多3層目錄
location 對(duì)URL進(jìn)行匹配.可以進(jìn)行重定向或者進(jìn)行新的代理 負(fù)載均衡
動(dòng)靜分離
動(dòng)靜分離也是利用負(fù)載均衡的原理來實(shí)現(xiàn)的,為了便于管理,我們把ip分配的配置
寫在conf.d這個(gè)文件夾里面:
cd conf.d
vim upstream.conf
里面寫上動(dòng)靜分離的分配(以PHP和靜態(tài)文件為例子):
upstream php {
server 192.168.10.10:80 #php給這個(gè)服務(wù)器處理
}
upstream static {
server 192.168.10.11:80 #html給這個(gè)服務(wù)器處理
}
然后在server服務(wù)器里面這樣配置:
server{
listen 80;
server_name a.com;
location / { #匹配所有靜態(tài)資源文件用這個(gè)代理
proxy_pass http://static; #這個(gè)地址一定是上面定義的負(fù)載均衡的名字
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文件用這個(gè)代理
proxy_pass http://php; #這個(gè)地址一定是上面定義的負(fù)載均衡的名字
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}