SpringCloud 组件

1. SpringCloud Alibaba-Nacos[作为注册中心]

1. 下载 nacos-serve

Nacos 文档地址: https://nacos.io/zh-cn/docs/quick-start.html

2. 启动 nacos-server

  • 双击 bin 中的 startup.cmd 文件
  • 访问 http://localhost:8848/nacos/
  • 使用默认的 nacos/nacos 进行登录

3. 将微服务注册到 nacos 中

1. 首先,修改 pom.xml 文件,引入 Nacos

<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

2. 在应用的 /src/main/resources/application.properties 配置文 件中配置 Nacos Server 地

spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

3.使用@EnableDiscoveryClient 开启服务注册发现功能

@SpringBootApplication
@EnableDiscoveryClient
public class ProviderApplication {
	public static void main(String[] args) {
		SpringApplication.run(Application.class, args);
	}
}

4.启动应用,观察 nacos 服务列表是否已经注册上服务

注意:每一个应用都应该有名字,这样才能注册上去。修改 application.properties 文件

spring.application.name=service-provider
server.port=8000

5.注册更多的服务上去,测试使用 feign 远程调

Nacos 使用三步
  1、导包 nacos-discovery
  2、写配置,指定 nacos 地址,指定应用的名字
  3、开启服务注册发现功能@EnableDiscoveryClient
Feign 使用三步
  1、导包 openfeign
  2、开启@EnableFeignClients 功能
  3、编写接口,进行远程调用

6.更多配置

https://github.com/alibaba/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/na cos-example/nacos-discovery-example/readme-zh.md#more

2.SpringCloud Alibaba-Nacos[作为配置中心]

1.pom.xml 引入 Nacos Config Sta

<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

2.在应用的 /src/main/resources/bootstrap.properties 配置文件中配置 Nacos Config 元数据

## 主要配置应用名和配置中心地址
spring.application.name=nacos-config-example
spring.cloud.nacos.config.server-addr=127.0.0.1:8848

3.在 nacos 中添加配置

在 nacos 中创建一个 应用名.properties 配置文件并编写配置

Nacos Config 数据结构
Nacos Config 主要通过 dataId 和 group 来唯一确定一条配置。
Nacos Client 从 Nacos Server 端获取数据时,调用的是此接口 ConfigService.getConfig(String dataId, String group, long timeoutMs)

Spring Cloud 应用获取数据
dataID:
在 Nacos Config Starter 中,dataId 的拼接格式如下
1、${prefix} - ${spring.profiles.active} . ${file-extension} prefix 默认为 spring.application.name的值,也可以通过配置项spring.cloud.nacos.config.prefix 来配置。
2、spring.profiles.active 即为当前环境对应的 profile
注意,当 activeprofile 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 p r e f i x . {prefix}. prefix.{file-extension}
file-extension 为配置内容的数据格式,可以通过配置项
spring.cloud.nacos.config.file-extension 来配置。 目前只支持 properties 类型。
Group:
Group 默认为 DEFAULT_GROUP,可以通过 spring.cloud.nacos.config.group 配

4.在应用中使用@Value 和@RefreshScop

完成上述两步后,应用会从 Nacos Config 中获取相应的配置,并添加在 Spring Environment的 PropertySources 中 。 这 里 我们 使 用 @Value 注 解 来 将 对 应 的 配 置 注 入 到 SampleController 的 userName 和 age 字段,并添加 @RefreshScope

@RefreshScope
class SampleController {

	@Value("${user.name}")
	String userName;
	
	@Value("${user.age}")
	int age;
	
}

3.SpringCloud Alibaba-Sentine

1.熔断降级限流

什么是熔断
  A 服务调用 B 服务的某个功能,由于网络不稳定问题,或者 B 服务卡机,导致功能时间超长。如果这样子的次数太多。我们就可以直接将 B 断路了(A 不再请求 B 接口),凡是 调用 B 的直接返回降级数据,不必等待 B的超长执行。 这样 B 的故障问题,就不会级联影 响到 A。

什么是降级
  整个网站处于流量高峰期,服务器压力剧增,根据当前业务情况及流量,对一些服务和页面进行有策略的降级[停止服务,所有的调用直接返回降级数据]。以此缓解服务器资源的 的压力,以保证核心业务的正常运行,同时也保持了客户和大部分客户的得到正确的相应。

异同:
  相同点:
    1、为了保证集群大部分服务的可用性和可靠性,防止崩溃,牺牲小我
    2、用户最终都是体验到某个功能不可用
  不同点:
    1、熔断是被调用方故障,触发的系统主动规则
    2、降级是基于全局考虑,停止一些正常服务,释放资源

什么是限流
  对打入服务的请求流量进行控制,使服务能够承担不超过自己能力的流量压力

2.Sentinel 简介

官方文档:https://github.com/alibaba/Sentinel/wiki/%E4%BB%8B%E7%BB%8D
项目地址:https://github.com/alibaba/Sentinel

3.Hystrix 与 Sentinel 比

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值