首页 > 其他分享 >985研一学习日记 - 2024.10.11

985研一学习日记 - 2024.10.11

时间:2024-10-12 12:21:18浏览次数:3  
标签:11 2024.10 调用 服务 请求 开启 接口 985 yml

偶尔一碗热鸡汤:一个人内耗,说明他活在过去;一个人焦虑,说明他活在未来。只有当一个人平静时,他才活在现在。

日常

1、6:00起床 √

2、健身1h

今天练了肩部以及背,然后跑步半小时

3、LeetCode刷了2题

  1. 括号生成:回溯、中
    • 仍然使用递归+回溯的方法,递归遍历字符串,每遇到一个)就在其左右分别插入一个()
    • 递归插入(),然后恢复状态后回溯继续插入,要注意当两个))相邻时,只需要插入一次即可
    • 此时会出现重复的情况,根据前面做的题的经验,可以从上一次插入位置开始下一次的遍历
  2. 单词搜索:回溯、中
    • 使用递归+回溯的算法,其中回溯是使用DFS深度优先遍历的思想,记录每个字母是否遍历过
    • 先遍历整个矩阵找到第一个字母,然后对字母进行递归,在递归函数中先判断当前递归的深度是否等于搜索单词的长度,如果等于说明存在;如果不等于则从当前字母开始DFS,分别判断上下左右四个位置的字母是否与当前的字母相同,要以回溯的方式进行递归,若相同则修改标记为1然后DFS递归遍历,然后再恢复状态后遍历别的情况
    • DFS要传入当前已经遍历的位置,而且要创建flag数组进行标识字母是否遍历过

4、22:30复盘

不复盘等于白学!!!

学习和感想

