原文出處:http://blog.csdn.net/hellochenlian/article/details/44655547
背景需求:開發Java Web程式,希望将靜态資源(如圖檔)交由Nginx處理,Tomcat隻處理一些動态接口請求,減輕Tomcat負擔。
解決方案:在Nginx的配置檔案nginx.conf中修改location配置項,将指定工程目錄和檔案格式的請求交給Nginx處理,其它請求交給Tomcat。
文法規則: location [=|~|~*|^~] /uri/ { … } = 開頭表示精确比對 ^~ 開頭表示uri以某個正常字元串開頭,了解為比對 url路徑即可。nginx不對url做編碼,是以請求為/static/20%/aa,可以被規則^~ /static/ /aa比對到(注意是空格)。 ~ 開頭表示區分大小寫的正則比對 ~* 開頭表示不區分大小寫的正則比對 !~ 和!~*分别為區分大小寫 不比對 及不區分大小寫 不比對 的正則 / 通用比對,任何請求都會比對到。 多個location配置的情況下比對順序為(參考資料而來,還未實際驗證,試試就知道了,不必拘泥,僅供參考): 首先比對 =,其次比對^~, 其次是按檔案中順序的正則比對,最後是交給 / 通用比對。當有比對成功時候,停止比對,按目前比對規則處理請求。
例子,有如下比對規則:
[plain] view plain copy
- location = / {
- #規則A
- }
- location = /login {
- #規則B
- }
- location ^~ /static/ {
- #規則C
- }
- location ~ \.(gif|jpg|png|js|css)$ {
- #規則D
- }
- location ~* \.png$ {
- #規則E
- }
- location !~ \.xhtml$ {
- #規則F
- }
- location !~* \.xhtml$ {
- #規則G
- }
- location / {
- #規則H
- }
那麼産生的效果如下: 通路根目錄/, 比如http://localhost/ 将比對規則A 通路 http://localhost/login 将比對規則B,http://localhost/register 則比對規則H 通路 http://localhost/static/a.html 将比對規則C 通路 http://localhost/a.gif, http://localhost/b.jpg 将比對規則D和規則E,但是規則D順序優先,規則E不起作用,而 http://localhost/static/c.png 則優先比對到 規則C 通路 http://localhost/a.PNG 則比對規則E, 而不會比對規則D,因為規則E不區分大小寫。 通路 http://localhost/a.xhtml 不會比對規則F和規則G,http://localhost/a.XHTML不會比對規則G,因為不區分大小寫。規則F,規則G屬于排除法,符合比對規則但是不會比對到,是以想想看實際應用中哪裡會用到。 通路 http://localhost/category/id/1111 則最終比對到規則H,因為以上規則都不比對,這個時候應該是nginx轉發請求給後端應用伺服器,比如FastCGI(php),tomcat(jsp),nginx作為方向代理伺服器存在。 是以實際使用中,個人覺得至少有三個比對規則定義,如下: [plain] view plain copy
- #直接比對網站根,通過域名通路網站首頁比較頻繁,使用這個會加速處理,官網如是說。
- #這裡是直接轉發給後端應用伺服器了,也可以是一個靜态首頁
- # 第一個必選規則
- location = / {
- proxy_pass http://tomcat:8080/index
- }
- # 第二個必選規則是處理靜态檔案請求,這是nginx作為http伺服器的強項
- # 有兩種配置模式,目錄比對或字尾比對,任選其一或搭配使用
- location ^~ /static/ {
- root /webroot/static/;
- }
- location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
- root /webroot/res/;
- }
- #第三個規則就是通用規則,用來轉發動态請求到後端應用伺服器
- #非靜态檔案請求就預設是動态請求,自己根據實際把握
- #畢竟目前的一些架構的流行,帶.php,.jsp字尾的情況很少了
- location / {
- proxy_pass http://tomcat:8080/
- }