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.mzph.cn/news/113842.shtml

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

相关文章

修改ConsoleApplication17_2项目实现oss上线

首先创建号oss&#xff0c;上传文件&#xff0c;复制临时链接 木马内写 可以看到能成功上线但是有个问题就是占用cpu大小为9%左右&#xff0c;这里我用的是腾讯云oss实现的&#xff0c;用阿里云oss实现也是9%左右 我再次进行url的aes加密 还是百分之9左右&#xff0c; 这里…

npm publish发布到在线仓库时,提示:Scope not found

当npm publish发布时&#xff0c;控制台提示&#xff1a;Scope not found&#xff0c;具体错误信息如下&#xff1a; npm notice npm ERR! code E404 npm ERR! 404 Not Found - PUT https://registry.npmjs.org/xxx%2fxxx - Scope not found npm ERR! 404 npm ERR! 404 xxx/xx…

Spring源码解析——事务的回滚和提交

正文 上一篇文章讲解了获取事务&#xff0c;并且通过获取的connection设置只读、隔离级别等&#xff0c;这篇文章讲解剩下的事务的回滚和提交。最全面的Java面试网站 回滚处理 之前已经完成了目标方法运行前的事务准备工作&#xff0c;而这些准备工作最大的目的无非是对于程…

Rust 中的String与所有权机制

文章目录 一、string二、所有权2.1 所有权与作用域2.2 对所有权的操作2.2.1 转移2.2.3 拷贝2.2.3 传递 2.3 引用2.3.1 借用2.3.2 可变引用 一、string 之前学习过 Rust 只有几种基础的数据类型&#xff0c;但是没有常用的字符串也就是String&#xff0c;今天来学习一下 String…

C++初阶(五)类和对象

文章目录 一、C两大类型二、类的6个默认成员函数三、构造函数1、概念2、特性1、构造函数自动调用特性演示2、无参有参调用两种情况演示3、函数重载演示4、默认构造函数组成及演示5、内置类型成员不初始化的补丁演示 3、析构函数1、概念2、特性1、代码演示2、析构两种情况 4、构…

Django实现音乐网站 (21)

使用Python Django框架做一个音乐网站&#xff0c; 本篇音乐播放器功能完善及原有功能修改。 目录 播放列表修改 视图修改 删除、清空播放器 设置路由 视图处理 修改加载播放器脚本 模板修改 脚本设置 清空功能实现 删除列表音乐 播放列表无数据处理 视图修改 播放…

【算法】TOP101-二叉树篇(持续更新ing)

文章目录 1. JZ36 二叉搜索树与双向链表2. 100. 相同的树3. 572. 另一棵树的子树4. BM26 求二叉树的层序遍历5. BM33 二叉树的镜像6. BM40 重建二叉树7. 106. 从中序与后序遍历序列构造二叉树 1. JZ36 二叉搜索树与双向链表 JZ36 二叉搜索树与双向链表 解题思路: 由题目可知,…

【uniapp/uView】解决消息提示框悬浮在下拉框之上

需要实现这样的效果&#xff0c;即 toast 消息提示框在 popup 下拉框之上&#xff1a; 解决方法&#xff0c;把 <u-toast ref"uToast" /> 放在 u-popup 里面即可&#xff0c;这样就可以提升 toast 的优先级&#xff1a; <!-- 弹出下拉框 --><u-popu…

大规模语言LLaVA:多模态GPT-4智能助手,融合语言与视觉,满足用户复杂需求

大规模语言LLaVA&#xff1a;多模态GPT-4智能助手&#xff0c;融合语言与视觉&#xff0c;满足用户复杂需求 一个面向多模式GPT-4级别能力构建的助手。它结合了自然语言处理和计算机视觉&#xff0c;为用户提供了强大的多模式交互和理解。LLaVA旨在更深入地理解和处理语言和视…

web前端基础CSS------美化页面“footer”部分

一&#xff0c;实验代码 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>关于我们</title><style type"text/css">#footer{margin: 10px 0px;background: #f5f5f5;border: top 1px solid #eee ;}#f…

