首页 > 其他分享 >SpringCloud学习

SpringCloud学习

时间:2024-07-08 18:26:19浏览次数:13  
标签:负载 调用 服务 service SpringCloud 学习 eurka order

认识微服务

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 #指定饥饿加载的服务名称(可有多个)

标签:负载,调用,服务,service,SpringCloud,学习,eurka,order
From: https://blog.csdn.net/weixin_68441705/article/details/140276054

相关文章

  • 深度学习中的正则化技术 - 引言篇
    序言在深度学习中,正则化技术是防止模型过拟合、提升泛化能力的关键策略。随着模型复杂度的增加,过拟合风险也随之上升。正则化通过引入额外约束或信息,调整模型训练过程,旨在简化模型结构,使其学习到数据中的本质特征而非噪声,从而在保证训练效果的同时,提高模型对新数据的适应能......
  • ts学习笔记
    1、ts简介以js为基础构建的语言,是js的超集,拓展了js并添加了类型,可以在任何支持js的平台执行。但是ts不能被js解析器直接执行,需要编译为js才能执行。  ts新加了类型,像枚举、any、接口、字面量等   Ts支持ES的新特性   Ts可以被编译成任意版本的js,方便兼容2、ts环......
  • 无问社区——让网安学习更简单的平台
    前言我们深知学习网络安全的不易,为此我们团队打造了一款免费学习网络安全技术的平台--无问社区(wwlib.cn),让学习技术更加简单。平台目前虽仅有千篇文章,但面向学习的深度广,有适合萌新学习的知识介绍和工具总结,有适合网络安全爱好者的漏洞分析和漏洞实战教学,有适合安全服务人员的......
  • 学习canvas(一些常用api)
    当然,以下是这些常用CanvasAPI的总结,按照Markdown格式编写:常用CanvasAPI总结1.获取绘图上下文constcanvas=document.getElementById('myCanvas');constctx=canvas.getContext('2d');//或'webgl'2.绘制矩形ctx.fillStyle='blue';ctx.fillRect(1......
  • 学习canvas(初步入门)
    canvas一些基础api用法首先需要创建一个canvas<canvasid="canvas"></canvas>然后获取到这个元素,可以用Document.getElementById('canvas')constcanvas=document.getElementById("canvas");然后拿到他的上下文对象ctx(然后可以在上下文的位置绘制内容)constcan......
  • 集成学习在回归分析中的新策略与性能优化
    1.引言        回归分析,作为预测科学的核心支柱,长期以来一直是量化关系、趋势预测及未来情境模拟不可或缺的方法论。它在诸如金融市场预测、医疗健康评估、环境变化分析等诸多关键领域扮演着至关重要的角色。尽管传统的单一模型,如线性回归、多项式回归等,为理解和解析......
  • Mojo 编程语言(AI开发者的新宠儿)介绍及安装学习
    关注我,持续分享逻辑思维&管理思维&面试题;可提供大厂面试辅导、及定制化求职/在职/管理/架构辅导;推荐专栏《10天学会使用asp.net编程AI大模型》,目前已完成所有内容。一顿烧烤不到的费用,让人能紧跟时代的浪潮。从普通网站,到公众号、小程序,再到AI大模型网站。干货满满。学成后可......
  • 从Java开发者到.NET Core初级工程师学习路线:C#语言基础
    1.C#语言基础1.1C#语法概览欢迎来到C#的世界!对于刚从Java转过来的开发者来说,你会发现C#和Java有很多相似之处,但C#也有其独特的魅力和强大之处。让我们一起来探索C#的基本语法,并比较一下与Java的异同。程序结构C#程序的基本结构与Java非常相似。这里是一个简单的C#程序:using......
  • Markdown学习
    Markdown学习标题对应井号#+空格+标题名多少个井号就是多少级标题字体helloworld斜体-->*内容*helloworld粗体-->**内容**helloworld倾斜加粗***helloworld删除线~~引用helloworld分割线***或者---图片语法:网络图片:超链接点击跳转......
  • 基于典型相关性分析的多视图学习方法(基于半监督学习的 CCA)——泛化能力的多视图分析模
    泛化能力的多视图分析模型(GeneralizedMulti-viewAnalysis,GMA)是由Sharma等人提出的,旨在扩展传统无监督的典型相关分析(CanonicalCorrelationAnalysis,CCA)至有监督学习和更广泛的数据分析场景。GMA的核心在于能够处理多源异构数据,同时考虑数据的标签信息,以提高模型的泛......