api-gateway是什么?为什么要api-gateway? 怎么使用api-gateway?
一 api-gateway网关,请求会先到网关这一层,由网关进行路由转发
二 Gateway作用:
1.SpringCloud体系专门推出
2.容器部署微服务的ip地址一直在换,需要结合注册中心来使用,所以gateway更灵活
三 项目中使用api-gateway
添加依赖:
<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>
<!--配置中心-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
配置文件配置:
server:
port: 8888
spring:
application:
name: api-gateway
cloud:
#注册中心地址
nacos:
discovery:
server-addr: 111.22.33.44:8848
gateway:
routes: #数组形式
- id: zwt-service1 #微服务1 路由唯一标识
uri: lb://zwt-user-service #从nocas进行转发
order: 1 #优先级,数字越小优先级越高
predicates: #断言 配置哪个路径才转发,前端访问路径统一加上XXX-server,网关判断转发对应的服务,如果是回调业务记得修改
- Path=/user-server/**
filters: #过滤器,请求在传递过程中通过过滤器修改
- StripPrefix=1 #去掉第一层前缀,转发给后续的路径
#开启网关拉取nacos的服务
discovery:
locator:
enabled: true
#设置日志级别,ERROR/WARN/INFO/DEBUG,默认是INFO以上才显示
logging:
level:
root: INFO
com.alibaba.nacos.client.config.impl: WARN
很多项目中,会选择同时使用nginx技术和gateway技术,那么为什么有了gateway了,还要使用nginx呢;或者为什么使用了nginx,还要使用gateway呢。我来大致描述下两者的区别:
nginx:
能做的事很多,反向代理,负载均衡,日志分析,黑名单配置,缓存前置,域名转发,配置https;很多gateway实现不了的,nginx可以实现,而且各个语言都可以配合使用
gateway:
是springcloud全家桶中的一员,和springcloud可以完美配合