文章插图
客户反映:说自己的网站走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; }}?
【nginx代理,网站404或空白怎么办?】
推荐阅读
- Nginx的主要功能你知道么?
- 网站优化100个法则,排名稳居第一的秘籍
- 网站应该怎样改版,怎样利用好SEO技术
- CentOS7如何安装最新版PHP7?Nginx或Apache该如何配置?
- Nginx 静态文件服务配置及优化
- linux 虚拟机下安装nginx的步骤教程
- 利用nginx设置浏览器协商缓存
- python:教你用爬虫通过代理自动刷网页的浏览量
- 快速了解正向代理与反向代理
- 建议收藏 Nginx的DNS解析详细过程分析