一、Gateway
有了网关就可以对请求进行路由,比如:可以根据请求路径路由、根据host地址路由等, 当微服务有多个实例时可以通过负载均衡算法进行路由,如下:
另外,网关还可以实现权限控制、限流等功能。
项目采用Spring Cloud Gateway作为网关,网关在请求路由时需要知道每个微服务实例的地址,项目使用Nacos作用服务发现中心和配置中心,整体的架构图如下:
流程如下:
1、微服务启动,将自己注册到Nacos,Nacos记录了各微服务实例的地址。
2、网关从Nacos读取服务列表,包括服务名称、服务地址等。
3、请求到达网关,网关将请求路由到具体的微服务。
配置和说明如下,另外还需导入依赖
gateway:
# filter:
# strip-prefix:
# enabled: true
routes: # 网关路由配置
- id: content-api # 路由id,自定义,只要唯一即可
# uri: http://127.0.0.1:8081 # 路由的目标地址 http就是固定地址
uri: lb://content-api # 路由的目标地址 lb就是负载均衡,后面跟服务名称
predicates: # 路由断言,也就是判断请求是否符合路由规则的条件
- Path=/content/** # 这个是按照路径匹配,只要以/content/开头就符合要求
# filters:
# - StripPrefix=1
- id: system-api
# uri: http://127.0.0.1:8081
uri: lb://system-api
predicates:
- Path=/system/**
# filters:
# - StripPrefix=1
二、Nacos
Nacos有两个作用:
1、服务发现中心/注册中心。
微服务将自身注册至Nacos,网关从Nacos获取微服务列表。
2、配置中心。
微服务众多,它们的配置信息也非常复杂,为了提供系统的可维护性,微服务的配置信息统一在Nacos配置。
如果不需要作为服务注册到nacos,只需导入config依赖
在搭建Nacos服务发现中心之前需要搞清楚两个概念:namespace和group
namespace:用于区分环境、比如:开发环境、测试环境、生产环境。
group:用于区分项目,比如:xuecheng-plus项目、xuecheng2.0项目
3、dataid
dataid有三部分组成,
比如:content-service-dev.yaml配置文件 由(content-service)-(dev). (yaml)三部分组成
content-service:第一部分,它是在application.yaml中配置的应用名,即spring.application.name的值。
dev:第二部分,它是环境名,通过spring.profiles.active指定,
Yaml: 第三部分,它是配置文件 的后缀,目前nacos支持properties、yaml等格式类型,本项目选择yaml格式类型。
4、扩展配置文件和共享配置文件
扩展配置文件extension-configs
extension-configs:
- data-id: content-service-${spring.profiles.active}.yaml
group: xuecheng-plus-project
refresh: true
共享配置文件shared-configs
shared-configs:
- data-id: swagger-${spring.profiles.active}.yaml
group: xuecheng-plus-common
refresh: true
三、配置文件优先级
配置文件 的优先级:项目应用名配置文件 > 扩展配置文件 > 共享配置文件 > 本地配置文件。
我们想让本地最优先,可以在nacos配置文件 中配置如下即可实现:
#配置本地优先 |
完整的配置文件优先级如下:
配置文件优先级:
(1)命令行参数;
(2)java:comp/env的JNDI属性;
(3)JAVA系统的环境属性;
(4)操作系统的环境变量;
(5)JAR包外部的application-XXX.properties或application-XXX.yml配置文件;
(6)JAR包内部的application-XXX.properties或application-XXX.yml配置文件;
(7)JAR包外部的application.properties或application.yml配置文件;
(8)JAR包内部的application.properties或application.yml配置文件;
(9)@Configuration注解类上的@PropertySource指定的配置文件;
(10)通过SpringApplication.setDefaultProperties 指定的默认属性;
四、分布式文件系统
概念:通过网络将若干文件存储服务器组织起来共同去存储海量的文件,这些服务器通过网络进行通信,这样的服务器组织就是分布式文件系统。
五、MinIO
本项目采用MinIO构建分布式文件系统,MinIO 是一个非常轻量的服务
MinIO集群采用去中心化共享架构,每个结点是对等关系
maven依赖如下:
|