【微服务学习笔记(一)】Nacos、Feign、Gateway基础使用
- 总览
- Nacos
- Feign
- 统一网关Gateway
-
- 搭建网关
-
- [路由断言工厂(Route Predicate Factory)](#路由断言工厂(Route Predicate Factory))
- 路由过滤器(GatewayFliter)
- 全局过滤器(GlobalFilter)
- 过滤器执行顺序
- 跨域
本篇内容为学习笔记,学习链接为SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课
课程资料链接可在视频下方找到,此处不粘贴,而以下的代码都是资料中有的,只不过做为记录单独粘贴,做为学习使用的参考步骤。
总览
微服务中需要用到的内容:
服务网关、 服务集群、 注册中心、配置中心、消息队列,在和数据库连接过程中则用到分布式缓存、分布式搜索,还需要的额外服务为分布式日志、系统监控链路追踪。
在以上的完成后,使用Jenkins完成自动化编译的过程,由Docker打包成镜像。
各个内容中所需的技术:
- 微服务注册发现
- Eureka
- Nacos
- Consul
- 服务远程调用
- OpenFegin
- Dubbo
- 服务链路监控
- Zipkin
- Sleuth
- 统一配置管理
- SpringCloudConfig
- Nacos
- 统一网关路由
- SpringCloudGateway
- Zuul
- 流量监控、降级、保护
- Hystix
- Sentinel
Nacos
Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
安装配置
可以参考文档下载Nacos。
Windows启动命令(standalone代表着单机模式运行,非集群模式):
java
startup.cmd -m standalone
打开nacos -> bin目录中,使用cmd启动,输入以上命令,点击生成的地址即可进入Nacos页面。
使用
项目中:
父工程pom文件:
java
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.5.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
子工程pom文件:
java
<!-- nacos客户端依赖包 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
客户端子配置文件(application.yml)中:
java
spring:
application:
name: userService
cloud:
nacos:
server-addr: localhost:8848
Nacos注册中心
服务多级存储模型
一级为服务、二级为集群、三级为实例。
项目中采用配置:
java
nacos:
server-addr: localhost:8848
discovery:
cluster-name: CQ #自定义集群名称
集群的设置可让某一个服务被集群内的服务请求优先访问。
负载均衡规则
NacosRule优先选择本地集群访问,本地集群内随机访问各个服务,本地集群无服务时进行跨集群访问:
在Nacos页面中,根据权重调整(0~1),权重越小,访问的概率越小:
环境隔离
通过namespace进行环境隔离:
1、nacos命名空间中创建
2、客户端服务中放入namespace生成的id号
3、重启服务,刷新nacos页面
java
spring:
cloud:
nacos:
server-addr: localhost:8848
discovery:
cluster-name: HZ #自定义集群名称
namespace: c2a69c6f-995c-4cc0-a3e1-8f545ece5875
默认情况下服务为临时实例,心跳检测即为每隔一段时间,向注册中心发送内容证明还在服务。
而非临时实例的主动询问,询问结果为服务关闭时,注册中心会等待服务恢复。
临时实例修改为非临时实例:
java
spring:
cloud:
nacos:
server-addr: localhost:8848
discovery:
cluster-name: HZ #自定义集群名称
namespace: c2a69c6f-995c-4cc0-a3e1-8f545ece5875
ephemeral: false #是否为临时实例
修改后在Nacos中心查看:

配置管理
获取配置原理:
添加配置,打开Nacos页面:

配置拉取
客户端依赖
java
<!-- nacos配置管理依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
resouces中新建bootstrp.yml文件,内容符合在nacos配置管理中的配置:
java
spring:
application:
name: userservice
profiles:
active: dev #环境
cloud:
nacos:
server-addr: localhost:8848
config:
file-extension: yaml #文件后缀名
配置热更新
方法一:
通过@Value注解注入,@RefreshScope刷新
java
@RefreshScope
public class UserController {
@Autowired
private UserService userService;
@Autowired
private PatternProperties patternProperties;
@Value("${pattern.dateformat}")
private String dateformat;
}
方法二:
注入后自动刷新,声明于类前
java
@ConfigurationProperties(prefix = "pattern")
多服务共享配置
多服务共享配置会根据读取优先级来进行配置,在此处主要介绍各个配置文件的优先级,以此来完成所想达到的共享配置目标。
微服务会从nacos读取的配置文件:
-
服务名\]-\[spring.profile.active\].yaml,环境配置
优先级:
服务名\]-\[环境\].yaml \> \[服务名\].yaml \> 本地配置
## Feign
Feign为声明式Http客户端,帮助实现http请求发送,其中已经集成了ribbn,不需担心负载均衡。
### 远程调用
客户端依赖:
```java