01认识微服务

一、微服务架构演变

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: orderservicecloud: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.rhkb.cn/news/164490.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis底层数据结构

总所周知&#xff0c;redis支持五种数据类型String、Hash、List、Set、ZSet。在支持这些复杂数据结构的同时&#xff0c;redis不仅需要保证读写的性能&#xff0c;还能提供各种微操作&#xff0c;比如直接修改Hash字典中的某个field的值&#xff0c;或者直接往ZSet中插入某个值…

vue3 列表页开发【选择展示列】功能

目录 背景描述&#xff1a; 开发流程&#xff1a; 详细开发流程&#xff1a; 总结&#xff1a; 背景描述&#xff1a; 这个功能是基于之前写的 封装列表页 的功能继续写的&#xff0c;加了一个选择展示列的功能&#xff0c;可以随时控制表格里展示那些列的数据&#xf…

Redis设计与实现笔记 - 数据结构篇

Redis设计与实现笔记 - 数据结构篇 相信在我们日常使用中&#xff0c;会经常跟 Redis 打交道。数据结构 String、Hash、List、Set 和 ZSet 都是常用的数据类型。对于使用场景&#xff0c;我们可以滔滔不绝地说很多&#xff0c;但是我们从来就没有关心过它们的底层实现&#xf…

RSTP详解:对比STP,到底改进了什么?

一、RSTP概述 IEEE 802.1W中定义的RSTP可以视为STP的改进版本&#xff0c;RSTP在许多方面对STP进行了优化&#xff0c;它的收敛速度更快&#xff0c;而且能够兼容STP。 二、RSTP对STP的改进 改进点1&#xff1a;端口角色 、 改进点2&#xff1a;端口状态 RSTP的状态规范缩…

信息系统项目管理师有什么用?

导语&#xff1a; 在当今数字化时代&#xff0c;信息系统项目管理师扮演着至关重要的角色。他们负责规划、组织和管理信息系统项目&#xff0c;确保项目按时、按质、按预算完成。本文将探讨信息系统项目管理师的重要性和作用&#xff0c;以及他们对组织和项目成功的贡献。 一、…

数据库系列之MySQL中Join语句优化问题

最近使用MySQL 8.0.25版本时候遇到一个SQL问题&#xff0c;两张表做等值Join操作执行很慢&#xff0c;当对Join连接字段添加索引优化后&#xff0c;执行效率反而变得更差&#xff0c;其中的原因值得分析。因此本文介绍下MySQL中常见的Join算法&#xff0c;并对比使用不同Join算…

百度文心一言 4.0 :如何申请百度文心一言 4.0

本心、输入输出、结果 文章目录 百度文心一言 4.0 &#xff1a;如何申请百度文心一言 4.0前言文心一言 4.0 ERNIE-Bot 4.0 &#xff1a;ERNIE-Bot 4.0 大模型深度测试体验报告如何申请千帆大模型试用百度文心一言 4.0 主要功能介绍配套发布的十余款AI原生应用插件、API 生态 百…

图论相关算法

一、迪杰斯特拉(Dijkstra)算法 迪杰斯特拉算法使用类似广度优先搜索的方法解决了带权图的单源最短路径问题。这是一个贪心算法。 1.核心思想 &#xff08;1&#xff09;每次选中一个点&#xff0c;这个点满足两个条件&#xff1a; 未被选过距离最短 &#xff08;2&#xf…

如何使用 MiniGPT-v2

MiniGPT-v2 是一个基于视觉语言模型&#xff08;LLM&#xff09;的多任务学习系统。它可以用于各种视觉语言任务&#xff0c;包括图像描述、图像识别、图像-文本对话等。 本文将介绍如何使用 MiniGPT-v2。 MiniGPT-v2 提供了一个简单的在线演示&#xff0c;可以用于测试模型。…

ENVI IDL:对于GEOTIFF结构体的说明

