nginx重發機制


如題: 如果你的服務器有用到nginx,同時后台執行較長時,后台就有可能會接收多次請求,前提是先確保前端沒有發送多次請求. (因為nginx默認有個機制是當后台達到一定時間(時間根據nginx的配置)而又沒有返回信息時,nginx就會嘗試重新請求)
對此 有如下兩種解決方案:
1. 確定自己項目不要用到nginx重發機制. 那么就直接 server_name 上面加上 proxy_next_upstream off; 這個就是整個域名都禁用了
2. 只想對某些url進行設置,那么可以參照如下設置.

nginx參考配置

server {
  #加在這為全局匹配
 ;
server_name www.域名.com;
root /home/wwwroot/項目名稱;
index index.php index.html index.htm;

location / {
if (!-e $request_filename) {
rewrite ^/index.php(.*)$ /index.php?s=$1 last;
rewrite ^(.*)$ /index.php?s=$1 last;
break;
}
}

# 這個地方是重點 包含thirdpayde的url都禁用重發機制
# 這個地方是重點 包含thirdpayde的url都禁用重發機制 ~ \wthirdpay\w 為正則, 可以將\wthirdpay\w替換你要匹配的路徑
location ~ \wthirdpay\w {
proxy_next_upstream off;
}

location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PHP_VALUE open_basedir=$document_root:/tmp/:/proc/;
include fastcgi_params;
}

}
————————————————
原文鏈接:https://blog.csdn.net/weixin_37281289/java/article/details/88767714


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM