SpringCloud学习

认识微服务

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

优点:架构简单

部署成本低

缺点:耦合度高

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

优点:降低服务耦合度

有利于服务升级拓展

缺点:配置环境增多

考虑问题:服务拆分粒度

服务集群地址维护

服务之间的远程调用

服务健康状态感知

3.微服务:经过良好的架构设计的分布式架构方案

特征:单一职责:微服务拆分粒度更小,每一服务都对应唯一的业务能力,做到单一职责,避免重复业务开发

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

自治:团队独立、技术独立、数据独立、部署独立

4.微服务结构

请求路由负载或均衡

用户——>服务网关——————————>服务集群

SpringCloud

1.国内使用最广泛

集成了各种微服务功能的组件,并基于SpringCloud实现组件的自动装配

2.组件: 服务注册发现 统一配置管理

服务远程调用 统一网关路由

服务链路监控 流控、降级、保护

3.服务拆分及远程调用

注:不同微服务,不需要重复开发相同业务

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

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

4.远程调用方式分析:基于RestTemplate发起的http请求实现远程调用(说明url路径)

http请求做远程调用是与语言无关的调用,只要知道对方的ip、端 口、接口路径、请求参数即可

  • 注入RestTemplate

  • 在Service类中使用restTemplate.queryOrderById(url,返回值类型)方法

5.服务远程调用:提供者与消费者

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

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

一个服务可以既是提供者又是消费者

6.服务调用的问题:消费者如何获取提供者的地址信息

若有多个提供者,消费者如何选择

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

Eurka

1.Eurka注册中心(对应上述问题):

  • 提供者启动时向eurka注册自己的信息(心跳机制,每30秒一次)

eurka保存这些信息

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

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

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

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

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

