springboot 配置多个请求服务代理

springboot 配置服务代理

  有时候,我们可能有下边这样的需求:
这里写图片描述
即,针对于分布式服务,我们会有多种业务接口服务,但是服务器上可能只要求开放一个服务的端口,比如上图的restA项目端口是对外开放的,但是restB项目端口并未对外开放,这样带来的问题就是,用户无法直接请求restB项目。
  那就想到了可以通过访问restA ,请求路径符合一定规范的时候,比如http://ip:port/test ,当请求中以rest 开头时,可以再转发请求到restB 项目中即可。

  当然代理转发 ,有很多的解决办法,nginxzuul 等都可以实现,但是nginx 虽然简单,但是总要多装一个服务;zuul 配置较为麻烦。
  经过百度后,发现了一个特别简单的配置,即这里要说的东西,ServletRegistrationBean的注入,相当于是引入servlet ,没有具体看过 。
这里写图片描述

下面写一下配置步骤:

1、项目结构及介绍

  下面是我的项目结构,以下选中蓝色的项目为我们要配置的项目,其他的项目先忽略,是我们基于dubbozookeeper 配置的时候用的。
  项目已放到GitHub 上,下载项目GitHub地址
这里写图片描述
  关于这个项目的介绍是下边这样的,再配张图来介绍下:

这里写图片描述
  上图中关于suiteoneservicesuitetwoservicemasterservice 项目是我们的服务接口发布方项目。在这里我只是画出来,跟我们要配置的内容是无关的。
  suiteonesuitetwo 项目端口没有外放,用户不能直接访问,而master项目是可以直接访问的,所以用户是通过访问master 项目,再由master 项目对请求代理转发到这两个项目中。

2、具体配置步骤

  主要的配置很少,都在master 项目中。

(1)引入依赖:
 <!--ProxyFilter的引入依赖-->
      <dependency>
          <groupId>org.mitre.dsmiley.httpproxy</groupId>
          <artifactId>smiley-http-proxy-servlet</artifactId>
          <version>1.7</version>
      </dependency>
(2)、配置一个配置类:

  该类可以参照下载下来的,master 项目中的配置。

package microservice.sc.config;

import org.mitre.dsmiley.httpproxy.ProxyServlet;
import org.springframework.boot.bind.RelaxedPropertyResolver;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.EnvironmentAware;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
/**
 * Created by lsf on 2018/7/31.
 */
@Configuration
public class ProxyServletConfiguration implements EnvironmentAware {
    @Bean
    public ServletRegistrationBean servletRegistrationBean(){
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new ProxyServlet(), propertyResolver.getProperty("servlet_url_one"));
        //这个setName必须要设置,并且多个的时候,名字需要不一样
        servletRegistrationBean.setName("suitone");
        servletRegistrationBean.addInitParameter("targetUri", propertyResolver.getProperty("target_url_one"));
        servletRegistrationBean.addInitParameter(ProxyServlet.P_LOG, propertyResolver.getProperty("logging_enabled", "false"));
        return servletRegistrationBean;
    }

    @Bean
    public ServletRegistrationBean servletRegistrationBean2(){
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new ProxyServlet(), propertyResolver.getProperty("servlet_url_two"));
        //这个setName必须要设置,并且多个的时候,名字需要不一样
        servletRegistrationBean.setName("suittwo");
        servletRegistrationBean.addInitParameter("targetUri", propertyResolver.getProperty("target_url_two"));
        servletRegistrationBean.addInitParameter(ProxyServlet.P_LOG, propertyResolver.getProperty("logging_enabled", "false"));
        return servletRegistrationBean;
    }

    private RelaxedPropertyResolver propertyResolver;

    @Override
    public void setEnvironment(Environment environment) {
        this.propertyResolver = new RelaxedPropertyResolver(environment, "proxy.test.");
    }
}

(3)、配置代理地址:

  到master 项目的主配置文件,即application.properties 文件中,加入以下内容:

#请求testone时代理转发到30001项目中
proxy.test.servlet_url_one=/testone/*
proxy.test.target_url_one=http://localhost:30001

#请求testtwo时代理转发到30002项目中
proxy.test.servlet_url_two=/testtwo/*
proxy.test.target_url_two=http://localhost:30002

  上边的配置简单介绍一下,对于testone/* 这样的写法,意思就是当你的请求路径以testone 开头,比如http://localhost:30000/testone/test/get1 这样的路径,它请求的真实路径是http://localhost:30001/test/get1 。主要就是将testone 替换成对应的被代理路径而已,* 的意思就是实际请求项目中接口的路径!!!
  30001 端口即suiteone项目,30002 端口即suitetwo 项目,下载项目之后,分别启动mastersuiteonesuitetwo 项目的启动类,启动完成后,访问http://localhost:30000/testone/test/get1 ,即会返回suiteone 项目test/get1 接口的内容。
  这种配置对getpost 请求都有效。
  以上即是完整的配置内容。
  如果有不懂的,可以下载下来项目看一下。GitHub地址

  • 10
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
是的,Spring Boot可以很方便地实现网关代理。通常情况下,网关作为应用程序的入口点,可以在应用程序中处理一些共性的问题,如认证、授权、日志记录、请求转发、负载均衡等,从而简化了应用程序的开发和维护工作。 Spring Boot提供了一个名为Spring Cloud Gateway的子项目,可以轻松地实现网关代理。Spring Cloud Gateway基于异步非阻塞的Netty服务器实现,具有高性能和低资源消耗的优点。它支持各种路由规则、过滤器链和限流等功能,可以灵活地配置和扩展。 以下是一个简单的示例,演示如何使用Spring Cloud Gateway实现网关代理: 1. 添加Spring Cloud Gateway依赖 在Maven或Gradle中添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> ``` 2. 配置路由规则 在应用程序的配置文件中定义路由规则,例如: ```yaml spring: cloud: gateway: routes: - id: my-service uri: http://localhost:8081 predicates: - Path=/my-service/** ``` 上述配置表示将所有以“/my-service”开头的请求转发到“http://localhost:8081”地址。 3. 配置过滤器链 在需要时,可以添加多个过滤器,例如: ```yaml spring: cloud: gateway: routes: - id: my-service uri: http://localhost:8081 predicates: - Path=/my-service/** filters: - AddRequestHeader=X-Request-Foo, Bar - AddResponseHeader=X-Response-Baz, Qux ``` 上述配置表示在请求转发到目标地址之前,添加一个名为“X-Request-Foo”的请求头,并设置其值为“Bar”,在请求返回时,添加一个名为“X-Response-Baz”的响应头,并设置其值为“Qux”。 4. 启动应用程序 完成上述配置后,启动应用程序即可。此时,所有以“/my-service”开头的请求将被转发到“http://localhost:8081”地址,并经过过滤器链处理。 以上是一个简单的示例,实际使用中可能需要根据具体需求进行更复杂的配置和扩展。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

茁壮成长的凌大大

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值