nginx反向代理服务contextpath的问题解决

nginx反向代理服务contextpath的问题解决文章目录问题描述解决方案 sub filter 方案使用重定向单独域名访问问题描述现在的企业服务 往往不是单体的 同时可能涉及中间件的访问如 dubbo solr mq 等 对于中间件的监控页面访问 如果直接暴露在公网 肯定这安全 需发对中间件访问进行安全加固 方法主要有 1 限制使用 IP 白名单访问 2 安全密码访问 不使用简单密码 对于没有密码的 可以使用 basic 认证 强密码访问 3

问题描述

本文要讲的是(3)使用nginx代理,中间可能遇到的问题。

nginx反向代理,可以配置location代理不同的服务,这里就涉及到context-path。如果代理服务本来就不是通过“http://ip:端口/”访问的,而是通过“http://ip:端口/contextpath”访问的,就不会有问题。如果服务不支持“http://ip:端口/contextpath”访问,就涉及“/”路径的问题。

location /activemq/ { proxy_pass http://192.168.17.19:8161/; } 

如上代码,location activemq经反向代理后,访问的实际是8161端口下面的activemq路径,而8161端口”/activemq”下没有内容,就会返回404。当然如果只是代理一个服务是没有问题的(可以用“/”location做反向代理),代理多个服务就需要多个location,必然出现问题。

解决方案

sub_filter方案

使用nginx在jenkins返回的所有资源链接前面都加上/jenkins字段,这样用户接下来产生的GET请求都可以map到location /jenkins区块。要实现这个功能需要用到nginx的ngx_http_sub_module。参考Example,可以写出类似配置:

location /jenkins { sub_filter '<a href="/' '<a href="/jenkins/'; sub_filter '<img src="/' '<img src="/jenkins/'; # ...其他替换规则... sub_filter_once off; # 查找并替换多次 proxy_pass http://localhost:8002; } 

案例因特殊情况,使用了这种配置(公供参考):

 #mq location /activemq/ { sub_filter '<a href="/' '<a href="/activemq/'; sub_filter '<a title="Manage ActiveMQ broker" href="/admin/' '<a href="/activemq/admin/'; sub_filter '<a title="See some Web demos" href="/demo/' '<a href="/activemq/demo/'; sub_filter '<img src="/' '<img src="/activemq/'; sub_filter '<script src="/' '<script src="/activemq/'; sub_filter "type='text/javascript' src='/" "type='text/javascript' src='/activemq/"; sub_filter '<link href="/' '<link href="/activemq/'; sub_filter 'url(/' 'url(/activemq/'; sub_filter "@import url('/" "@import url('/activemq/"; sub_filter_once off; # 查找并替换多次 proxy_pass http://192.168.7.19:8161/; allow 219.143.147.82;#访问控制 allow 220.160.125.218;#访问控制 allow 36.110.62.178; # allow for sslvpn access allow 36.110.218.132; allow 112.48.19.106; deny all; } #solr location /solr/ { proxy_pass http://192.168.17.18:8983/solr/; allow 219.143.147.82;#访问控制 allow 220.160.125.218;#访问控制 allow 36.110.62.178; # allow for sslvpn access allow 36.110.218.132; allow 112.48.19.106; deny all; } #dubbo-admin location /dubbo-admin/ { proxy_pass http://192.168.17.20:8090/dubbo-admin/; allow 219.143.147.82;#访问控制 allow 220.160.125.218;#访问控制 allow 36.110.62.178; # allow for sslvpn access allow 36.110.218.132; allow 112.48.19.106; deny all; } #dubbo-monitor location /dubbo-monitor/ { sub_filter '<a href="/' '<a href="/dubbo-monitor/'; sub_filter '<img src="/' '<img src="/dubbo-monitor/'; #sub_filter_once off; # 查找并替换多次 proxy_pass http://192.168.17.21:8081/; allow 219.143.147.82;#访问控制 allow 220.160.125.218;#访问控制 allow 36.110.62.178; # allow for sslvpn access allow 36.110.218.132; allow 112.48.19.106; deny all; } 

但是这样做效率很低、且filter遗漏和出错可能性大(比如=>其他2)。

使用重定向

location /activemq/ { return 302 http://www.domain.com:8161/; } 

这样做的前提是开通8002的端口映射,还是涉及端口暴露问题。

单独域名访问

如果条件允许的话,应该是分配一个子域名(子域名都是单独的公网IP),比如activemq.domain.com会更合理和方便。nginx同一80端口,支持多域名监听配置。

配置参考

server { listen 443; server_name activemq.domain.com; add_header X-Frame-Options SAMEORIGIN; #rewrite ^(.*)$ http://${server_name}$1 permanent; ssl on; ssl_certificate /etc/nginx/sslkey/_.XXX.com_bundle.crt; ssl_certificate_key /etc/nginx/sslkey/XXX.com.key; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers AESGCM:ALL:!DH:!EXPORT:!RC4:+HIGH:!MEDIUM:!LOW:!aNULL:!eNULL; ssl_prefer_server_ciphers on; add_header X-Via nginx; #static path location / { proxy_pass http://192.168.17.19:8161/; } } 

臭味相投的朋友们,我在这里:
猿in小站:http://www.yuanin.net
csdn博客:https://blog.csdn.net/jiabeis
简书:https://www.jianshu.com/u/4cb7d664ec4b
微信免费订阅号“猿in”
猿in




参考:https://blog.csdn.net/silvita/article/details/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233537.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 《廖雪峰python3教程》| 书评 + 学习笔记干货

    《廖雪峰python3教程》| 书评 + 学习笔记干货如果你正在考虑自己适不适合读《廖雪峰python3教程》,不妨看看我的评价~我把知识盲点整理成了一份清单,你可以自测,然后参考我的学习笔记哦~

    2025年6月13日
    3
  • 怎么设置pycharm环境_怎么设置环境光影响物体

    怎么设置pycharm环境_怎么设置环境光影响物体恍惚大半年过去了,我也大半年没接触Pycharm找个软件了,今天由于项目需要,重新打开恍如一个陌生软件。折腾几分钟也渐渐回忆起那些熟悉的操作,但这几分钟以及在这几分钟前的对于陌生畏惧,以后像尽力避免罢了。我曾在不舍昼夜在Pycharm前敲打代码,似乎也成为了许久的过往,实际只是半年多而已…牢骚结束,言归正传。虚拟环境搭建搭建一个虚拟环境是件十分麻烦的事情,再娴熟的人也要花费个把小时,因为有一大堆包需要下载。点击File—>CreateProject,选择新环境,按照如下目录搭建虚拟环境,不过

    2022年8月27日
    4
  • Python—数据类型之float类型

    Python—数据类型之float类型浮点类型 Python 提供了 3 种浮点值 内置的 float 与 complex 类型 以及标准的 decimal Decimal 类型 Python 支持混合模式的算术运算 int 与 float 运算 生成 float float 与 complex 运算 生成 complex decimal Decimal 与 intS 运算 生成 decimal Decimal 注意 不兼容的数据类型进行运算 会产生 TypeEr

    2025年9月14日
    2
  • byte类型转换运算

    byte类型转换运算java中正数由原码表示,负数由补码表示!(符号位不取反!)(1)bytea=(byte)128 结果为-128128原码表示:00000000000000000000000010000000,取最后8位,最高位为1,表示负数。取反,加1,结果-128。(2)bytea=(byte)-129 结果为127-129补码表示:111111111111111

    2022年6月24日
    31
  • 最有效的最新防360拦截方法大全![通俗易懂]

    最有效的最新防360拦截方法大全![通俗易懂]首先声明,现在对于360拦截,没有任何一种方法是绝对有效的。因为存在举报,同一网站举报次数达到5次以上就会有360公司的员工接入人工审核,人工接入的话,再好的技术都是百搭,所以我这里的技术可以说绝对拦得住“机器审核”,具体“拦截时间未知”(因为不知道您的竞争对手什么时候会给您搞点小动作)我总结的方法一共有5种,都做过测试,分析出优缺点。具体如下:方法一:用框架调用主页,也就

    2025年8月10日
    3
  • Pycharm超好用的插件推荐,小新必备,快来收藏吧。(二)[通俗易懂]

    Pycharm超好用的插件推荐,小新必备,快来收藏吧。(二)[通俗易懂]Pcharm超好用的插件

    2022年8月25日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号