springcloud(七)zuul 路由网关

本文详细介绍了Zuul作为微服务路由网关的功能,包括其路由和过滤特性,如何整合Eureka实现服务发现,以及如何配置和使用Zuul进行微服务间的路由和代理。提供了具体的配置示例和访问规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,zuul

Zuul包含了对请求的路由和过滤两个最主要的功能:
其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。

注意:Zuul服务最终还是会注册进Eureka

提供=代理+路由+过滤三大功能

2,具体使用

2.1 新建Module模块 microservice-zuul-gateway-9527

pom.xml

   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-eureka</artifactId>
   </dependency>
   <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-zuul</artifactId>
   </dependency>

application.yml

server:
  port: 9527

spring:
  application:
    name: microservicecloud-zuul-gateway

eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka
  instance:
    instance-id: gateway-9527.com
    prefer-ip-address: true

zuul:
  prefix: /testdemo
  ignored-services: "*"
  routes:
    mydept.serviceId: microservice-config-provider-dept
    mydept.path: /mydept/**

info:
  app.name: gateway-9527
  company.name: www.testdemo.com
  build.artifactId: $project.artifactId$
  build.version: $project.version$
主启动类
@SpringBootApplication
@EnableZuulProxy
public class Zuul_9527_StartSpringCloudApp {
    public static void main(String[] args)
    {
        SpringApplication.run(Zuul_9527_StartSpringCloudApp.class, args);
    }

}

2.2 测试

启动Eureka Server(microservice-eureka-7001)
启动服务配置中心(microservice-config-center-3344)【从 GitHub 获取配置信息 】
启动服务提供者(microservice-provider-dept-8001)【从服务配置中心获取信息】
启动服务路由网关(microservice-zuul-gateway-9527)

不用路由:http://localhost:8001/dept/get/2
使用路由:http://myzuul.com:9527/microservicecloud-dept/dept/get/2

2.4 路由访问映射规则

代理名称

before
http://myzuul.com:9527/microservice-dept/dept/get/2

application.yml

zuul: 
  routes: 
    mydept.serviceId: microservice-dept
    mydept.path: /mydept/**  # 代理名称

after
http://myzuul.com:9527/mydept/dept/get/2

忽略原真实服务名

application.yml

zuul: 
  ignored-services: "*"  # 忽略所有微服务,即所有访问都要通过zuul
  routes: 
    mydept.serviceId: microservice-dept
    mydept.path: /mydept/**

设置统一公共前缀

application.yml

zuul: 
  prefix: /atguigu  # 设置前缀
  ignored-services: "*"
  routes: 
    mydept.serviceId: microservice-dept
    mydept.path: /mydept/**

最终yml

zuul: 
  prefix: /atguigu
  ignored-services: "*"
  routes: 
    mydept.serviceId:microservicecloud-dept
    mydept.path: /mydept/**

http://myzuul.com:9527/atguigu/mydept/dept/get/1

3,参考资料

http://www.chilangedu.com/sectionq/1910610451/E45F6ED4FAB77F58

资源下载链接为: https://pan.quark.cn/s/1bfadf00ae14 华为移动服务(Huawei Mobile Services,简称 HMS)是一个全面开放的移动服务生态系统,为企业和开发者提供了丰富的工具和 API,助力他们构建、运营和推广应用。其中,HMS Scankit 是华为推出的一款扫描服务 SDK,支持快速集成到安卓应用中,能够提供高效且稳定的二维码和条形码扫描功能,适用于商品扫码、支付验证、信息获取等多种场景。 集成 HMS Scankit SDK 主要包括以下步骤:首先,在项目的 build.gradle 文件中添加 HMS Core 库和 Scankit 依赖;其次,在 AndroidManifest.xml 文件中添加相机访问和互联网访问权限;然后,在应用程序的 onCreate 方法中调用 HmsClient 进行初始化;接着,可以选择自定义扫描界面或使用 Scankit 提供的默认扫描界面;最后,实现 ScanCallback 接口以处理扫描成功和失败的回调。 HMS Scankit 内部集成了开源的 Zxing(Zebra Crossing)库,这是一个功能强大的条码和二维码处理库,提供了解码、生成、解析等多种功能,既可以单独使用,也可以与其他扫描框架结合使用。在 HMS Scankit 中,Zxing 经过优化,以更好地适应华为设备,从而提升扫描性能。 通常,ScanKitDemoGuide 包含了集成 HMS Scankit 的示例代码,涵盖扫描界面的布局、扫描操作的启动和停止以及扫描结果的处理等内容。开发者可以参考这些代码,快速掌握在自己的应用中实现扫码功能的方法。例如,启动扫描的方法如下: 处理扫描结果的回调如下: HMS Scankit 支持所有安卓手机,但在华为设备上能够提供最佳性能和体验,因为它针对华为硬件进行了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值