Spring cloud Gateway与nacos配置中心整合

Spring cloud Gateway与nacos配置中心整合

新建工程并导入依赖

		<!--gateway依赖,与spring-boot-start-web会有冲突,不可同时存在-->
 		<dependency>
 			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-gateway</artifactId>
		</dependency>
		<!--注册服务到nacos-->
		<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--使用nacos的配置中心-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

修改配置文件 bootstrap.yml

server:
  port: 10010
spring:
  application:
    name: gateway-service
  profiles:
    active: dev
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
        username: nacos
        password: nacos
      config:
        server-addr: localhost:8848
        file-extension: yaml
        # 自动刷新配置文件
        refresh-enabled: true
        group: DEFAULT_GROUP

在nacos的配置中心新建配置文件,测试不同的谓词工厂

gateway-service-dev.yaml(命名格式必须为:服务名+特定环境配置文件名.yaml)

spring.cloud.gateway.routes:
  - id: consumer
    # lb 是 LoadBalancer的缩写,表示要使用本地的负载均衡器来路由到指定的服务
    uri: lb://consumer-service
    # 截取请求的第一个字段
    filters: 
      - StripPrefix=1

    # 1、The After Route Predicate Factory
    predicates:
      - After=2023-07-14T17:50:42.579+08:00[Asia/Shanghai]


    # 2、The Before Route Predicate Factory
    # predicates:
    #   - Before=2023-07-18T17:50:42.579+08:00[Asia/Shanghai]


    # 3、The Between Route Predicate Factory
    # predicates:
    #   - Between=2023-07-10T17:50:42.579+08:00[Asia/Shanghai],2023-07-18T17:50:42.579+08:00[Asia/Shanghai]


    # 4、The Cookie Route Predicate Factory       
    # 设置访问请求的cookie名称和cookie值符合的正则表达式
    # predicates:
    #   - Cookie=mycookie,[a-zA-Z]

    # 5、The Header Route Predicate Factory   
    # 设置请求头的名称和请求头的值符合的正则表达式
    # 只有请求的名称和设置一致并且请求头的值满足正则表达式,请求才能发送给服务
    # predicates:
    #   - Header=Request-Id,[a-zA-Z]    

    # 6、The Host Route Predicate Factory
    # 只有请求头的名称为host,并且符合**.somehost,请求才能转发给服务
    # predicates:
    #   - Host=**.somehost

    # 7、The Method Route Predicate Factory
    # 设置能够访问的请求方法
    # predicates:
    #   - Method=GET,POST

    # 8、The Path Route Predicate Factory
    # predicates:
    #   - Path=/consumer/**

    # 9、The Query Route Predicate Factory
    # 设置允许访问的携带参数的名称
    # 只有请求携带有data的参数,请求才能访问到服务
    # predicates:
    #   - Query=data

    # 10、The RemoteAddr Route Predicate Factory
    # 设置允许访问的ip地址
    # 只有访问的ip地址在此网段内,请求才能访问服务
    # predicates:
    #   - RemoteAddr=127.0.0.1/10
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于将GatewayNacos进行整合,您可以按照以下步骤进行操作: 1. 确保您已经正确安装和配置NacosSpring Cloud Gateway。 2. 在您的Gateway项目中,添加对Nacos的依赖。您可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> ``` 3. 在您的Gateway项目的配置文件中,配置Nacos的相关信息。您可以在application.yml或application.properties文件中添加以下配置: ```yaml spring: cloud: nacos: discovery: server-addr: ${NACOS_SERVER_ADDR:localhost:8848} # Nacos服务端地址 ``` 4. 在您的Gateway启动类上添加`@EnableDiscoveryClient`注解,以使Gateway能够与Nacos进行服务发现和注册。例如: ```java import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @EnableDiscoveryClient public class GatewayApplication { public static void main(String[] args) { SpringApplication.run(GatewayApplication.class, args); } } ``` 5. 根据您的需求,配置Gateway的路由规则。您可以在配置文件中使用`spring.cloud.routes`属性或编程方式进行配置。更多关于Gateway路由的信息,请参考Spring Cloud Gateway的官方文档。 6. 启动Gateway应用程序,并确保Nacos服务正在运行。 通过以上步骤,您就可以成功将GatewayNacos整合在一起,实现服务的动态发现和路由。希望能对您有所帮助!如果您有任何其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值