nginx是怎么處理http請求的
參考:How nginx processes a request
nginx first decides which server should process the request. Let’s start with a simple configuration where all three virtual servers listen on port *:80:
nginx首先決定要用配置文件里的哪個server{}塊來處理,假設有下面的server{}配置
server {
listen 80;
server_name aaa;
...
}
server {
listen 80;
server_name bbb;
...
}
nginx會根據過來的http請求頭里的Host字段里的值,來判斷使用哪個server{}。
- 如果請求頭里沒有Host字段,或者Host字段里的值,和Nginx配置文件里的server{}里的{server_name}都不匹配,則使用第一個server{},來處理這個請求。
- 如果請求頭里的Host字段里的值和Nginx配置文件里的某個server{}里的{server_name},匹配上了,則使用這個server{},來處理這個請求。
可以使用curl工具來方便的做實驗,curl可以設置http請求的請求頭,所以可以任意設置Host字段,用【-H】來設置。下面的10.210.65.73是安裝了nginx的機器的IP地址。
所以用下面的命令,發送了http請求后,nginx就會使用server{server_name aaa}來處理這個請求。
curl.exe -H "Host: aaa" 10.210.65.73
非常重要的結論:server_name對應的是http請求頭里的Host字段的值
有了上面的理論支撐,就可以很容易的設置反向代理和負載均衡
- 當過來的http請求頭里的Host字段為aaa時,storage.test來處理。
- 當過來的http請求頭里的Host字段為bbb時,tracker.test來處理。
#負載均衡配置,IP為129的機器配置高,所以給他的數字的27,就是讓它多處理
upstream storage.test {
server 10.210.65.129:80 weight=27;
server 10.210.65.130:80 weight=1;
}
#負載均衡配置
upstream tracker.test {
server 10.210.65.52:80 weight=7;
server 10.210.65.53:80 weight=2;
}
#文件的存儲
server {
listen 80;
server_name aaa;
location / {
#http:://后面的內容是自己定義,對應上面upstream的名字
proxy_pass http://storage.test;
}
}
#文件服務器tracker
server {
listen 80;
server_name bbb;
location / {
#http:://后面的內容是自己定義的,對應上面upstream的名字
proxy_pass http://tracker.test;
}
}
server{}里的listen監聽的是誰的端口?
監聽的是:發送過來http請求的進程(大部分是瀏覽器)的端口(如果是http請求,則為端口為80),不是nginx服務器自己進程的端口。
nginx根據http請求頭的Host字段里的值,和發送過來http請求的進程(大部分是瀏覽器)的端口,來決定使用哪個server{}來處理http請求。