SpringCloud微服务框架(通俗易懂,一秒上手)

这篇具有很好参考价值的文章主要介绍了SpringCloud微服务框架(通俗易懂,一秒上手)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🎁🎁资源:https://pan.baidu.com/s/1zRmwSvSvoDkWh0-MynwERA&pwd=1234

(一)认识微服务

服务架构演变

单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署。

SpringCloud微服务框架(通俗易懂,一秒上手)

分布式架构:根据业务功能对系统进行拆分,每个业务模块作为独立项目开发,称为一个服务。

SpringCloud微服务框架(通俗易懂,一秒上手)
微服务

微服务是一种经过良好架构设计的分布式架构方案,微服务架构特征:
单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责,避免重复业务开发。
面向服务:微服务对外暴露业务接口
自治:团队独立、技术独立、数据独立、部署独立
隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题

SpringCloud微服务框架(通俗易懂,一秒上手)

单体架构特点:
简单方便,高度耦合,扩展性差,适合小型项目。例如:学生管理系统
分布式架构特点:
松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目,例如:京东、淘宝
微服务:一种良好的分布式架构方案。
优点:拆分粒度更小、服务更独立、耦合度更低·缺点:架构非常复杂,运维、监控、部署难度提高

微服务这种方案需要技术框架来落地,全球的互联网公司都在积极尝试自己的微服务落地技术。在国内最知名的就是SpringCloud和阿里巴巴的Dubbo。
SpringCloud微服务框架(通俗易懂,一秒上手)
企业需求:
SpringCloud微服务框架(通俗易懂,一秒上手)

SpringCloud

SpringCloud是目前国内使用最广泛的微服务框架。官网地址: https://spring.io/projects/spring-cloud。SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的开箱即用体验:

SpringCloud微服务框架(通俗易懂,一秒上手)
SpringCloud微服务框架(通俗易懂,一秒上手)

(二)微服务拆分案例

服务拆分

服务拆分注意事项
1.单一职责:不同微服务,不要重复开发相同业务
2.数据独立:不要访问其它微服务的数据库
3.面向服务:将自己的业务暴露为接口,供其它微服务调用

SpringCloud微服务框架(通俗易懂,一秒上手)

启动项目,在浏览器中输入http://localhost:8080/order/id,http://localhost:8081/user/id
两个项目都能够根据id查询出对应的数据。

服务间调用

SpringCloud微服务框架(通俗易懂,一秒上手)
注册RestTemplate

在order-service的OrderApplication中注册RestTemplate

@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(OrderApplication.class, args);
    }

    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

修改order-service中的OrderService的queryOrderById方法:

@Service
public class OrderService {
    @Resource
    private OrderMapper orderMapper;
    @Autowired
    private RestTemplate restTemplate;

    public Order queryOrderById(Long orderId) {
        // 1.查询订单
        Order order = orderMapper.findById(orderId);
       //查询用户
        String url="http://localhost:8081/user/"+order.getUserId();
        User user=restTemplate.getForObject(url,User.class);
        order.setUser(user);
        // 4.返回
        return order;
    }
}

提供者与消费者

服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)服务消费者:一次业务中,调用其它微服务的服务。(调用其它微服务提供的接口)

SpringCloud微服务框架(通俗易懂,一秒上手)

(三)eureka注册中心

远程调用的问题

SpringCloud微服务框架(通俗易懂,一秒上手)

eureka原理

SpringCloud微服务框架(通俗易懂,一秒上手)

在EEureka架构中,微服务角色有两类:
EurekaServer:服务端,注册中心
记录服务信息
心跳监控
EurekaClient:客户端
Provider:服务提供者,例如案例中的user-service注册自己的信息到EurekaServer
每隔30秒向EurekaServer发送心跳
consumer:服务消费者,例如案例中的 order-service根据服务名称从EurekaServer拉取服务列表基于服务列表做负载均衡,选中一个微服务后发起远程调用

搭建EurekaServer

SpringCloud微服务框架(通俗易懂,一秒上手)
搭建EurekaServer

1.创建项目,引入spring-cloud-starter-netflix-eureka-server的依赖

<dependency> 
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

2.编写启动类,添加@EnableEurekaServer注解

3.添加application.yml文件,编写下面的配置:

server:
  port: 10086
spring:
 application:
  name: eurekaserver
  eureka:
   client:
    service-url:  defaultZone: http://127.0.0.1:10086/eureka/

服务注册

注册user-service

在user-service项目引入spring-cloud-starter-netflix-eureka-client的依赖

<dependency>
  <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
   </dependency>

在application.yml文件,编写下面的配置:

spring:
  application:
     name: userservice
     eureka:
      client:
      service-url:
          defaultZone: http://127.0.0.1:10086/eureka/

order-service完成服务注册

order-service虽然是消费者,但与user-service一样都是eureka的client端,同样可以实现服务注册:
1.在order-service项目引入spring-cloud-starter-netflix-eureka-client的依赖

<dependency>
  <groupId>org.springframework.cloud</groupId>  
   <artifactId>spring-cloud-starter-netflix-eurekaclient</artifactId>
   </dependency>

