apache轉換到了nginx的幾個注意點

←手機掃碼閱讀     火星人 @ 2014-03-04 , reply:0

apache轉換到了nginx的幾個注意點

【from】www.mlives.cn
最近把整站從apache升級到了nginx,客戶的站點大概有30台伺服器大部分架構位tomcat+apache,只有一個php頁面
一下是我升級遇到的幾個問題的注意點

1.
當我們去訪問伺服器上的一個目錄時候,他不會自動加上一個/ ,瀏覽器會給出改頁無法打開的錯誤,這個時候瀏覽器去取的地址實際上是upstream中所寫的地址和埠或如果沒有使用upstream時 當使用localhost做servername時候 瀏覽器會去訪問http://127.0.0.1/dir。
解決辦法
在每個虛擬主機的server定義中加上
if (-d $request_filename) {
                           rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
                }
注意 root欄位的定義也一定要出現在server中 如果server中沒有定義root 錯誤還將存在
例子:
server {
                listen                800;
                server_name www.1.com;
                root   /opt/1-index;   //這邊定義了 就會在目錄訪問的時候加上/  如果這邊沒有定義這個 上面的url重寫依然不會生效
                include                vhost/alias.conf;
                include                vhost/proxy.conf;
                if (-d $request_filename) {
                           rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
                }
                error_page   405 =200 @405;
                location @405 {
                proxy_pass      http://PROXY_STATIC;
                }
                location / {
                        root   /opt/1-index;        //只在這邊定義是沒有用的,這邊甚至可以不做定義
                        rewrite ^/(\d+)\.home$ /index.html?userId=$1 last;
                        index  index.html index.htm;
                }                       

2.url重寫的注意事項:
原有的url支持正則  重寫的url不支持正則
rewrite ^/(\d+)\.home$ /index.html?userId=$1 last;
這個重寫中 ^/(\d+)\.home$ 這部分支持正則
而/index.html?userId=$1
不要用正則 也不匹配正則 /index.html?*userId=$1 這樣他就會去找.html?*userId=$1這個url 然後給你個404 not found

3.post方式去訪問靜態文件
Apache、IIS、Nginx等絕大多數web伺服器,都不允許靜態文件響應POST請求,否則會返回「HTTP/1.1 405 Method not allowed」錯誤。(但是之前程序在apache上跑 沒問題)
如果有這個需求呢 就要做如下配置了
error_page   405 =200 @405;
                location @405 {
                proxy_pass      http://PROXY_STATIC;
        #        root /usr/local/nginx/html;
                }
把所有405錯誤重定向成200 然後吧所有405錯誤的請求全部交給一個代理去執行
或者寫上本地路徑,因為我的路徑比較多 所以重定向請求到一台web伺服器上了

4.。關於防盜鏈
1.com的需求是 不是從本來來的請求給除一個403
因為在虛擬主機里配置毫無作用 可能是我們用的是虛擬目錄的緣故
所以我們直接對目錄做的防盜鏈
在alias里
別名配置
                location /res/ {
                alias   /opt/Src/;
                valid_referers none blocked server_names *.1.com ;
                if ($invalid_referer) {
        return 403;
                }
        }

5,關於動態請求轉發
location  ~ ^/login/(.*\.do)$ {
                proxy_pass      http://login ;
        proxy_set_header  X-Real-IP  $remote_addr;
}
~ ^/login/(.*\.do)$ 這個表示 凡是匹配/login/ 下 .do的都轉發到一個upstream池裡處理 這裡的$符號並不起多大作用 只要是有.do的他會全部轉 並不是以.do結尾的才轉

6.關於php上傳文件大小的問題
只改php里的配置是沒有用的
需要更改的地方還有nginx的配置

client_max_body_size 10M;
他的默認值是1M;

以上就是基本的注意點

[ 本帖最後由 asusarhai 於 2009-2-12 11:06 編輯 ]
《解決方案》

回復 #1 asusarhai 的帖子

好文,我在遷移的時候,也遇到上面的一些問題。
《解決方案》

看過了
《解決方案》

不知樓主有沒有遇到過返回400錯誤的情況,

這時在訪問日誌中出現:
" 400 0 "-" "-" "-" "-"
這種記錄
《解決方案》

好文


記錄下
《解決方案》

貌似那個不自動給子目錄加/的問題好像可以用兩個參數解決啊

optimize_server_names off;#優化伺服器名稱:關
server_name_in_redirect off;#伺服器名稱重定向:關
《解決方案》

好文收藏。
《解決方案》

原帖由 kisswen 於 2009-1-14 18:57 發表 http://bbs.chinaunix.net/images/common/back.gif
貌似那個不自動給子目錄加/的問題好像可以用兩個參數解決啊

optimize_server_names off;#優化伺服器名稱:關
server_name_in_redirect off;#伺服器名稱重定向:關
我之前有試驗過 好像沒管用
《解決方案》

關注 Nginx。。。。
可以應用在高併發的站點上,不知道比起lighttpd 效果如何
《解決方案》

正在關注nginx




[火星人 ] apache轉換到了nginx的幾個注意點已經有427次圍觀

http://coctec.com/docs/service/show-post-19915.html