1、SpringCloud!!!

  1. LoadBalancer负载均衡
    1. LoadBalancer组件是微服务客户端自己实现的,在RestTemplateConfig配置类上使用@LoadBalanced注解进行配置,表示赋予Rest负载均衡能力(在Consul中必须开启负载均衡 ,否则会报错)

    2. 是什么:是springcloud提供的用来替代ribbon的本地客户端的负载均衡组件,每个微服务均有一个本地的,然后由客户端自己根据规则选择相应的服务实现负载均衡

    3. 先导入LoadBalancer组件所需要的POM依赖:spring-cloud-starer-loadbalancer

    4. 不需要修改yml文件,而是在微服务之间进行通信的RestTemplate对象的@Bean方法上加上@LoadBalanced注解即可在这里插入图片描述

    5. 在使用Consul后,微服务之间进行通信时必须要实现负载均衡,在RestTemplate上加上注解来实现本地客户端的负载均衡

    6. 负载均衡算法原理:rest接口第几次请求数 % 服务器总数 = 实际调用的服务器下标(每次重启后rest接口计数从1开始)

  2. OpenFeign:服务调用与负载均衡(服务端接口)
    1. 是什么:通过OpenFeign可以实现服务调用和负载均衡

      1. OpenFeign是一个声明性web服务客户端在这里插入图片描述
    2. 怎么用:服务提供者提取公共接口用@FrignClient标注,服务调用者POM,yml,主启动,然后业务类在这里插入图片描述

      1. 当使用RestTemplate实现服务调用时,要在每个微服务中定义RestTemplate对象,然后手动设置要调用的微服务的名字,再使用该对象对该微服务进行调用;此时每个要调用服务的微服务都要定义一个RestTemplate对象
      2. 为了解决这一问题,引入了OpenFeign:此时只需将服务提供者所提供的方法在公共微服务中相应的接口中声明,并用@FeignClients(‘服务提供者名’)标注该接口(此时公共微服务要引入spring-cloud-starter-openfeign依赖才可使用@FeignClients注解),此时就代表服务提供者将其要提供的服务放到公共的接口中,该接口中的方法必须与所提供的服务方法有一致的路径@XxxMapping(),接口方法名字可以不相同
      3. 服务调用者要调用对应微服务提供的服务时,就可以使用openfrign进行调用首先要在该微服务中引入spring-cloud-starter-openfeignPOM依赖,然后改yml,然后再修改启动类,加入@EnableFeign注解来开启OpenFeign,然后此时在controller中通过自动装配定义要调用服务所提供的接口类对象,然后就可以通过该对象调用对应的方法实现对应的服务
    3. 超时控制:在yml中设置全局或者单个超时时间

      1. 在调用者通过Openfeign调用微服务时,会有两个关于超时的配置,分别是connectTimeout和readTimeout
      2. connectTimeout是调用者连接到提供者的超时控制,而readTimeout是连接上后完成服务调用直到返回所限制的超时时间,默认是60秒,即当服务调用时间超过60s未返回时就会报错
      3. 可以在服务调用者客户端上通过修改yml文件来配置超时时间(谁发起调用就配置谁的yml文件),通过修改 spring.cloud.openfeign.client.config.dafault.readtimeout 来设置全局请求(所有调用请求)的超时控制,也可以单独指定某个服务调用的超时控制,通过修改 spring.cloud.openfeign.client.config.服务名.readtimeout 来实现,两个可以共存,且单个配置会覆盖全局配置
    4. 重试机制:默认是关闭的,只要第一个调用失败则直接返回(在配置类开启重试机制)

      1. 可以开启重试机制,当调用失败后会重新发起请求
      2. 在调用者客户端微服务中创建FeignConfig配置类@Configuration注解标注,然后用@Bean注解标注 Retry myRetry(){} 方法,在该方法中默认 return Retry.NEVER_RETRY;(默认是不进行重试的),此时可以修改return Retry.default(初次间隔时间,最大间隔时间,请求总次数)来开启重试机制,此时当第一次请求失败后,会间隔时间后重新发起调用请求,直到规定次数失败后才会返回报错
    5. 性能优化HttpClient5:一定要替换!!先引入POM依赖再在yml中进行配置

      1. OpenFeign默认使用JDK中自带的HttpClient.HttpURLConnection发送HTTP请求,没有连接池、性能和效率也比较低,此时就可以修改OpenFeign的连接
      2. 此时可以使用Apache 的HttpClient5来替换以提高性能,先修改POM中的依赖,导入HC5的依赖,然后修改调用者的yml配置文件spring.cloud.openfeign.httpclient.hc5.enabled=true,以开启HC5来替换默认的HttpClient
      3. 是什么
    6. 请求回应压缩:直接在yml中开启压缩

      1. 使用OpenFeign进行服务调用时可以对请求和回应进行GZIP压缩,以减少通信过程中性能损耗,要通过参数 **spring.cloud.openfeign.compression.request/response.enabled=true 来开启请求和回应的数据压缩
      2. 是什么
    7. 日志打印:对Feign的接口调用情况进行监控和输出先在配置类开启日志级别,再在yml中配置对哪个接口进行监控

      1. 先在配置类开启日志级别,再在yml中配置对哪个接口进行监控
      2. 首先要在需要开启日志功能的客户端微服务中的FeignConfig配置类中配置@Bean:Logger.Level返回所选择开启的日志级别Logger.Level.Xxx,然后在yml配置文件中开启日志功能提供设置logging.level.含有@FeignClient注解的接口的完整包名和接口名=debug表示开启日志监控哪个接口的调用情况
      3. OpenFeign提供日志打印功能,了解请求的细节,对Feign的接口调用情况进行监控和输出,有四个日志级别:NULL、BASIC、HEADER、FULL,默认是NULL不会记录任何日志信息,BASIC记录了请求的url、请求方法等信息,HEADER记录了请求和响应的头信息,FULL全部信息都记录了正文和元数据等
  3. CircuitBreaker断路器:服务熔断和降级
    1. 为什么要有:禁止服务雪崩故障,对故障结点快速熔断或降级保险丝
      1. 分布式系统微服务之间有多种级联的调用关系,当某一个调用失败时,会导致雪崩(一个故障导致所有都不能正常运行),此时就需要对故障和延迟进行隔离和管理
      2. 之前是Hystrix豪猪,分布式容错,当一个出错时不会发生级联错误
    2. 有什么作用:服务熔断、服务降级
      1. 服务熔断就相对于保险丝,当出现故障时直接熔断使服务不可用,并对服务降级(系统繁忙,请稍后再试)返回友好的兜底界面
    3. CircuitBreaker实现原理:circuitbreak只是一套规范和接口
      1. 当某一个组件发生故障时会切换到OPEN状态,过一会会切换到HALF_OPEN状态来试探是否恢复,恢复了则切换到CLOSED状态
      2. 保护分布式系统免受故障和异常,当一个组件发生故障时,会切换到OPEN状态,阻止请求发送到该组件从而避免更多请求发送到该组件
    4. Resilience4J:轻量级的容错库,专门做服务熔断和服务降级
      1. 能干吗:断路、速率限制、舱壁(隔离)
      2. Circuitbreaker:断路
        1. 断路器
          1. 三大状态之间的转换:刚开始默认是CLOSED关闭状态,此时任何请求均可以通过,当最近N次调用或者最近N秒内调用故障率过高时,则会判定服务提供者发生了故障,就会将状态切换为OPEN,此时会拒绝任何请求,过一段时间后会进入HALF_OPEN状态,此时会通过一些请求,然后根据这些请求的结果将状态切换为CLOSED或者OPEN
          2. 配置参数

标签:11,2024.10,调用,服务,请求,开启,接口,985,yml
From: https://blog.csdn.net/LiuYQi/article/details/142874719

相关文章

  • COMP3811 Computer Graphics
    SchoolofComputing:assessmentbriefModuletitleComputerGraphicsModulecodeCOMP3811AssignmenttitleCoursework1AssignmenttypeanddescriptionProgrammingassignment:GraphicsfundamentalsRationaleThecourseworkrevolvesaroundfundamentalgra......
  • <<迷雾>> 第11章 全自动加法计算机(1)--比特单元 示例电路
    具有唯一输入/输出线的存储器info::操作说明读取时,将读R开关闭合即可,Q的输出将通过传输门G到达输出DB处写入时,首先将写W开关闭合,再将上方为测试引入的开关闭合,此时此高电平将写入Q之后断开写W的开关,写入状态结束,之后可将上方为测试引入的开......
  • win11 24H2怎么安装_u盘安装win11 24H2详细步骤【支持新旧机型安装】
    10月1日,微软正式发布了Windows1124H2正式版。对于win1124h2新机器安装肯定是可以的,对于旧电脑在硬件配置上可能无法满足Windows1124h2的最低系统要求,如果按官方要求是无法安装win11的。但是如果采用第三方pe方式安装的话,配置不太低的话还是可以安装win11的。因为我们......
  • Windows 11 24H2版本有哪些新功能_Windows 11 24H2十四大新功能介绍
    距离上次发布的23H2版本已经过去了一年时间,现在,Win11的24H2版本终于等到了,微软已经全面公开发布Win1124H2版本,版本号为26100.1742,此次官宣的版本包括了消费者版、商业版、LTSC2024版等,各种语言版本应有尽有,与之前的预览版一样。在这个快速发展的数字时代,操作系统的不断......
  • 2024.10.11(自定义异常)
    自定义异常当程序中出现了某些“错误”,但该错误信息并没有在Throwable子类中描述处理,这个时候可以自己设计异常类,用于描述该错误信息。自定义异常的步骤定义类:自定义异常类名(程序员自己写)继承Exception或RuntimeException如果继承Exception,属于编译异常如果继承RuntimeExc......
  • 【2024-10-11】传承运动
    20:00人生易老天难老,岁岁重阳。今又重阳,战地黄花分外香。一年一度秋风劲,不似春光。胜似春光,寥廓江天万里霜。                                                 ——《采......
  • 2024.10.8(生成算数)
    importjavax.swing.;importjava.awt.;importjava.util.HashMap;importjava.util.HashSet;importjava.util.Random;publicclassMathQuizAppextendsJFrame{privatestaticfinalintQUIZ_TIME=3*60;//3privatestaticfinalintQUESTION_COUNT=40;/......
  • 2024.10.10
    Static当方法中不涉及到任何和对象相关的成员,则可以将方法设计成静态方法,提高开发效率,如:Math.sqrt()静态方法,只能访问静态的成员,非静态的方法,可以访问静态成员和非静态成员(必须遵守访问权限)注意这个的意思是静态方法不可以使用this访问本类的成员,但可以在静态方法内创建本......
  • 2024.10.7(数据结构的栈)
    顺序栈是利用顺序存储结构实现的栈,指针top指示栈顶在顺序栈的位置。base为存储空间基地址,S.top-S.base是栈中元素的个数,类似Length。栈为空时:S.topS.base;栈满时:S.top-S.baseMAXSIZE;顺序栈,top在最高元素的上一个,base位置是最低元素,故取栈顶元素要取top-1的:队列先进先出。......
  • 文件管理方案参考 2024.10.12
    文件管理方案参考2024.10.12说明:此文档中的文件是指手机、平板电脑、笔记本电脑等电子设备在使用过程中新建、接收、重命名、移动、编辑的电子文件。例如:Word文档(.docx)、Excel表格(.xlsx)、Photoshop图片(.jpg)、酷我音乐盒无损音乐歌曲(.flac)、国语中字电影视频(.MP4)、视频教程(.AVI)。......