当前位置: 首页> 游戏> 游戏 > 杭州定制软件开发_百度提交入口使用教程_营销引流都有什么方法_新闻投稿平台

杭州定制软件开发_百度提交入口使用教程_营销引流都有什么方法_新闻投稿平台

时间:2025/7/8 16:11:34来源:https://blog.csdn.net/bohu83/article/details/144458861 浏览次数:0次
杭州定制软件开发_百度提交入口使用教程_营销引流都有什么方法_新闻投稿平台

本文属于b站图灵课堂springcloud笔记系列。讲的好还不要钱,值得推荐。

为什么需要API网关?

  • 客户端多次请求不同的微服务,会增加客户端代码和配置的复杂性,维护成本比价高
  • 认证复杂,每个微服务可能存在不同的认证方式,客户端去调用,要去适配不同的认证
  • 存在跨域的请求,调用链有一定的相对复杂性(防火墙 / 浏览器不友好的协议)
  • 难以重构,随着项目的迭代,可能需要重新划分微服务

为了解决上面的问题,引入了API网关

Spring Cloud Gateway 是什么?

This project provides an API Gateway built on top of the Spring Ecosystem, including: Spring 6, Spring Boot 3 and Project Reactor. Spring Cloud Gateway aims to provide a simple, yet effective way to route to APIs and provide cross cutting concerns to them such as: security, monitoring/metrics, and resiliency.

There are two distinct flavors of Spring Cloud Gateway: Server and Proxy Exchange. Each flavor offers WebFlux and MVC compatibility.

  • The Server variant is a full-featured API gateway that can be standalone or embedded in a Spring Boot application.

  • The Proxy Exchange variant is exclusively for use in annotation based WebFlux or MVC applications and allows the use of a special ProxyExchange object as a parameter to a web handler method.

就是spring cloud 官方推出的第二代网关,是由 WebFlux + Netty + Reactor 实现的响应式的 API 网关。

特性:

  • Java 17

  • Spring Framework 6

  • Spring Boot 3

  • Dynamic routing

  • Route matching built into Spring Handler Mapping

  • Route matching on HTTP Request (Path, Method, Header, Host, etc…​)

  • Filters scoped to Matching Route

  • Filters can modify downstream HTTP Request and HTTP Response (Add/Remove Headers, Add/Remove Parameters, Rewrite Path, Set Path, Hystrix, etc…​)

  • API or configuration driven

  • Supports Spring Cloud DiscoveryClient for configuring Routes

其余详细介绍请看GitHub - spring-cloud/spring-cloud-gateway: An API Gateway built on Spring Framework and Spring Boot providing routing and more.

 行业中通常把网关分为两个大类:流量网关与业务网关,流量网关主要提供全局性的、与后端业务无关的策略配置,如NG,随着应用架构模式从单体演进到现在的分布式微服务,业务网关也有了新的叫法 - 微服务网关,比如gateway.当然阿里也有开源的Higress实现了流量网关 + 微服务网关 + 安全网关高度集成的功能,这是一种发展趋势。

微服务接入gateway

新建一个模块,就是一个一个启动类

核心配置,pom引入gateway依赖

<!-- gateway网关 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!--nacos-discovery  注册中心依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!-- loadbalancer 负载均衡器依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-loadbalancer</artifactId></dependency>

配置文件:application.yml 如下

server:port: 18888spring:application:name: tlmall-gatewaycloud:nacos:
#      discovery:
#        server-addr: tlmall-nacos-server:8848config:server-addr: tlmall-nacos-server:8848file-extension: yml   #指定配置文件扩展名为yml#    gateway:
#      #设置路由:路由id、路由到微服务的uri、断言
#      routes:
#        - id: order_route  #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-order  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/order/**   # 断言,路径相匹配的进行路由
#
#        - id: storage_route   #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-storage  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/storage/**   # 断言,路径相匹配的进行路由
#
#        - id: account_route   #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-account  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/account/**   # 断言,路径相匹配的进行路由config:import:- optional:nacos:${spring.application.name}.yml- nacos:nacos-discovery.yml

注释掉内容抽取到nacos, Nacos配置中心创建一个dataId为tlmall-gateway.yml的配置,导入网关的配置.

测试:

启动网关服务。

修改postman,改用网关地址下单:http://127.0.0.1:18888/order/create

修改页面地址,order.html中访问地址都替换为tmall-gateway:18888,测试下单是否成功

小结:gateway可以实现微服务中流量入口。

关键字:杭州定制软件开发_百度提交入口使用教程_营销引流都有什么方法_新闻投稿平台

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: