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的对比
相关文章:

01认识微服务
一、微服务架构演变 1.单体架构 将所有的功能集中在一个项目开发,打成一个包部署。优点架构简单,部署成本低。缺点耦合度高,不利于大型项目的开发和维护 2.分布式架构 根据业务功能对系统进行拆分,每个业务模块作为独立的项目…...

智能电表上的模块发热正常吗?
智能电表是一种可以远程抄表、计费、控制和管理的电力计量设备,它可以实现智能化、信息化和网络化的电力用电管理。智能电表的主要组成部分包括电能计量模块、通信模块、控制模块和显示模块等。其中,通信模块和控制模块是智能电表的核心部件,…...

网络代理技术的广泛应用和安全保障
随着网络世界的日益发展,网络代理技术作为保障隐私和增强安全的重要工具,其在网络安全、爬虫开发和HTTP协议中的多面应用备受关注。下面我们来深入了解Socks5代理、IP代理以及它们的作用,探讨它们如何促进网络安全和数据获取。 Socks5代理和…...

EasyCVR视频汇聚平台显示有视频流但无法播放是什么原因?该如何解决?
视频汇聚/视频云存储/集中存储/视频监控管理平台EasyCVR能在复杂的网络环境中,将分散的各类视频资源进行统一汇聚、整合、集中管理,实现视频资源的鉴权管理、按需调阅、全网分发、云存储、智能分析等,视频智能分析平台EasyCVR融合性强、开放度…...

WuThreat身份安全云-TVD每日漏洞情报-2023-10-13
漏洞名称:libcue <2.2.1 越权访问漏洞 漏洞级别:高危 漏洞编号:CVE-2023-43641,CNNVD-202310-579 相关涉及:系统-alpine_edge-libcue-*-Up to-(excluding)-2.2.1-r0- 漏洞状态:未定义 参考链接:https://tvd.wuthreat.com/#/listDetail?TVD_IDTVD-2023-25092 漏洞名称:科大…...

中文编程工具开发语言开发的实际案例:触摸屏点餐软件应用场景实例
中文编程工具开发语言开发的实际案例:触摸屏点餐软件应用场景实例 软件特色: 1、功能实用,操作简单,不会电脑也会操作,软件免安装,已内置数据库。软件在关闭的时候,可以设置会员数据备份到U盘&…...

138.【JUC并发编程- 03】
JUC并发编程- 03 (六)、共享模型之无锁1.问题提出(1).为什么不安全?(2).安全实现_使用锁(3).安全实现_使用CAS 2.CAS与volatile(1).CAS_原理介绍(2).CAS_Debug分析(3).volatile(4).为什么无锁效率高(5).CAS的特点 3.原子整形(1).原子整数类型_ 自增自减(2).原子整数类型_乘除模…...

