| 客户反映:说自己的网站走nginx代理后,打开空白。直接IP加地址访问是好的(http://ip:port)。 
 故障排查: (1) 打开chrome浏览器,访问了下,访问情况真是客户描述的那样。 (2) 感觉打开chrome ,开发者工具,发现部分请求URL是404,css和js的 
 (3) 找客户要服务器登录的账号,检查nginx配置文件 upstream www.test.com{   server 127.0.0.1:8080; } server {   listen 80;   listen 443 ssl http2;   ssl_certificate /usr/local/nginx/conf/ssl/www.test.com.pem;   ssl_certificate_key /usr/local/nginx/conf/ssl/www.test.com.key;   server_name www.test.com;   access_log /data/wwwlogs/www.test.com_nginx.log combined;   index index.html index.htm index.jsp;   root /data/wwwroot/www.test.com;          location ~ .*.(js|css)?$ {         expires 7d;     access_log off;   }    location / {     proxy_pass http://www.test.com;     include proxy.conf;   } } 
 (4) 大家有发现上面配置有问题不?刚开始我也没有注意,自认为配置文件是对 的。 打算检查nginx的日志,一遍请求URL,一遍查看nginx果然还是404.(感觉疑惑),明明配置了proxy_pass  http://www.test.com。 故障原因: 是因为 “location ~ .*.(js|css)?$” 这个匹配拦截掉了,请求不能正常发往下一个“location /”  ,也就不能正常抵达后端proxy_pass了。 解决方法: 第一种解决方法:是将后端的静态文件(css 和js ),放入前置nginx 机器/data/wwwroot/www.test.com 第二种解决方法 :修改配置文件 upstream www.test.com{   server 127.0.0.1:8080; } server {   listen 80;   listen 443 ssl http2;   ssl_certificate /usr/local/nginx/conf/ssl/www.test.com.pem;   ssl_certificate_key /usr/local/nginx/conf/ssl/www.test.com.key;   server_name www.test.com;   access_log /data/wwwlogs/www.test.com_nginx.log combined;   index index.html index.htm index.jsp;   root /data/wwwroot/www.test.com;         location ~ .*.(js|css)?$ {       proxy_pass http://www.test.com;     expires 7d;     access_log off;   }    location / {     proxy_pass http://www.test.com;     include proxy.conf;   } } 
 【编辑推荐】 【责任编辑:赵宁宁 TEL:(010)68476606】Windows 10中没有文本的空或空白对话框官宣:F5 已完成对 NGINX 的收购大流量、高负载场景 Nginx+Linux 性能调优Nginx 如何配置防盗链Nginx 如何限制访问频率,下载速率和并发连接数
 点赞 0
 (编辑:源码网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |