个人名片:
博主:酒徒ᝰ.
个人简介:沉醉在酒中,借着一股酒劲,去拼搏一个未来。
本篇励志:三人行,必有我师焉。
本项目基于B站黑马程序员Java《SpringCloud微服务技术栈》,SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 点击观看
一、了解网关
1.网关功能
- 身份认证和权限校验
- 服务路由
- 负载均衡
- 请求限流
2.技术实现
- gateway:基于Spring5中WebFlux 响应是编程
- zuul:基于Servlet 阻塞式编程
3.网关的作用:
- 对用户请求做身份认证、权限校验
- 将用户请求路由到微服务,并实现负载均衡
- 对用户请求做限流
二、快速入门
1.创建网关模块(gateway)
注意位置。
2.引入依赖
<!--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>
3.编写配置(application.yml)
application.yml包括:服务基本信息(端口,名称),nacos地址,路由
路由包括:
1.路由id:路由的唯一标示
2.路由目标(uri):路由的目标地址,http代表固定地址,lb代表根据服务名负载均衡
3.路由断言(predicates):判断路由的规则,
4.路由过滤器(filters):对请求或响应做处理
server:
port: 10010 # 网关端口
spring:
application:
name: gateway # 服务名称
cloud:
nacos:
server-addr: localhost:8848 # nacos地址
gateway:
routes:
- id: user-service # 路由ID,自定义,只要唯一即可
# uri: http://127.0.0.1:8081 # 路由的目标地址 http 就是固定地址
uri: lb://userservice # 路有目标 lb为开启负载均衡,userservice为服务名称
predicates: # 路由断言,判断请求是否符合路由规则
- Path=/user/** # 路由规则 以user开头即可
- id: order-service
uri: lb://orderservice
predicates:
- Path=/order/**
了解:uri中的lb是(LoadBalance)实现负载均衡。如果不需要,可以使用固定地址。
4.启动类
package cn.itcast.gateway;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class GatewayApplication {
public static void main(String[] args) {
SpringApplication.run(GatewayApplication.class, args);
}
}
5.测试
访问路径:http://localhost:10010/user/1
访问路径:http://localhost:10010/order/101