我在本地 CentOS 6.3 服务器上运行 nginx。我有一个加载到网页中的特定 javascript 文件。如果我更改 javascript 文件并刷新网页,我总是会收到 500 错误。然后当我再次刷新它时,JS文件加载得很好。
稍后,如果我再次更改 JS 文件,并刷新浏览器,同样的 500 错误。一次又一次地刷新,它加载得很好。它只在第一次刷新时给出 500 错误。
为什么是这样?这是我的服务器配置:
server {
listen 80;
server_name www.mysite.local;
rewrite ^(.*) http://mysite.local$1 permanent;
}
server {
listen 80;
server_name mysite.local;
access_log /var/log/nginx/mysite.local/access.log;
error_log /var/log/nginx/mysite.local/error.log;
rewrite_log on;
root /vhosts/mysite/mysite.local/public;
index index.php;
# Heres my redirect, try normal URI and then our Laravel urls.
location / {
try_files $uri $uri/ /index.php?$query_string;
}
include /etc/nginx/templates/other;
这是包含文件:
if (!-d $request_filename) {
rewrite ^/(.+)/$ /$1 permanent;
}
location ~ \.php$ {
include /etc/nginx/fastcgi_params;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
location ~ /\.ht {
deny all;
}
错误日志:
2014/09/06 23:19:58 [crit] 27884#0: *29935 open() "/vhosts/mysite.local/public/js/testfile.js" failed (11: Resource temporarily unavailable), client: 192.168.1.51, server: mysite.local, request: "GET /js/testfile.js HTTP/1.1", host: "mysite.local", referrer: "http://mysite.local/some/page"
我是唯一连接到服务器的人。没有其他流量。保存文件后是否立即刷新页面或等待(例如 15 秒或其他时间)都没有关系。第一次刷新总是500错误。
我正在通过 Samba 连接访问/编辑文件。
这最终成为 Samba 的问题,而不是 nginx。我通过将以下内容添加到我的 Samba 配置中解决了这个问题:
最初在以下 SO 线程中找到:https ://stackoverflow.com/questions/10202567/nginx-resource-temporarily-unavailable-using-a-samba-share