01认识微服务

news2025/7/21 0:53:30

一、微服务架构演变

1.单体架构

将所有的功能集中在一个项目开发,打成一个包部署。优点架构简单,部署成本低。缺点耦合度高,不利于大型项目的开发和维护

2.分布式架构

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

优点耦合度低,利于服务升级扩展

 

问题:

  • 服务拆分粒度如何
  • 服务集群地址如何维护
  • 服务之间如何实现远程调用
  • 服务健康状态如何感知

使用微服务

3.微服务:一种分布式架构方案

①单一职责:每一个服务对应唯一的业务能力,做到单一职责,避免重复业务开发。

②面向服务:微服务对外暴露接口

③自治:团队独立,技术独立,数据独立,部署独立。  

④隔离性强:服务调用做好隔离,容错,降级,避免出现级联问题

 架构复杂,运维,监控,部署,难度高。

二、微服务结构

1.微服务架构

SpringCloud和阿里巴巴的Dubbo

2.微服务技术对比

 3.企业需求

 三、SpringCloud

1. SpringCloud介绍

①SpringCloud是使用最广泛的微服务框架

②SpringCloud集成各种微服务组件,基于SpringBoot实现组件自动装配,提供良好的开箱即用。

 2.SpringCloud与SpringBoot版本兼容关系

 四、服务拆分及远程调用

1.服务拆分的注意事项

①不同微服务,不要重复开发相同业务

②微服务数据独立,不要访问其他微服务的数据库

③微服务将自己的业务暴露为接口,供其他微服务调用

2.远程服务调用

基于RestTemplate发起http请求远程调用

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

User user = restTemplate.getForObject(url, User.class);

3.提供者与消费者

提供者:暴露接口给其他微服务

消费者:调用其他微服务的接口

一个服务可以同时提供者和消费者

五、Eureka注册中心

1.服务调用出现的问题

地址为硬编码会出现问题。

  • 消费者如何获取提供者的地址信息?

服务提供者启动时向eureka注册自己的信息

eureka保存这些信息

消费者根据服务名称向eureka拉取提供者信息

  • 多个提供者,消费者如何选择?

服务消费者利用负载均衡算法,从服务列表中挑选一个

  • 消费者如何得知提供者的健康状态?

服务提供者会每隔30秒向EurekaServer发送心跳请求,报告健康状态

eureka会更新记录服务列表信息,心跳不正常会被剔除

消费者就可以拉取到最新的信息

2.Eureka的作用

角色分为:

服务端eureka-server:注册中心,记录和管理这些微服务,心跳监控

客户端eureka-client:微服务的消费者和提供者

  • 每一次客户端启动,服务端eureka-server会注册服务信息,记录名称和ip端口。
  • 当客户端的消费者要调用提供者接口时,会从服务端拉取提供者的信息
  • 服务消费者采用负载均衡的方式选择ip端口,远程调用发起请求

 

3.Eureka总结

在Eureka架构中,微服务角色有两类:

①EurekaServer服务端,注册中心

记录服务信息

心跳监控

②EurekaClient客户端

provider:服务提供者

注册自己的信息到EurekaServer

每隔30秒向EurekaServer发送心跳

consumer:服务消费者

根据服务名称从EurekaServer拉取服务列表

基于服务列表做负载均衡,选中一个微服务后发起远程调用

4.服务端:搭建EurekaServer服务步骤

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

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

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

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

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

server:
  port: 10086 # 服务端口
spring:
  application:
    name: eurekaserver # eureka的服务名称
eureka:
  client:
    service-url:  # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

④访问http://localhost:10086/

 5.客户端:注册user-service,order-service

①引入eureka-client依赖

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

②在application.yml中配置eureka地址

spring:
  application:
    name: userservice
eureka:
  client:
    service-url:  # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

6.服务发现order-service服务拉取

①消费者order-service配置类添加@LoadBalanced注解

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

②修改url路径,服务名代替ip端口

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

改成

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

7.总结

 六、Ribbon负载均衡

1.负载均衡的流程

①当客户端发起请求时被Ribbon负载均衡拦截。

Ribbon负载均衡从eureka-server拉取服务

③eureka-server返回服务列表

④Ribbon负载均衡随机轮询,发起请求

2.负载均衡的详解

①当客户端发起请求时被LoadBalancerInterceptor负载均衡拦截器拦截

②RibbonLoadBanlancerClient获取url中的服务iduserservice

③DynamicServerListLoadBalancer从eureka-server拉取服务,返回服务列表。通过IRule基于规则选择出ip端口

④把选出的某个服务传给RibbonLoadBanlancerClient,修改url,发起请求

 

 

3.负载均衡策略

Ribbon的负载均衡规则是IRule接口定义的。

 ZoneAvoidanceRule(默认):以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询

4.饥饿加载

Ribbon默认是懒加载,第一次访问才会创建LoadBalanceClient,请求时间长。

饥饿加载是项目启动创建,降低第一次的访问耗时。

