一、背景
最近遇到一個(gè)問(wèn)題504 GATEWAY TIMEOUT的問(wèn)題,在瀏覽器的NetWork里面看是這個(gè)效果。時(shí)間大概是60s。
二、問(wèn)題排查與解決
2.1 修改nginx配置
目前后端技術(shù)架構(gòu)主要是nginx和php-fpm,前端主要是vue框架打包發(fā)布。
于是首先想到了是nginx超時(shí)時(shí)間或者與php的超時(shí)時(shí)間設(shè)置的過(guò)段,然后配置nginx.conf設(shè)置了這些參數(shù)。
http {
...
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
proxy_connect_timeout 300;
proxy_read_timeout 300;
proxy_send_timeout 300;
keepalive_timeout 300;
...
}
nginx -s reload
2.2 修改PHP配置
然后發(fā)現(xiàn)并沒(méi)有解決問(wèn)題,504 GATEWAY TIMEOUT仍然在請(qǐng)求60秒左右被返回。然后又想到php的配置問(wèn)題,決定調(diào)整一下php的一些參數(shù)。
vim /etc/php.ini
max_execution_time = 300 //設(shè)置執(zhí)行時(shí)間為300秒保存
service php-fpm restart
// 然后去代碼里面設(shè)置
set_time_limit(300);
2.3 進(jìn)一步調(diào)整
經(jīng)過(guò)了上面PHP的設(shè)置,發(fā)現(xiàn)也沒(méi)有什么用,該超時(shí)還是超時(shí)。針對(duì)于一般的情況來(lái)說(shuō),上面的操作一般就能解決問(wèn)題了。
然后又開(kāi)始懷疑是不是vue框架本身的request有一個(gè)默認(rèn)的超時(shí)。
于是通過(guò)瀏覽器把請(qǐng)求通過(guò)curl拿出來(lái),去命令行執(zhí)行。發(fā)現(xiàn)經(jīng)過(guò)1分鐘還是超時(shí)。
到現(xiàn)在為止實(shí)際上還是沒(méi)有解決問(wèn)題。于是比較頭疼。
2.4 找到原因
接著分析原因??词欠裼蛎L問(wèn)后的第一步?jīng)]有直接到服務(wù)器。
1. 在服務(wù)器上面執(zhí)行如下命令,查看機(jī)器ip,得到ip A
curl ifconfig.me
2. 然后使用ping命令查看域名指向得到ip B
ping 你的域名
3. 發(fā)現(xiàn)A和B不一樣,問(wèn)題終于找到了,說(shuō)明域名是經(jīng)過(guò)中轉(zhuǎn)才到達(dá)我們的服務(wù)器
真實(shí)的超時(shí)是在B機(jī)器上面,而不是我們自己的服務(wù)器,所以這就是為啥上面的一系列調(diào)整沒(méi)有生效的原因。
4. 馬上來(lái)測(cè)試一下。`windows + R` 輸入 `C:\WINDOWS\system32\drivers\etc` 回車,找到`hosts`文件。
5. 打開(kāi)`hosts` 末尾追加`ipA 你的域名`。然后保存。這樣就讓域名直接指向了我們自己的服務(wù)器。
然后在進(jìn)行請(qǐng)求,發(fā)現(xiàn)請(qǐng)求時(shí)長(zhǎng)就可以超過(guò)60秒了。也沒(méi)有再出現(xiàn)504 GATEWAY TIMEOUT的情況。
三、網(wǎng)上其他該問(wèn)題的原因
3.1 PHP 執(zhí)行時(shí)間過(guò)長(zhǎng)
當(dāng) PHP 腳本的執(zhí)行時(shí)間超過(guò)了 Nginx 配置中設(shè)置的超時(shí)時(shí)間時(shí),會(huì)導(dǎo)致 Gateway Timeout 錯(cuò)誤??梢酝ㄟ^(guò)增加 fastcgi_read_timeout 配置項(xiàng)來(lái)延長(zhǎng)超時(shí)時(shí)間。
3.2 后端服務(wù)錯(cuò)誤
如果 PHP 后端服務(wù)發(fā)生了錯(cuò)誤,并且沒(méi)有及時(shí)返回響應(yīng),那么 Nginx 就會(huì)在超時(shí)時(shí)間內(nèi)等待,然后拋出 Gateway Timeout 錯(cuò)誤??梢酝ㄟ^(guò)檢查 PHP 代碼和日志來(lái)解決這個(gè)問(wèn)題。
3.3 PHP-FPM 配置問(wèn)題
PHP-FPM 是一種常用的 PHP FastCGI 管理器,在配置不正確的情況下可能會(huì)導(dǎo)致 Gateway Timeout 錯(cuò)誤。可以通過(guò)檢查 PHP-FPM 配置文件(通常位于 /etc/php-fpm.conf 或 /etc/php-fpm.d/www.conf)來(lái)解決問(wèn)題。
3.4 Nginx 配置問(wèn)題
Nginx 的配置文件也可能會(huì)導(dǎo)致 Gateway Timeout 錯(cuò)誤??梢酝ㄟ^(guò)檢查 Nginx 配置文件(通常位于 /etc/nginx/nginx.conf 或 /etc/nginx/conf.d/default.conf)來(lái)解決問(wèn)題。
3.5 網(wǎng)絡(luò)問(wèn)題
如果 PHP 后端服務(wù)無(wú)法正常連接或響應(yīng)請(qǐng)求,那么也會(huì)導(dǎo)致 Gateway Timeout 錯(cuò)誤??梢酝ㄟ^(guò)檢查網(wǎng)絡(luò)連接和防火墻設(shè)置來(lái)解決這個(gè)問(wèn)題。文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-782278.html
總結(jié)與思考
所以很多時(shí)候不要陷入到自己的常規(guī)思維里面去了,偶爾出去放松一下,回來(lái)或許有不一樣的視角。今天內(nèi)容就分享到這個(gè),有疑問(wèn)的,可以留言討論哦,喜歡作者可以給個(gè)關(guān)注喲
。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-782278.html
到了這里,關(guān)于解決504 GATEWAY TIMEOUT Nginx網(wǎng)關(guān)超時(shí)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!