如題: 如果你的服務器有用到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