SpringCould快速入门

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
简介: SpringCould快速入门

SpringCloud

1.远程调用

添加RestTemplate作为bena,调用RestTemplate.getForObject()方法,参数是url和类字节码

2.Eureka注册中心

作用:获取远程调用ip和端口,实现负载均衡,检查提供者是否健康

搭建流程:

搭建服务端
  1. 注册中心服务端:eureka-server,这必须是一个独立的微服务(模块)
  2. 引入依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  1. 编写启动类,需要@SpringBootApplication和@EnableEurekaServer注解
  2. 编写配置文件
server:
  port: 10086
spring:
  application:
    name: eureka-server # 模块名称
eureka:
  client:
    service-url: 
      defaultZone: http://127.0.0.1:10086/eureka # 默认地址
  1. 启动服务
将其他服务注册到eureka-server中
  1. 引入依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  1. 编写配置文件
spring:
  application:
    name: userservice
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:10086/eureka # eureka地址
  1. 启动多个实例
服务发现
  1. 给RestTemlate这个bean添加@LoadBalanced注解实现负载均衡
  2. 修改之前的RestTemplate.getForObject()方法,讲ip和端口改为消费者的名字即可

3.Ribbon负载均衡

SpringCloud底层利用Ribbon组件实现负载均衡

LoadBalancerInterceptor拦截请求从eureka更具服务id获取服务列表,然后利用负载均衡算法替换服务id

负载均衡策略

负载均衡的规则都定义在IRule接口中,而IRule有很多不同的实现类:

默认实现轮询

内置负载均衡规则类 规则描述
RoundRobinRule 简单轮询服务列表来选择服务器。它是Ribbon默认的负载均衡规则。
AvailabilityFilteringRule 对以下两种服务器进行忽略: (1)在默认情况下,这台服务器如果3次连接失败,这台服务器就会被设置为“短路”状态。短路状态将持续30秒,如果再次连接失败,短路的持续时间就会几何级地增加。 (2)并发数过高的服务器。如果一个服务器的并发连接数过高,配置了AvailabilityFilteringRule规则的客户端也会将其忽略。并发连接数的上限,可以由客户端的..ActiveConnectionsLimit属性进行配置。
WeightedResponseTimeRule 为每一个服务器赋予一个权重值。服务器响应时间越长,这个服务器的权重就越小。这个规则会随机选择服务器,这个权重值会影响服务器的选择。
ZoneAvoidanceRule 以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询
BestAvailableRule 忽略那些短路的服务器,并选择并发数较低的服务器。
RandomRule 随机选择一个可用的服务器。
RetryRule 重试机制的选择逻辑
自定义负载均衡策略
  1. 定义一个新的IRule
@Bean
public IRule randomRule(){
    return new RandomRule();
}
  1. 配置文件
userservice: # 给某个微服务配置负载均衡规则,这里是userservice服务
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 

一般用默认的负载均衡规则,不做修改。

饥饿加载

Ribbon默认实现懒加载,第一次访问才会创建按LoadBalanceClent,请求时间长,

而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

ribbon:
  eager-load:
    enabled: true
    clients: userservice

4.Nacos注册中心

安装自行解决

启动命令

startup.cmd -m standalone

注册服务

  1. 在父工程pom文件中的<dependencyManagement>中引入SpringCloudAlibaba的依赖:
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.6.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>
  1. 然后在user-service和order-service中的pom文件中引入nacos-discovery依赖:
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

注意:不要忘了注释掉eureka的依赖。

  1. 配置nacos地址
# 在微服务中配置nacos地址
spring:
  cloud:
    nacos:
      server-addr: localhost:8848
  1. 启动nacos

服务分级存储模型

一个服务可以有多个实例,nacos将一个机房的实例划分为一个集群

也就是说一个服务可以包含多个集群,如上海,杭州,北京,每个集群又存在多个实例,形成分级模型

微服务访问时要尽可能访问同集群实例,这样更快

配置集群
  1. 修改配置文件
spring:
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        cluster-name: HZ # 集群名称
  1. 同集群优先的负载均衡
# 默认的不能实现同集群优先,nacos提供了一个NacosRule的实现
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则 

权重配置在nacos中配置

环境隔离

nacos中可以有多个namespace

namespace中有group,service等

不同namespace互相隔离,服务不可见

  1. 在nacos中创建namespace
  2. 给服务添加namespace
spring:
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        cluster-name: HZ
        namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID
  1. 永久实例
spring:
  cloud:
    nacos:
      discovery:
        ephemeral: false # 设置为非临时实例

5.Nacos配置管理

统一配置管理

注意:项目的核心配置,需要热更新的配置才有放到nacos管理的必要。基本不会变更的一些配置还是保存在微服务本地比较好。

  1. 在配置列表添加配置即可
    ID : [服务名称]-[profile].[后缀名]
  2. 从微服务拉取配置
  1. 引入nacos-config客户端依赖
<!--nacos配置管理依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
  1. 添加bootstrap.yaml
# 会根据配置在扫描application之前读取到服务名称
spring:
  application:
    name: userservice # 服务名称
  profiles:
    active: dev #开发环境,这里是dev 
  cloud:
    nacos:
      server-addr: localhost:8848 # Nacos地址
      config:
        file-extension: yaml # 文件后缀名
  1. 读取nacos配置 @Value注入即可

配置热更新

方式一:在@Value注入的变量类上添加注解@RefreshScope

方式二:使用@ConfigurationProperties注解代替@Value注解

配置共享

在nacos中添加一个yaml文件

在服务中拉取

6.Feign远程调用

  1. 引入依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  1. 添加@EnableFeignClients开启Fegin功能
  2. 编写客户端

使用优化

配置连接池

最佳实践

继承

抽取feign-api模块

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
算法 C语言 C++
快速入门C++
快速入门C++
83 0
|
Web App开发 人工智能 数据可视化
RPA 快速入门|学习笔记
快速学习 RPA 快速入门
822 0
RPA 快速入门|学习笔记
|
Kubernetes Linux API
[没接触过kubevirt?]15分钟快速入门kubevirt
什么是kubevirt? kubevirt是一个容器方式运行虚拟机的项目。`kubevirt`是附加`kubernetes`集群上的,它是通过 `CustomResourceDefinition(CRD)`部署到`Kubernetes API`变成资源对象。使用方式类似创建`deploy、pod`......这些资源清单。
4386 0
[没接触过kubevirt?]15分钟快速入门kubevirt
|
7月前
|
存储 编译器 Linux
C++:快速入门篇
C++:快速入门篇
75 0
|
7月前
|
存储 算法 程序员
C++基础快速入门
C++基础快速入门
110 0
C++基础快速入门
|
7月前
|
缓存
SpringBootRestFul快速入门
SpringBootRestFul快速入门
42 0
|
Linux Windows
QMQTT快速入门
环境搭建 • 准备一台linux设备和一台windows设备虚拟机也是可以的; • 安装mosquitto ; • 准备QMQTT环境 - windows下;
172 0
|
存储 JavaScript 前端开发
ES6快速入门
ES6快速入门
90 0
|
SQL 负载均衡 NoSQL
DawnSql快速入门
DawnSql开源分布式数据库,快速入门
DawnSql快速入门
|
SQL 分布式计算 关系型数据库
MLSQL(Byzer)的快速入门
MLSQL(Byzer)的快速入门
MLSQL(Byzer)的快速入门