【动态路由】系统web url整合系列【springcloud-gateway实现】【不改hosts文件版】组件一:多个Eureka路由过滤器

需求

      实现URL web资源整合,实现使用一个web地址访问多个web资源

方案

      本方案使用SpringCloud Gateway实现,不需要在hosts文件加添加域名映射(也不需要定义一系列域名),通过url路径来将请求转发到不同的Web资源

      如:http://${proxyIP}:${proxyPORT}/nacos1 

             转发到

             http://${nacos1IP}:${nacos1PORT}     

1、优点

  • 不需要用户端修改hosts文件(或是域名服务支持)

2、缺点

  • session信息可能会生产覆盖,存在session失效和横向越权风险

小知识:

        浏览器的session是按ip+端口(或域名+端口)作为唯一key存的

环境

spring-cloud 2024.0.0

spring-cloud gateway 4.2.0

实现代码

pom

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <!-- 3.4.0  3.3.6  3.1.5  3.0.12  -->
        <version>3.4.0</version>
        <!--  lookup parent from repository  -->
        <relativePath/>
    </parent>

    <groupId>person.daizd</groupId>
    <artifactId>gwproxy</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!-- 统一管理jar包版本 -->
    <properties>
        <java.version>17</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>

        <!--   3.4.0   3.3.6  -->
        <spring-boot.version>3.4.0</spring-boot.version>
        <!-- 2024.0.0   2023.0.4    -->
        <spring-cloud.version>2024.0.0</spring-cloud.version>
        <!--  2023.0.3.2   2023.0.1.3    2022.0.0.0    2021.1   2021.0.6.1   2021.0.5.0   -->
        <spring-cloud-alibaba.version>2023.0.3.2</spring-cloud-alibaba.version>

        <!--  springcloud 2020.02 以后需要单独引入     4.1.4   4.0.5  3.1.9  3.0.6  -->
        <spring-cloud-starter-bootstrap.version>4.1.4</spring-cloud-starter-bootstrap.version>
        <!-- 0.3.0-RC 适配springboot3    0.2.12 适配springboot2    0.1.10 适配springboot1   -->
        <nacos-config-spring-boot-starter.version>0.3.0-RC</nacos-config-spring-boot-starter.version>

        <!--        <junit.version>5.8.2</junit.version>-->
        <log4j.version>1.2.17</log4j.version>
        <lombok.version>1.18.28</lombok.version>

        <commons-lang3.version>3.14.0</commons-lang3.version>
        <io.micrometer.version>1.9.17</io.micrometer.version>

        <!--  pmd-core 7.0.0:  3.25.0  3.24.0  3.23.0  3.22.0
              pmd-core 6.55.0:  3.21.2    3.13.0  3.11.0 copote  -->
        <maven-pmd-plugin.version>3.26.0</maven-pmd-plugin.version>
        <maven-clean-plugin.version>3.26.0</maven-clean-plugin.version>
        <fastjson2.version>2.0.53</fastjson2.version>
    </properties>

    <dependencies>
        <!--gateway的依赖 springcloud开发-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
            <version>${spring-cloud-starter-bootstrap.version}</version>
        </dependency>

        <!--   之前工程即没有引入 SpringCloud,也没有引入 SpringCloudAlibaba  -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba.fastjson2</groupId>
            <artifactId>fastjson2</artifactId>
            <version>${fastjson2.version}</version>
        </dependency>

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>${commons-lang3.version}</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>io.micrometer</groupId>
            <artifactId>micrometer-registry-prometheus</artifactId>
        </dependency>

        <dependency>
            <groupId>io.netty</groupId>
            <artifactId>netty-resolver-dns-native-macos</artifactId>
            <version>4.1.115.Final</version>
            <classifier>osx-aarch_64</classifier>
        </dependency>


        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.8.22</version>
<!--            <scope>test</scope>-->
        </dependency>

        <!-- 测试相关 这个包含junit5  -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

    </dependencies>

    <dependencyManagement>
        <dependencies>

            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
                <version>${lombok.version}</version>
                <optional>true</optional>
            </dependency>

            <dependency>
                <groupId>io.micrometer</groupId>
                <artifactId>micrometer-registry-prometheus</artifactId>
                <version>${io.micrometer.version}</version>
                <scope>compile</scope>
            </dependency>

        </dependencies>

    </dependencyManagement>


    <build>

        <plugins>
            <!-- 用于支持热部署 -->
            <plugin>
                <groupId>org.springframework.boot</groupId>
        
<think>好的,我现在需要帮助用户在Spring Cloud Gateway集群中实现服务发现,而使用/etc/hosts配置。首先,我得理解用户的需求。他们可能希望在手动配置每个服务IP的情况下,通过服务发现机制让网关自动路由到相应的服务实例。这可能涉及到服务注册与发现组件,比如Eureka、Consul或Nacos。 根据用户提供的引用,特别是引用[3]和引用[4],他们提到了使用Eureka作为服务注册中心,并且网关配置中使用了lb://SpringBootDemo这样的URI,说明已经集成了负载均衡。但用户现在的问题是如何避免使用/etc/hosts文件来解析主机名,通常/etc/hosts用于本地域名解析,但在集群环境中手动维护这个文件实际,尤其是在动态扩展的服务中。 接下来,我需要确定如何让Spring Cloud Gateway通过服务发现机制自动获取服务实例,而依赖于静态的主机配置。首先,服务发现的核心是让各个服务实例在启动时向注册中心注册自己的信息,包括主机名和端口。网关则通过查询注册中心来获取可用的服务实例列表,并根据路由规则进行转发。 用户可能已经配置了Eureka,如引用[2]提到的启动Eureka服务器和注册服务。需要检查他们的网关配置是否正确集成Eureka客户端,以便自动发现服务。可能的步骤包括: 1. 确保网关服务添加了Eureka客户端依赖,例如spring-cloud-starter-netflix-eureka-client。 2. 配置application.yml或bootstrap.yml中的Eureka服务器地址,使网关能够连接到注册中心。 3.路由配置中使用lb://SERVICE-ID格式,这样网关会通过负载均衡器从Eureka获取服务实例列表。 4. 确保各个微服务正确注册到Eureka,并且健康状态正常。 另外,用户提到使用/etc/hosts,可能需要使用DNS服务来解析Eureka服务器的主机名,或者在云环境中使用服务发现的内置机制。例如,在Kubernetes中,可以通过服务名自动解析,但用户的环境可能同。 还需要考虑服务发现的高可用性,比如Eureka集群配置,如引用[2]中的集群构建步骤,确保多个Eureka节点相互注册,避免单点故障。 总结下来,用户需要正确配置Spring Cloud GatewayEureka的集成,利用服务发现动态获取服务实例,避免手动维护主机配置。同时,确保所有服务正确注册到Eureka,并且网关的路由配置使用服务ID进行负载均衡。</think>在Spring Cloud Gateway集群中实现服务发现且依赖`/etc/hosts`配置,需通过服务注册与发现组件(如Eureka、Consul或Nacos动态获取服务实例信息。以下是具体步骤: --- ### **1. 集成服务注册中心(以Eureka为例)** #### **1.1 添加Eureka客户端依赖** 在Gateway项目的`pom.xml`中添加Eureka客户端依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> ``` #### **1.2 配置Eureka服务器地址** 在`application.yml`中配置Eureka服务器地址,使网关能连接到注册中心: ```yaml eureka: client: service-url: defaultZone: http://eureka-server1:8761/eureka,http://eureka-server2:8762/eureka # Eureka集群地址 instance: hostname: gateway-node1 # 网关实例名称(可选) ``` --- ### **2. 配置动态路由** 在网关的路由配置中使用`lb://SERVICE-ID`格式,通过负载均衡器动态获取服务实例: ```yaml spring: cloud: gateway: routes: - id: order-service uri: lb://ORDER-SERVICE # 服务注册中心的ID predicates: - Path=/api/order/** - id: payment-service uri: lb://PAYMENT-SERVICE predicates: - Path=/api/payment/** ``` --- ### **3. 验证服务发现** 1. **启动服务**: - 启动Eureka集群(参考引用[2]的集群配置步骤)。 - 启动微服务(如`payment-service`、`order-service`),确保它们成功注册到Eureka- 启动Spring Cloud Gateway实例。 2. **检查服务注册**: - 访问Eureka控制台(如`http://eureka-server1:8761`),确认所有服务实例和网关已注册。 3. **测试路由转发**: - 访问`http://gateway-host:port/api/order/123`,请求会自动路由到`ORDER-SERVICE`的实例,无需手动配置IP或域名[^3]。 --- ### **4. 替代`/etc/hosts`的方案** - **DNS服务**:为Eureka服务器和微服务配置DNS解析,避免硬编码IP。 - **容器化环境**:在Kubernetes中使用Service名称直接解析服务实例。 - **服务发现集成**:直接依赖注册中心(如Eureka)返回实例的IP和端口,无需本地解析。 --- ### **5. 高可用配置** - **Eureka集群**:部署多个Eureka节点并相互注册(参考引用[2]的集群构建步骤)。 - **网关集群**:部署多个Gateway实例,通过负载均衡器(如Nginx)分发请求[^3]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

飞火流星02027

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

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

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

打赏作者

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

抵扣说明:

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

余额充值