java-ee - nginx反向代理tomcat时资源文件处理问题
问题描述
nginx上配置如下48 location ^~ /bgmonitor/ { 50 proxy_pass http://localhost:8080/; 51 }
形如www.mr.org/bgmonitor的请求转发到本地8080端口的tomcat
tomcat配置如下<Context docBase='/Users/mr/Documents/code_pool/bgmonitor-git/bgmonitor-web/target/bgmonitor' path='' reloadable='true'/>页面渲染使用velocity,资源文件引用路径为:
<!-- bootstrap 3.0.2 --> <link href='https://www.haobala.com/wenda/${rc.contextPath}/css/bootstrap.css' rel='stylesheet' type='text/css'/> <!-- font Awesome --> <link href='https://www.haobala.com/wenda/${rc.contextPath}/css/font-awesome.min.css' rel='stylesheet' type='text/css'/> <!-- Ionicons --> <link href='https://www.haobala.com/wenda/${rc.contextPath}/css/ionicons.min.css' rel='stylesheet' type='text/css'/> <!-- Theme style --> <link href='https://www.haobala.com/wenda/${rc.contextPath}/css/AdminLTE.css' rel='stylesheet' type='text/css'/>现象
访问时由于${rc.contextPath}取出为空,导致整个资源路径变为/css/AdminLTE.css ,这个请求发到nginx后就没法正常转发啦
问怎么做才能在最小修改的情况下让整个应用正常?
问题解答
回答1:静态文件不需要转发,在 nginx 本机上部署静态文件,比如
location ~* ^/(?:images/|js/|css/) { root /home/app/htdocs;}
具体如何配置参考文档
回答2:详见博客:http://blog.iaceob.name/nginx-proxy/以及http://blog.iaceob.name/tomcat-multi-domain-binding/
便是我使用的解决方案, 只是我个人这么使用而已, 暂未发现有别人这么使用过.
相关文章:
1. node.js - webpack required打包问题2. javascript - h5微信中怎么禁止横屏3. 为什么我ping不通我的docker容器呢???4. docker-compose中volumes的问题5. boot2docker无法启动6. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题7. nignx - docker内nginx 80端口被占用8. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””9. python - 怎么查看网址做的是什么反爬虫10. angular.js使用$resource服务把数据存入mongodb的问题。

网公网安备