故障排查:
、打开chrome浏览器,访问了下,访问情况真是客户描述的那样。
、感觉打开chrome ,开发者工具,发现部分请求URL是,css和js的
、找客户要服务器登录的账号,检查nginx配置文件
upstream www.test.com{ server ...:; } server { listen ; listen ssl http; 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 d; access_log off; } location / { proxy_pass http://www.test.com; include proxy.conf; } }
、大家有发现上面配置有问题不?刚开始我也没有注意,自认为配置文件是对 的。
打算检查nginx的日志,一遍请求URL,一遍查看nginx果然还是.(感觉疑惑),明明配置了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 ...:; } server { listen ; listen ssl http; 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 d; access_log off; } location / { proxy_pass http://www.test.com; include proxy.conf; } }