React Hooks批量更新问题
React 版本17.0.2 import React, { useState } from react;const Demo () > {const [count, setCount] useState(0);const [count1, setCount1] useState(0);const [count2, setCount2] useState(0);console.log(Demo);const add async () > {await 10;setCount(c…...

竞赛 深度学习YOLO抽烟行为检测 - python opencv
文章目录 1 前言1 课题背景2 实现效果3 Yolov5算法3.1 简介3.2 相关技术 4 数据集处理及实验5 部分核心代码6 最后 1 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 基于深度学习YOLO抽烟行为检测 该项目较为新颖,适合作为竞赛课…...

cAdvisor监控Docker容器做性能测试
cAdvisor监控Docker容器做性能测试 缘起 当前有个服务做技术选型,服务要求比较高的性能,要做性能测试。部署的环境是容器话部署,但申请新的容器流程较长,于是我打算在流程走完之前简单评估下性能,来确定技术选型是否…...

记一次EDU证书站
如果文章对你有帮助,欢迎关注、点赞、收藏一键三连支持以下哦! 想要一起交流学习的小伙伴可以加zkaq222(备注CSDN,不备注通不过哦)进入学习,共同学习进步 目录 目录 1.前言: 2.信息搜集 3.漏…...

React高频面试题100+题,这一篇就够了!
1 - 5 题详解传送门>>>>>>>>>>>> 1. 如何在代码中判断一个 React 组件是 class component 还是 function component? 2. useRef / ref / forwardsRef 的区别是什么? 3. useRef和useState区别? 4. useEffect 的…...

mysql MVC jsp实现表分页
mysql是轻量级数据库 在三层架构中实现简单的分页 在数据库sql编程中需要编写sql语句 SELECT * FROM sys.student limit 5,5; limit x,y x是开始节点,y是开始节点后的需要显示的长度。 在jdbc编程中需要给出x和y 一般是页数*页码,显示的长度。 代…...

【微信小程序】数字化会议OA系统之首页搭建(附源码)
🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《微信小程序开发实战》。🎯Ἲ…...

Leetcode——二维数组及滚动数组练习
118. 杨辉三角 class Solution { public:vector<vector<int>> generate(int numRows) {// 定义二维数组vector<vector<int>> num(numRows);for(int i0;i<numRows;i){//这里是给内层vector定义大小。默认是0,这里n是个数,不是值num[i].re…...

钢水包升降翻转液压系统比例阀放大器
钢水包升降翻转液压系统是一种用于控制钢水包升降和翻转的液压系统。该系统主要由液压泵、液压缸、控制阀和一些辅助元件组成。 钢水包升降翻转液压系统的液压泵将油从油箱中抽出,将油压力提高到一定值,然后通过控制阀将油分配到液压缸中。液压缸内的活…...

通达OA-通用版-V12,流程及表单自定义好用的类
通达OA-通用版-V12,流程及表单自定义好用的类 V1.0 V1.0 日期:2023年10月19日 新建类文件,将下面代码复制到文件中即可。 功能说明: 1、根据flow_id,可以获取流程表单相关的表名、及字段名。 2、根据run_id࿰…...

如何在vue中实现图片懒加载
1.什么是图片懒加载 概念当图片还未出现在浏览器的可视区,图片并不加载src所引入的图片资源。只有当图片出现在可视区时,才加载图片资源。 好处:当页面中需要许多图片进行展示。但是,在我们不可视区的图片我们可以进行图片懒加载…...

Mac 远程桌面软件
对于使用 Mac 计算机和笔记本电脑的企业来说,适用于 Mac 的远程桌面软件变得越来越重要,随着远程工作变得越来越普遍,IT 管理员和组织需要一种安全的方式来访问和修复问题、处理紧急任务以及监控远程工作站的状态,为了促进远距离协…...

EPLAN_005#宏边框、页宏、窗口宏/符号宏
一、宏边框 红边框不能用,变成了灰色 要在项目属性中更改位宏项目——才能使用宏边框功能 注意:创建宏边框时候要打开——显示隐藏元素 框选目标后,双击红边框的边——弹出红边框创建属性对话框——输入名称——更改变量ABC等 最后——自动…...

如何正确地使用ChatGPT(角色扮演+提示工程)
如何正确地使用ChatGPT 一、ChatGPT介绍二、准备工作2.1 获取ChatGPT环境2.2 确定使用ChatGPT的目标和需求 三、重要因素3.1 角色赋予3.2 提示工程 四、正确案例 一、ChatGPT介绍 可以查阅ChatGPT快速入门 二、准备工作 2.1 获取ChatGPT环境 国外的有OpenAI和微软NewBing等…...

MySQL服务安装与登录
(1)以管理员身份启动命令提示符: (2)定位到安装目录的bin目录下(根据自己的安装路径进行调整即可)。先输入“d:”,定位到d盘,输入cd空格文件路径(直接复制粘贴…...

论文阅读之《Kindling the Darkness: A Practical Low-light Image Enhancer》
目录 摘要 介绍 已有方法回顾 普通方法 基于亮度的方法 基于深度学习的方法 基于图像去噪的方法 提出的方法 2.1 Layer Decomposition Net 2.2 Reflectance Restoration Net 2.3 Illumination Adjustment Net 实验结果 总结 Kindling the Darkness: A Practical L…...

性能测试基础知识及性能指标
前言:最近公司接了个项目,领导开会突然来了句,让我出一份性能测试方案,后面性能测试工作交给我!我心里想之前面试没要求会这个啊(最少得加钱才能做吧~,没办法既然下达了指令,那就只能…...

ArcGIS笔记10_如何创建渔网?
本文目录 前言Step 1 确定渔网的精度单位Step 2 有底图时创建渔网的操作 前言 ArcGIS中的渔网是一个很好用的工具,它可以创建出规规整整的小格子,每个小格子都对应一个标注点,可以将原本散乱的数据规整化,如下图: Ste…...

Jmeter安装(快速入门)
大家好我是苏麟今天简单聊一下Jmeter . Jmeter Jmeter官网 : Apache JMeter - Download Apache JMeter 安装Jmeter Jmeter依赖于JDK,所以必须确保当前计算机上已经安装了JDK,并且配置了环境变量。 下载 : 官网下载 : 网盘自取 : 链接:…...

一个react前端项目中的配置文件作用解析
前端框架中用到的配置文件 .editorconfig, .gitignore, .npmrc, .prettierignore, .prettierrc, .umirc.local.ts, .umirc.ts, package-lock.json, package.json, README.md, tsconfig.json, typings.d.ts, webpack.config.js.editorconfig:用于定义代码编辑器的配…...

MAC 配置 Maven
Maven 是一个流行的 Java 项目管理和构建工具,它可以帮助我们管理项目依赖、构建和发布等过程。本文将指导您在 MAC 上配置 Maven 的详细步骤。 1、下载 Maven 首先,从 Maven 官方网站下载最新版本的 Maven 安装包。下载完成后,将其解压到您…...

vue3.0 + element plus upload图片 上传
直接上图吧: 记录一下,方便后续遇到啥问题...

Leetcode 18:四数之和
给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复)。 解题思路:…...