ribbon:
  eager-load:
    enabled: true #开启饥饿加载
    clients: userservice

5.总结

 七、Nacos注册中心

1.服务注册到nacos

①在bin目录运行指令startup.cmd -m standalone,启动nacos

②在父工程添加管理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>

③在子工程添加nacos客户端依赖

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

④application.yml文件,添加nacos地址:

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

2.Nacos服务分级存储模型

提供给用户功能的user-service,以机房划分集群。

 

 

3.服务跨集群调用问题

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高。

本地集群不可访问,再去访问其他集群。

4.服务集群的属性

①修改application.yml

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        cluster-name: HZ # 集群名称

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

 5.集群总结

 6.优先选择本地集群

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

userservice: # 配置的微服务的名称
  ribbon:
    NFLoribbon:adBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则 
  • 优先选择同集群服务实例列表
  • 本地集群找不到提供者,才去其它集群寻找,并且会报警告
  • 确定了可用实例列表后,再采用随机负载均衡挑选实例

7.根据权重负载均衡

服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,希望性能好的机器承担更多的用户请求

Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高

步骤

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

②将权重设置为0.1,测试可以发现8081被访问到的频率大大降低 

总结:

  • Nacos控制台可以设置实例的权重值,0~1之间
  • 同集群内的多个实例,权重越高被访问的频率越高
  • 权重设置为0则完全不会被访问

8.环境隔离-namespace

Nacos服务存储和数据存储是namespace最外层隔离

 

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

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

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

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

spring:
  application:
    name: orderservice
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        cluster-name: HZ # 集群名称
        namespace: b5300f3f-0600-489e-a64a-b35ecbea970c #命名空间

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

⑥order-service,因为namespace不同,会导致找不到userservice,控制台会报错 

总结:

  • 每个namespace都有唯一id
  • 服务设置namespace时要写id而不是名称
  • 不同namespace下的服务互相不可见

9.nacos注册中心的细节

 

临时实例和非临时实例 

临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会 

10.Nacos和eureka的对比

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1102400.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaScript基础知识14——运算符:逻辑运算符,运算符优先级

哈喽&#xff0c;大家好&#xff0c;我是雷工&#xff01; 一、逻辑运算符 1、概念&#xff1a;在程序中用来连接多个比较条件时候使用的符号。 2、应用场景&#xff1a;在程序中用来连接多个比较条件时候使用。 3、逻辑运算符符号&#xff1a; 4、代码演示逻辑运算符的使用…

opensl学习——base16编码解码、base64编码解码、ASCII码表、扩展ASCII码

文章目录 ASCII表概述base家族简单说明 Hex(十六进制)编码、Base32编码、Base64编码、base256编码base16编码与解码base64编码概述转换过程不足 3 字节处理方法例子一,不足3字节&#xff0c;只有一个字节例子二,不足3字节&#xff0c;只有两个字节 base64示例代码1代码分析 acl…

基于AT89C51流水花样灯proteus仿真设计

一、仿真原理图&#xff1a; 二、仿真效果图&#xff1a; 三、仿真工程&#xff1a; c51单片机流水灯花样灯proteus仿真设计资源-CSDN文库

【前端学习】—给定数组求最大值(七)

【前端学习】—给定数组求最大值(七) 一、给定数组求最大值场景 二、怎样对给定的数组求最大值 Math.max数组的reduce函数数组的sort函数//Math.maxconst arr=[1,2,3,4]; const res=Math.max(

Linux UWB Stack实现——MCPS通道访问

在前文MCPS相关介绍的基础之上&#xff0c;对UWB协议栈中实现访问控制相关数据结构进行介绍&#xff0c;并介绍了其载体struct mcps802154_local&#xff0c;保存了MCPS的私有数据。 1.关于MCPS802154_CA 关于IEEE 802.15.4 MAC公共部分子层&#xff08;MAC common part subla…

【k8s总结】

资源下载&#xff1a;http://www.ziyuanwang.online/912.html Kubernetes(K8s) 一、Openstack&VM 1、认识虚拟化 1.1、什么是虚拟化 在计算机中&#xff0c;虚拟化&#xff08;英语&#xff1a;Virtualization&#xff09;是一种资源管理技术&#xff0c;是将计算机的…

GB/T 41510-2022 起重机械安全评估规范 通用要求 摘要

在线预览|GB/T 41510-2022http://c.gb688.cn/bzgk/gb/showGb?typeonline&hcno696806EC48F4105CEF7479EB32C80C9E 知识点&#xff1a; 安全等级定义&#xff0c;设计寿命&#xff0c;剩余寿命&#xff0c;使用寿命。 标准附录有应力的具体解算演示。

剧本杀公众号系统开发在线组队开团多玩法

一款针对剧本杀行业开发的公众号系统&#xff0c;配置到公众号里即可轻松简单运营起来。 核心功能&#xff1a; 1、在线开本是特色&#xff0c;直接线上玩起。 2、支持多商户入驻哦、后台会同步进行控制。 3、前台剧本的控制。 4、多玩法模式&#xff0c;满足剧本杀爱好者…