2.在application.yml文件,编写下面的配置:

spring:
  application:
    name: orderservice
    eureka:
      client:
        service-url:
             defaultZone: http://127.0.0.1:10086/eureka/

1.服务注册
·引入eureka-client依赖
·在application. yml中配置eureka地址
2.无论是消费者还是提供者,引入eureka-client依赖知道eureka地址后,都可以完成服务注册

服务发现

在order-service完成服务拉取

服务拉取是基于服务名称获取服务列表,然后在对服务列表做负载均衡
1.修改OrderService的代码,修改访问的url路径,用服务名代替ip、端口:

String url = "http://userservice/user/" + order.getUserId();

2.在order-service项目的启动类OrderApplication中的RestTemplate添加负载均衡注解:

@Bean
@LoadBalanced
public RestTemplate restTemplate() {
    return new RestTemplate();
    }

SpringCloud微服务框架(通俗易懂,一秒上手)

(四)Ribbon负载均衡原理

负载均衡原理

SpringCloud微服务框架(通俗易懂,一秒上手)

负载均衡策略

Ribbon的负载均衡规则是一个叫做IRule的接口来定义的,每一个子接口都是一种规则:

SpringCloud微服务框架(通俗易懂,一秒上手)
SpringCloud微服务框架(通俗易懂,一秒上手)

通过定义IRule实现可以修改负载均衡规则,有两种方式:
1.代码方式:在order-service中的OrderApplication类中,定义一个新的IRule:

@Bean
public IRule randomRule(){
   return new RandomRule();
   }

2.配置文件方式:在order-service的application.yml文件中,添加新的配置也可以修改规则:

userservice:
ribbon:
  NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule# 负载均衡规则

懒加载

Ribbon默认是采用懒加载,即第一次访问时才会去创建LoadBalanceClient,请求时间会很长。
而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

ribbon:
  eager-load:
    enabled: true # 开启饥饿加载 
      clients: userservice # 指定对userservice这个服务饥饿加载

SpringCloud微服务框架(通俗易懂,一秒上手)

(五)nacos注册中心

认识和安装Nacos

Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eureka功能更加丰富,在国内受欢迎程度较高。
SpringCloud微服务框架(通俗易懂,一秒上手)

Nacos服务搭建
a.下载安装包
GitHub主页:https://github.com/alibaba/nacos
GitHub的Release下载页:https://github.com/alibaba/nacos/releases
b.解压
c.在bin目录下运行指令:startup.cmd -m standalone

Nacos快速入门

服务注册到Nacos

1.在cloud-demo父工程中添加spring-cloud-alilbaba的管理依赖:

<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>

2.注释掉order-service和user-service中原有的eureka依赖。
3.添加nacos的客户端依赖:

<!-- nacos客户端依赖 -->
<dependency>
   <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
      </dependency>

4.修改user-service&order-service中的application.yml文件,注释eureka地址,添加nacos地址:

spring:
  cloud:
    nacos:
       server-addr: localhost:8848 # nacos 服务端地址 

SpringCloud微服务框架(通俗易懂,一秒上手)

Nacos服务分级存储模型

SpringCloud微服务框架(通俗易懂,一秒上手)

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高
本地集群不可访问时,再去访问其它集群

服务集群属性

1.修改application.yml,添加如下内容:

spring:
cloud:
  nacos:   
    server-addr: localhost:8848 # nacos 服务端地址    
      discovery: 
          cluster-name: HZ # 配置集群名称,也就是机房位置,例如:HZ,杭州

2.在Nacos控制台可以看到集群变化:

SpringCloud微服务框架(通俗易懂,一秒上手)
SpringCloud微服务框架(通俗易懂,一秒上手)
根据集群负载均衡

1.修改order-service中的application.yml,设置集群为HZ:

spring:
 cloud:
    nacos:
       server-addr: localhost:8848 # nacos 服务端地址 
          discovery:  
              cluster-name: HZ # 配置集群名称,也就是机房位置

2.然后在order-service中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务

userservice:
 ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

SpringCloud微服务框架(通俗易懂,一秒上手)
根据权重负载均衡

实际部署中会出现这样的场景:
服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求
Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高

1.在Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮

SpringCloud微服务框架(通俗易懂,一秒上手)

2.将权重设置为0.1(0-1),测试可以发现8081被访问到的频率大大降低

SpringCloud微服务框架(通俗易懂,一秒上手)
SpringCloud微服务框架(通俗易懂,一秒上手)

Nacos环境隔离

SpringCloud微服务框架(通俗易懂,一秒上手)

1.在Nacos控制台可以创建namespace,用来隔离不同环境

SpringCloud微服务框架(通俗易懂,一秒上手)

2.然后填写一个新的命名空间信息:

SpringCloud微服务框架(通俗易懂,一秒上手)

3.保存后会在控制台看到这个命名空间的id:

SpringCloud微服务框架(通俗易懂,一秒上手)

4.修改order-service的application.yml,添加namespace