2.搭建EurkaServer服务步骤:

  • 创建项目,引入eurka-server依赖

  • 编写启动类,添加注解@EnableEurkaServer

  • 添加文件application.yml,编写配置文件eurka地址(http://127.0.0.1:10086/eureka)

3.服务注册(将客户端注册进eurka)

将user-service服务注册到EurkaServer中

  • 引入依赖eurka-client

  • 在application.yml文件,编写配置eurka地址

4.在order-service完成服务拉取(服务发现)

服务拉取是基于服务名称获取服务列表,然后对服务列表做负载均衡

  • 修改order-service代码,修改访问url的路径,用服务名代替ip、端口

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

  • 在order-service项目的启动类OrderAppilation中的RestTemplate添加负载均衡注解

@LoadBalenced

服务发现步骤

  • 引入依赖eurka-client

  • 在application.yml文件,编写配置eurka地址

  • 在RestTemplate中添加@LoadBalanced注解

  • 给服务提供者的服务名称远程调用

负载均衡

1.负载均衡流程

  • order-service向Ribbon负载均衡发起请求

  • Ribbon拉取eurka-server

  • eurka-server返回服务列表给Ribbon

  • Ribbon轮询到端口号

2.负载均衡策略

修改负载均衡策略(两种)

  • 代码方式(全局):在order-service中的OrderApplication类中,定义一个新的IRule(规则接口)

@Bean

public IRule randomRule(){

return new RandomRule();

}

  • 配置文件方式(某个微服务):在order-service中的application.yml文件中,添加新的配置

userservice:

ribbon:

NFLoadBalanceRuleClassName: com.netflix.loadbalancer.RandomRule

3.饥饿加载

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

饥饿加载是在项目启动时创建,降低第一次访问的耗时,通过修改配置开启饥饿加载

ribbon:

eager-load:

enabled:ture #开启饥饿加载

clients: userservice #指定饥饿加载的服务名称(可有多个)

Nacos

1.认识Navos

是SpringCloud的一个组件,功能比Eurka更多

2.服务注册到Navos

  • 在cloud-demo父工程中添加spring-cloud-alibaba的管理依赖

  • 注释掉原有的eureka依赖

  • 添加nacos的客户端依赖

  • 修改application.yml文件,配置nacos地址(localhost:8848)

3.Nacos服务分级存储模型

  • 服务--->集群(按地域划分)----->实例

  • 服务跨集群调用问题

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

本地集群不可访问时,再去访问其他集群,会报警告

确定了可用的实例列表后,再采用随机负载均衡挑选实例

  • 服务集群属性

discovery

cluster-name:HZ #配置集群的位置eg:HZ杭州

4.根据集群负载均衡

  • 修改order-service中的application.yml文件,设置集群为HZ

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

  • 将user-service的权重都设置为1

5.根据权重负载均衡

通过改变权重可以控制访问频率,权重越大则访问频率越高

  • 在Nacos控制台设置实例权重值(0-1),选中实例后的编辑按钮

  • 将权重设置为0.1,测试发现访问频率降低

6.环境隔离-namespace

对服务做出隔离,每个namespace都有唯一id,不同namespace下的服务不可见

  • 在控制台创建namespace,填写新的命名空间信息,得到命名空间的id

  • 修改order-service中的application.yml文件,添加namespace(id)

Eurka和Nacos区别

1.共同点:

都支持服务注册 和服务拉取

都支持服务提供者心跳方式做健康检测

2.区别:

Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式

临时实例心跳不正常会被剔除,非临时实例 则不会被剔除

Nacos支持服务列表变更的消息推送模式,服务列表更新更及时

Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式:Eureka采用AP模式

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

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

相关文章

k8s record 20240710 监控

不是adaptor 是opetator 案例 监控有了,日志搜集呢? 一、kubelet 的小弟 kubelet — 负责维护容器的生命周期,节点和集群其他部分通信 cAdvisor 集成在 Kubernetes 的 kubelet 中,能够自动发现和监控集群中所有的容器。dockers…

创业者一定要做好时间管理

2024.7.5 最近接了两个项目,给我拖入了战争泥潭,耗费了大量的时间和精力。再加上今天不知道咋回事,有好多客户来咨询,就搞得人很疲惫,脑袋快炸了一样,感觉再这样下去会积怨成疾。现在能深刻的体会到&#x…

YOLOv5白皮书-第Y5周:yolo.py文件解读

本文为365天深度学习训练营 中的学习记录博客 原作者:K同学啊|接辅导、项目定制 本次训练是在前文《YOLOv5白皮书-第Y2周:训练自己的数据集》的基础上进行的。 前言 文件位置:./models/yolo.Py 这个文件是YOLOv5网络模型的搭建文件,如果你想改进YOLOv5&…

抖音短视频矩阵管理系统搭建全攻略:功能详解与实战应用

在短视频时代,抖音已经成为众多企业、网红、个人创作者不可或缺的传播平台。然而,如何高效管理多个抖音账号,实现内容、数据、粉丝的全方位掌控,成为了摆在大家面前的一道难题。本文将为大家深入解析抖音短视频矩阵管理系统的搭建…

Linux内核中的双向链表介绍

参考文章:https://www.cnblogs.com/liangliangge/p/11359196.html 相关结构体和api的介绍 1.1 struct list_head 用来创建双向循环链表的结构 1.2 INIT_LIST_HEAD 双向链表初始化,让一个链表节点首尾相连 1.3 list_add和list_add_tail 给链表增加一个结点 list_add :…

从0开始学习informer

目录 informer特点informer原理attention计算KL散度 backbone网络部分encoder输入输出部分embadding这里就不讲了 和transfomer一样EncoderStack decoder部分接下来就是最关键的结构 关于如何将输入经过注意力得到结果 结束,代码会放到下一篇讲 这里是原理 informer…

基于GIS矿产勘查靶区优选技术

定义: 找矿远景区(ore-finding prospect): 一般将中小比例尺(小于等于1:10万)成矿预测所圈定的找矿有利地段(preferable ore-finding area)成为找矿远景区 找矿靶区(ore-finding t…

车流量统计YOLOV8+DEEPSORT

车流量统计,YOLOV8NANODEEPSORT资源-CSDN文库 车流量统计YOLOV8DEEPSORT,目前支持PYTHON,C开发 PYTHON版本,需要YOLOV8,依赖PYTORCH C版本,只需要OPENCV

MYSQL的面试题

目录 一.数据库的约束类型 一.创建数据库、修改数据库名、修改表名,修改列名、修改某个属性的语法 三.索引的类型、优缺点以及使用场景 四.索引的常见的索引数据结构 五.数据库中常用的锁 六.事务的四大特性 七.什么是脏读?幻读?不可重…

技术周总结 2024.07.08~07.14(算法,Python,Java,Scala,PHP)

文章目录 一、07.13 周六1.0)算法题:字符串中的单词反转1.1) 问题01:可靠性计算中的MTTR MTTF MTBF 分别指什么?他们之间有什么联系?MTTR (Mean Time to Repair)MTTF (Mean Time to Failure)MTBF (Mean Time Between F…

vsCode 格式化代码及安装的插件

背景: 开发过程用的比较顺手的插件,首先看概览,然后分开发场景分别介绍。。。原生、vue2、vue3、react 效果展示: 不分前端开发框架,都在使用的几款插件: 插件官网链接:点击跳转官网 使用他能…

深入解析香橙派 AIpro开发板:功能、性能与应用场景全面测评

文章目录 引言香橙派AIpro开发板介绍到手第一感觉开发板正面开发板背面 性能性能概况性能体验 应用场景移植操作系统香橙派 AIpro开发板支持哪些操作系统?烧写操作系统到SD卡中启动开发板的步骤查看系统提供的事例程序体验——开发的简洁性 视频播放展示ffmpeg简介f…

C++ 语法习题(2)

第三讲 循环语句 1.偶数 编写一个程序&#xff0c;输出 1 到 100之间&#xff08;包括 1 和 100&#xff09;的全部偶数。 输入格式 无输入。 输出格式 输出全部偶数&#xff0c;每个偶数占一行。 输入样例 No input输出样例 2 4 6 ... 100 参考代码: #include <i…

Kafka接收消息

文章目录 Acknowledgment读消息指定分区批量消费消息拦截 // 采用监听得方式接收 Payload标记消息体内容. KafkaListener(topics {"test"},groupId "hello") public void onEvent(Payload String event,Header(value KafkaHeaders.RECEIVED_TOPIC) Stri…

服务重启时容器未自动启动

1、容器重启策略 通过设置容器的重启策略&#xff0c;‌可以决定在容器退出时Docker守护进程是否重启该容器。‌常见的重启策略包括&#xff1a;‌ no&#xff1a;‌不重启容器&#xff0c;‌默认策略。‌always&#xff1a;‌无论容器是如何退出的&#xff0c;‌总是重启容器…

2024 辽宁省大学数学建模竞赛A题 风切变影响及处置 完整思路 代码结果分享(仅供学习)

风切变对航空安全会构成危害。航空人员需了解相关知识&#xff0c;掌握相应技术&#xff0c;从而在遭遇上述天气时最大程度的规避风险&#xff0c;保证飞行安全。 风切变是指在大气中相对比较短的距离内或时间段内产生的风速大小、方向大幅度变化的现象。通常将发生在距离地面…

白话无人驾驶:1风暴来袭

----->更多内容&#xff0c;请移步“鲁班秘笈”&#xff01;&#xff01;<----- 根据最新的消息&#xff0c;在2024世界人工智能大会上&#xff0c;上海发放了首批完全无人驾驶智能网联汽车示范应用许可&#xff0c;即“完全无人载人车牌照”。首批获得许可的企业包括Au…

mysql 字段为json字符串,转对象然后赛选查询案例

sql 案例 SELECT JSON_UNQUOTE(JSON_EXTRACT(remark, $.deviceIp)) AS ip FROM intellect_identify_camera where JSON_UNQUOTE(JSON_EXTRACT(remark, $.deviceIp)) 127.0.0.1 ;

外国程序猿是什么水平?印度/越南/泰国/菲律宾

外国程序猿是什么水平? 中国互联网企业在海外扩张中,会遇到哪些困难和问题? 文化的差异本地法律法规的问题产品定位的问题人员招聘的问题等等…… 文化的差异和法律法规只能去适应,产品定位可以做调研,参考竞争对手和竞品。 人呢?这是最不可控的因素! 这里所说的人肯定…

mybatis语法进阶1

日志的使用 我们在使用MyBatis的时候, 其实MyBatis框架会打印一些必要的日志信息, 在开发阶段这些日志信息对我们分析问题,理解代码的执行是特别有帮助的; 包括项目上线之后,我们也可以收集项目的错误日志到文件里面去; 所以我们采用专门的日志系统来处理. 步骤 导入坐标拷贝…