AR智能眼镜主板设计方案_AR眼镜PCB板设计

AR智能眼镜是一种采用先进技术的创新产品&#xff0c;具备强大的功能和性能。它采用了MTK8788八核 12nm低功耗硬件平台&#xff0c;搭载IMG GE830063OMhz或以上的GPU&#xff0c;并运行Android 11.0或以上的操作系统。该眼镜支持光波导1080P显示和LVDS接口自由曲面显示&#xf…

SW2303 Type-C 口/Type-A 口快充协议芯片 支持多种快充协议

SW2303 是一款高集成度的 Type-C 口/Type-A 口快充协议芯片&#xff0c;支持 PD、QC、FCP、高低压 SCP、AFC、SFCP 以及 PE 等主流快充协议&#xff0c;支持光反馈和 FB 反馈两种工作模式SW2303 集成了 CV/CC 控制环路&#xff0c;Type-C 接口逻辑&#xff0c;快充协议控制器&a…

独家分析:安卓“Janus”漏洞的产生原理及利用过程

*本文中涉及到的相关漏洞已报送厂商并得到修复&#xff0c;本文仅限技术研究与讨论&#xff0c;严禁用于非法用途&#xff0c;否则产生的一切后果自行承担。 近日&#xff0c;Google在12月发布的安卓系统安全公告中披露了一个名为“Janus”安卓漏洞&#xff08;漏洞编号&#…

红黑树与AVL树

文章目录 前言一、AVL是什么&#xff1f;二、AVL的插入与删除插入删除 三、红黑树是什么四、红黑树的插入与删除插入删除 五、红黑树与AVL树的对比 前言 红黑树与AVL树是数据结构中避不开的话题&#xff0c;也是面试中常问的问题。今天就把他们总结在一起。 一、AVL是什么&am…

基于ChatGPT的智能客服助手

导读1.应用场景与系统框图2.搭建基于ChatGPT的智能客服助手 2.1 ChatGPT原理2.2 Prompt设计3.智能客服系统二期优化之用户问题分类 3.1 Bert简介3.2 用户问题分类网络训练数据3.3训练分类模型4.智能客服系统三期优化之商详和质检项相关知识筛选5.总结6.参考文献 导读 传统客服…

Web自动化测试:测试用例断言!

运行测试用例时&#xff0c;需要判断用例是否执行成功&#xff0c;此时需要有一个我们期望的结果来进行验证。这里unittest中&#xff0c;如果一个case执行的过程中报错&#xff0c;或者我们判断结果不符合期望&#xff0c;就会判定此条用例执行失败&#xff0c;判断的条件主要…

leetcode3. 无重复字符的最长子串 [滑动窗口]

题目 给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc"&#xff0c;所以其长度为 3。示例 2: 输入: s "bbbbb" 输出: 1 解释:…

蓝桥杯每日一题2023.10.17

迷宫 - 蓝桥云课 (lanqiao.cn) 题目描述 样例&#xff1a; 01010101001011001001010110010110100100001000101010 00001000100000101010010000100000001001100110100101 01111011010010001000001101001011100011000000010000 0100000000101010001101000010100000101010101100…

视频批量添加背景图片教程,详细步骤一看就会

你是否曾经需要为多个视频添加相同的背景图片&#xff1f;或者你需要为一些视频添加自定义的背景来增强视觉效果&#xff1f;如果你遇到了这样的问题&#xff0c;那么有一个软件可以帮助你解决&#xff0c;那就是固乔剪辑助手。下面是一个简单的步骤指南&#xff0c;教你如何使…

如何快速定位BUG?BUG定位技巧及测试人员定位的N板斧

很多测试人员可能会说&#xff0c;我的职责就是找到bug&#xff0c;至于找原因并修复&#xff0c;那是开发的事情&#xff0c;关我什么事&#xff1f; 好&#xff0c;我的回答是&#xff0c;如果您只想做一个测试人员最基本最本分的事情&#xff0c;那么可以这么想。但是&#…

基于边缘网关构建水污染监测治理方案

绿水青山就是金山银山&#xff0c;生态环境才是人类最宝贵的财富。但是在日常生活生产中&#xff0c;总是免不了各种污水的生产、排放。针对生产生活与环境保护的均衡&#xff0c;可以借助边缘网关打造环境污水监测治理体系&#xff0c;保障生活与环境的可持续性均衡发展。 水污…

数据结构-----红黑树(全)

目录 前言 一、什么是红黑树&#xff1f; 二、为什么需要红黑树&#xff1f;&#xff08;与AVL树对比&#xff09; 三、红黑树的特性 四、红黑树的储存结构 五、节点旋转操作 左旋&#xff08;Left Rotation&#xff09; 右旋&#xff08;Right Rotation&#xff09; 六、…