客户反映:说自己的网站走nginx代理后,打开空白。直接IP加地址访问是好的(http://ip:port)
故障排查:
1、打开chrome浏览器,访问了下,访问情况真是客户描述的那样。
2、感觉打开chrome ,开发者工具,发现部分请求URL是404,css和js的
3、找客户要服务器登录的账号,检查nginx配置文件
upstream www.test.com{\n server 127.0.0.1:8080;\n}\nserver {\n listen 80;\n listen 443 ssl http2;\n ssl_certificate /usr/local/nginx/conf/ssl/www.test.com.pem;\n ssl_certificate_key /usr/local/nginx/conf/ssl/www.test.com.key;\n server_name www.test.com;\n access_log /data/wwwlogs/www.test.com_nginx.log combined;\n index index.html index.htm index.jsp;\n root /data/wwwroot/www.test.com;\n \n \n location ~ .*\\.(js|css)?$ {\n \n expires 7d;\n access_log off;\n }\n\n location / {\n proxy_pass http://www.test.com;\n include proxy.conf;\n }\n}\n
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{\n server 127.0.0.1:8080;\n}\nserver {\n listen 80;\n listen 443 ssl http2;\n ssl_certificate /usr/local/nginx/conf/ssl/www.test.com.pem;\n ssl_certificate_key /usr/local/nginx/conf/ssl/www.test.com.key;\n server_name www.test.com;\n access_log /data/wwwlogs/www.test.com_nginx.log combined;\n index index.html index.htm index.jsp;\n root /data/wwwroot/www.test.com;\n \n\n location ~ .*\\.(js|css)?$ {\n proxy_pass http://www.test.com;\n expires 7d;\n access_log off;\n }\n\n location / {\n proxy_pass http://www.test.com;\n include proxy.conf;\n }\n}\n
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。