NET7下用WebSocket做简易聊天室

NET7下用WebSocket做简易聊天室 步骤&#xff1a; 建立NET7的MVC视图模型控制器项目创建websocket之间通信的JSON字符串对应的实体类一个房间用同一个Websocketwebsocket集合类&#xff0c;N个房间创建websocket中间件代码Program.cs中的核心代码&#xff0c;使用Websocket聊…

NRK3301语音芯片在智能窗帘上的应用

窗帘是人们日常生活中所经常使用的家居产品&#xff0c;传统的窗帘大多都需要手动拉动窗帘使用&#xff1b;存在着拉拽费劲&#xff0c;挂钩容易掉落等问题。随着数字化转型的升级&#xff0c;推进了窗帘市场的高质量发展。智能窗帘也“适时出现”出现了&#xff0c;一款带有语…

[python 刷题] 287 Find the Duplicate Number

[python 刷题] 287 Find the Duplicate Number 题目&#xff1a; Given an array of integers nums containing n 1 integers where each integer is in the range [1, n] inclusive. There is only one repeated number in nums, return this repeated number. You must sol…

实现Traefik工具Dashboard远程访问:搭建便捷的远程管理平台

文章目录 前言1. Docker 部署 Trfɪk2. 本地访问traefik测试3. Linux 安装cpolar4. 配置Traefik公网访问地址5. 公网远程访问Traefik6. 固定Traefik公网地址 前言 Trfɪk 是一个云原生的新型的 HTTP 反向代理、负载均衡软件&#xff0c;能轻易的部署微服务。它支持多种后端 (D…

wireshark数据包内容查找功能详解

wireshark提供通过数据包特征值查找具体数据包的功能&#xff0c;具体查找功能如下&#xff0c; &#xff08;1&#xff09;选择查找目标区域&#xff08;也就是在哪里去匹配特征值&#xff09; 如下图&#xff0c;【分组列表】区域查找指的是在最上方的数据包列表区域查找&…

【Pillow库的内涵】01/3 进行基本图像操作

一、说明 Pillow 具有被 Python 社区广泛使用的优势&#xff0c;并且它不像其他一些图像处理库那样具有陡峭的学习曲线。应用PIL库的Image对象&#xff0c;益处很多&#xff0c;首先它可以处理网上URL文件&#xff0c;其次&#xff0c;图片可以方面转化成int32、64或float类型&…

自然语言处理---huggingface平台使用指南

1 huggingface介绍 Huggingface总部位于纽约&#xff0c;是一家专注于自然语言处理、人工智能和分布式系统的创业公司。他们所提供的聊天机器人技术一直颇受欢迎&#xff0c;但更出名的是他们在NLP开源社区上的贡献。Huggingface一直致力于自然语言处理NLP技术的平民化(democr…

设计模式:组合模式(C#、JAVA、JavaScript、C++、Python、Go、PHP)

简介&#xff1a; 组合模式&#xff0c;它是一种用于处理树形结构、表示“部分-整体”层次结构的设计模式。它允许你将对象组合成树形结构&#xff0c;以表示部分和整体的关系。这种模式的主要目的是简化客户端代码&#xff0c;并使客户端以一致的方式处理单个对象和组合对象。…

Flyway Desktop updated

Flyway Desktop updated 为比较工件序列化和反序列化添加了额外的调试日志记录。 Flyway Desktop现在将记住以前用于创建项目和匹配克隆的位置。 新的脱机许可工作流现在已在Microsoft Windows上启用。 现在&#xff0c;在配置目标数据库列表时&#xff0c;环境ID是可见的。 现…

【虹科干货】Redis Enterprise vs ElastiCache——如何选择缓存解决方案?

使用Redis 或 Amazon ElastiCache 来作为缓存加速已经是业界主流的解决方案&#xff0c;二者各有什么优势&#xff1f;又有哪些区别呢&#xff1f; 文况速览&#xff1a; - Redis 是什么&#xff1f; - Redis Enterprise 是什么&#xff1f; - Amazon ElastiCache 是什么&…