spring:
 datasource:
     url: jdbc:mysql://localhost:3306/heima?useSSL=false
         username: root
             password: 123
                driver-class-name: com.mysql.jdbc.Driver 
                  cloud:
                      nacos:
                         server-addr: localhost:8848 
                             discovery:
                        cluster-name: SH # 上海
                               namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID

5.重启order-service后,再来查看控制台:

SpringCloud微服务框架(通俗易懂,一秒上手)
SpringCloud微服务框架(通俗易懂,一秒上手)

6.此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错

SpringCloud微服务框架(通俗易懂,一秒上手)

后记
👉👉💕💕美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! 🌹🌹🌹
文章来源地址https://www.toymoban.com/news/detail-465101.html

到了这里,关于SpringCloud微服务框架(通俗易懂,一秒上手)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 最通俗易懂的讲解HTTPS的加密原理【多图、易懂】

    目录 前言 HTTPS加密原理概述 HTTP 为什么不安全 安全通信的四大原则 HTTPS 通信原理 对称加密:HTTPS 的最终加密形式 非对称加密:解决单向的对称密钥的传输问题 数字证书:解决公钥传输信任问题 证书一整个被掉包怎么办? 总结 其它 HTTPS 相关问题 什么是双向认证? 什么是

    2024年02月05日
    浏览(58)
  • 小白入门区块链(通俗易懂)

    区块链基础入门 什么是区块链 科技层面解释 数学,密码学,互联网,计算机编程 官方解释 区块链是一个分布式的共享账本和数据库,具有去中心化,不可篡改,全程留痕,可以追溯,集体维护,公开通明的特点分布式数字账簿,加密技术,不可篡改,通证(一种以数字形

    2024年02月08日
    浏览(43)
  • Java反射(通俗易懂)

    目录 1、反射介绍 2、反射API 2.1 获取类对应的字节码的对象(三种) 2.2 常用方法 3、反射的应用 3.1 创建 : 测试物料类 3.2 获取类对象 3.3 获取成员变量 3.4 通过字节码对象获取类的成员方法 3.5 通过字节码对象获取类的构造方法 4、创建对象         Reflection(反射) 是 Java

    2024年02月03日
    浏览(39)
  • 通俗易懂声学基础

    声音是由振动产生的,当物体振动时,会引起周围空气的波动,导致空气粒子间的距离发生疏密的变化,从而引发空气压强的变化,这种变化会传到人的耳膜,再传到人的大脑,人就听到声音了。 物理上,声音有四个基本特性:音色、音强、音高、音长。其中音色为音段特征

    2023年04月24日
    浏览(45)
  • C 递归 详解(通俗易懂)

    目录 一、定义         1.概述         2.条件         3.比较 二、 如何理解递归?         1.函数调用其他函数示例 :          2.函数调用函数自身示例 :          3.函数调用自身的底层操作 :                  ①在主调函数调用被调函数之前——              

    2024年02月05日
    浏览(37)
  • 通俗易懂的TextCNN

      了解TextCNN,看这一篇就够了。   我们之前提到CNN时,通常会认为属于CV领域,是用于解决计算机视觉方向问题的模型,但是在2014年,Yoon Kim针对CNN的输入层做了一些变形,提出了文本分类模型TextCNN。与传统图像的CNN网络相比,TextCNN 在网络结构上没有任何变化(甚至更

    2024年02月06日
    浏览(36)
  • Zookeeper选举机制(通俗易懂)

    SID: 服务器ID。用来唯一标识一台ZooKeeper集群中的机器,每台机器不能重复,和myid一致。 ZXID: 事务ID。ZXID是一个事务ID,用来标识一次服务器状态的变更。在某一时刻,集群中的每台机器的ZXID值不一定完全一致,这和 ZooKeeper服务器对于客户端“更新请求”的处理逻辑有关

    2024年01月22日
    浏览(41)
  • useVModel()的使用------通俗易懂

    用于父子组件共享数据, 1、父组件有个flag(Boolean)属性 2、将flag属性传递给子组件,要实现双向数据绑定 3、flag属性在子组件发生变化,父组件的flag属性一起改变 父组件app.vue 1、父组件有flag属性,使得flag和子组件uniInput双向绑定 2、使用v-model:flag进行双向绑定,v-model的默

    2024年01月15日
    浏览(36)
  • 通俗易懂:什么是拉链表

    拉链表是数据仓库中一种重要的模型,相信很多数据工作者都接触过,面试也是经常考察的点。 但是很多人第一次接触“拉链表”这个词,难免会产生疑惑:拉链表是什么? 按照度娘的解释:“拉链表是一种针对数据仓库设计中表存储数据的方式而定义的数据模型,它有点

    2024年02月08日
    浏览(37)
  • 简述马尔可夫链【通俗易懂】

    马尔可夫链(Markov Chain)可以说是机器学习和人工智能的基石,在强化学习、自然语言处理、金融领域、天气预测、语音识别方面都有着极其广泛的应用 The future is independent of the past given the present 未来独立于过去,只基于当下。 这句人生哲理的话也代表了马尔科夫链的思想:

    2023年04月08日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包