Tag标签-前言 其中最关键的只有两个标签Tag&#xff0c;一个是MODELPIXELSCALETAG&#xff0c;一个是MODELTIEPOINTTAG。 至于ModelTransformationTag我没用过不了解&#xff0c;但是应该是关于仿射变换相关的&#xff0c;用于将像素坐标与地理/投影坐标进行转换的矩阵。 对于…

k8s kubernetes 1.23.6 + flannel公网环境安装

准备环境&#xff0c;必须是同一个云服务厂商&#xff0c;如&#xff1a;华为&#xff0c;阿里、腾讯等&#xff0c;不要存在跨平台安装K8S&#xff0c;跨平台安装需要处理网络隧道才能实现所有节点在一个网络集群中&#xff0c;这里推荐使用同一家云服务厂商安装即可 这里使用…

黄金眼PAAS化数据服务DIFF测试工具的建设实践 | 京东云技术团队

一、背景介绍 黄金眼PAAS化数据服务是一系列实现相同指标服务协议的数据服务&#xff0c;各个服务间按照所生产指标的主题作划分&#xff0c;比如交易实时服务提供实时交易指标的查询&#xff0c;财务离线服务提供离线财务指标的查询。黄金眼PAAS化数据服务支撑了黄金眼APP、黄…

用Python获取网络数据

用Python获取网络数据 网络数据采集是 Python 语言非常擅长的领域&#xff0c;上节课我们讲到&#xff0c;实现网络数据采集的程序通常称之为网络爬虫或蜘蛛程序。即便是在大数据时代&#xff0c;数据对于中小企业来说仍然是硬伤和短板&#xff0c;有些数据需要通过开放或付费…

b树和b+树

二叉树和平衡二叉树 二叉树&#xff0c;每个节点支持两个分支的树结构&#xff0c;相比于单向链表&#xff0c;多了一个分支。 二叉查找树&#xff0c;在二叉树的基础上增加了一个规则&#xff0c;左子树的所有节点的值都小于它的根 节点&#xff0c;右子树的所有子节点都大于它…

了解活动聊天机器人如何革新活动行业

在如今快节奏的时代&#xff0c;活动策划和管理对于任何活动的成功变得至关重要。无论是会议、展览会还是企业聚会&#xff0c;组织者都努力为参与者创造难忘的体验&#xff0c;同时确保幕后的顺利执行。然而&#xff0c;由于有许多任务需要处理且资源有限&#xff0c;管理活动…

双指针——盛水最多的容器

一, 题目要求 给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线&#xff0c;使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明&#xff1a;你不能倾斜容…

Django小白开发指南

文章目录 HTTP协议socket实现一个web服务器WSGI实现一个web服务器WSGI实现支持多URL的web服务器WSGI实现图片显示的web服务器MVC && MTV1.MVC2.MTV3.总结 一、创建Django项目1.创建项目2.创建app3.第一次django 请求 二、模板1.配置settings.py2.模板语法3.继承模板 三…

LLM ReAct: 将推理和行为相结合的通用范式 学习记录

LLM ReAct 什么是ReAct? LLM ReAct 是一种将推理和行为相结合的通用范式,可以让大型语言模型(LLM)根据逻辑推理(Reason),构建完整系列行动(Act),从而达成期望目标。LLM ReAct 可以应用于多种语言和决策任务,例如问答、事实验证、交互式决策等,提高了 LLM 的效率、…

小程序搭建OA项目首页布局界面

首先让我们来学习以下Flex布局 一&#xff0c;Flex布局简介 布局的传统解决方案&#xff0c;基于盒状模型&#xff0c;依赖 display属性 position属性 float属性 Flex布局简介 Flex是Flexible Box的缩写&#xff0c;意为”弹性布局”&#xff0c;用来为盒状模型提供最大的…

centos 7.9 安装sshpass

1.作用 sshpass是一个用于非交互式SSH密码验证的实用程序。它可以用于自动输入密码以进行SSH登录&#xff0c;从而简化了自动化脚本和批处理作业中的SSH连接过程。 sshpass命令可以与ssh命令一起使用&#xff0c;通过在命令行中提供密码参数来执行远程命令。以下是一个示例命…