【微服务】1、引入;注册中心;OpenFeign
微服务技术学习引入
- 微服务自2016年起搜索指数持续增长,已成为企业开发大型项目的必备技术,中高级java工程师招聘多要求熟悉微服务相关技术。
- 微服务架构介绍
- 概念:微服务是一种软件架构风格,以专注于单一职责的多个响应项目为基础,组合出复杂大型应用,与单体架构不同,其内部由多个小项目组合而成。
- 单体架构特点:业务功能和模块无论多复杂都写在一个项目中,项目体积随功能增加而增大,但始终是一个项目。
- 微服务架构特点:将单体架构项目按单一职责原则拆分成多个小项目,每个小项目独立开发、运行和部署,组合形成微服务集群。
- 服务拆分问题
- 架构选择问题:开发新项目时需考虑选择单体架构还是微服务架构,若选择微服务架构,需确定何时从单体架构转变以及如何拆分服务、确定服务拆分边界等。
- 拆分后的问题
- 跨服务远程调用:服务拆分后,业务功能在不同项目中,物理上隔绝,存在跨服务调用问题。
- 服务治理:服务间调用关系复杂,需要管理服务的状态和调用关系。
- 服务请求路由:单体项目时前端通过IP端口访问,微服务架构下有多个独立部署的服务,前端需明确访问路径,存在服务请求路由问题。
- 何时拆分单体架构项目
- 创业型项目
- 适合采用单体架构,因其需要快速开发、低成本试错。
- 确定的大型项目
- 如大厂开发网上商城,资金充足、目标明确,一上来就推荐使用微服务架构,可避免从单体架构再拆分的麻烦,后续开发更轻松。
- 创业型项目
- 如何拆分单体项目
- 拆分目标
- 高内聚:拆出的服务职责应单一,包含关联度高且完整度高的业务,即功能升级或迭代时大部分代码在服务内部修改,减少对其他服务影响。
- 低耦合:服务功能相对独立,减少对其他服务依赖,核心业务尽量在内部完成,跨服务合作业务应尽量减少,做到高内聚自然低耦合。
- 拆分方式
- 纵向拆分(垂直拆分):按业务模块拆分,如黑马商城按商品管理、用户管理、订单、支付、购物车等业务模块进行拆分。
- 横向拆分(水平拆分):抽取公共服务模块,避免重复开发,如登录、下单等业务中的风控和短信功能,可分别抽取成风控微服务和短信微服务,供其他业务共享。
- 拆分目标
基于Rest template的服务调用问题
- 调用方式说明:基于Rest template的服务调用需在代码中写死对方服务的IP地址、端口号和资源路径。
- 多实例部署问题:实际部署中,服务可能多实例部署,写代码时无法预知部署数量及地址,导致负载均衡失效,如商品服务多实例部署时,写死的代码可能无法访问到所有实例。
- 服务挂掉问题:服务挂掉后,代码写死地址无法动态切换,影响业务,如商品服务挂掉后,购物车服务因写死地址无法访问商品服务,业务出现问题。
- 新服务启动问题:新服务启动后,代码无法动态获取地址,如运维启动新的商品服务实例,端口变化后,购物车服务无法得知新地址。
注册中心解决服务治理问题
- 服务治理问题:包括服务提供者地址未知、服务状态变更无法感知、多实例负载均衡等。
- 注册中心技术:用于解决上述服务治理问题。
- 解决问题原理:服务提供者启动后向注册中心注册服务信息,服务调用者向注册中心订阅服务,注册中心返回实例列表,服务调用者通过负载均衡算法选择实例进行调用。
注册中心的工作原理
- 服务注册:服务提供者启动后向注册中心注册服务信息,包括服务名称、IP端口、提供的功能等,注册中心形成服务注册表记录这些信息。
- 服务订阅:服务调用者向注册中心订阅所需服务,注册中心返回实例列表。
- 负载均衡:服务调用者从实例列表中通过负载均衡算法选择一个实例进行调用,负载均衡算法包括随机、轮询、加权轮询等。
- 心跳机制与服务状态监控:服务与注册中心形成心跳机制,服务定期向注册中心报告健康状态,注册中心监控服务状态,服务挂掉后,注册中心剔除实例并推送变更给服务调用者;新服务启动后注册信息变更,注册中心推送新信息给服务调用者,使其感知服务状态变更。
负载均衡算法及注册中心的作用
- 负载均衡算法
- 随机算法:从多个实例中随机选择一个。
- 轮询算法:按顺序依次请求各个实例,实现均衡访问。
- 加权轮询或加权随机:根据实例权重分配访问概率,适用于硬件配置不同情况。
- 注册中心作用
- 接收服务注册信息,形成服务注册表。
- 监控服务状态变更,通过心跳机制实现。
- 服务状态变化时,剔除或添加实例信息并推送变更给服务调用者,实现服务治理。
注册中心原理回顾
- 原理回顾:注册中心原理类似家政中心,服务提供者注册服务,服务调用者订阅服务,通过负载均衡选择实例,服务与注册中心心跳维持状态监控,实现服务治理。服务治理涉及服务提供者、消费者、注册中心三个角色,注册中心记录监控服务状态并推送变更。
- 注册中心组件选择
- 介绍多种注册中心组件,如NFLICK公司的Eureka、Spring Cloud Consul、阿里巴巴的NEO等,它们都遵循Spring Cloud标准,使用差别不大。
- 介绍多种注册中心组件,如NFLICK公司的Eureka、Spring Cloud Consul、阿里巴巴的NEO等,它们都遵循Spring Cloud标准,使用差别不大。
OpenFeign
OpenFeign是一个声明式的HTTP客户端,在微服务架构中可简化跨服务调用的代码。以下是其主要内容总结:
OpenFeign引入背景
在微服务架构中,跨服务查询商品时,原始代码复杂,涉及根据服务名称获取服务实例、负载均衡、发送请求、解析结果等多个步骤,而单体架构实现类似查询仅需一行代码。为解决此问题,引入OpenFeign技术。
OpenFeign使用步骤
- 引入依赖
- spring cloud starter OpenFeign:OpenFeign组件依赖。
- spring cloud starter LoadBalancer:用于负载均衡,新版本使用,早期使用ribbon。
- 添加注解
- 在启动类上加@EnableFeignClients注解,开启OpenFeign功能。
- 定义FeignClient接口
- 这是一个接口,用于替代之前复杂代码。
- 接口上加@FeignClient注解并指定服务名称(如item service),OpenFeign会据此从注册中心拉取实例列表。
- 通过定义方法并加注解(如@GetMapping、@RequestParam等Spring MVC注解),标记请求方式、路径、参数等信息,降低学习成本。
- 方法返回值类型用于确定返回值类型,OpenFeign可将JSON结果转为相应Java对象。
- 该接口无需手动实现,OpenFeign会动态代理实现。
示例代码实现
- 在cut service的pom文件引入上述依赖。
- 在启动类添加@EnableFeignClients注解。
- 编写item client接口,如:
@FeignClient("item-service")
public interface ItemClient {@GetMapping("/items")Collection<ItemDTO> queryItemByIds(@RequestParam("ids") List<String> ids);
}
- 在调用处注入item client接口,直接调用接口方法(如itemClient.queryItemByIds())实现远程查询,一行代码搞定。
总结
OpenFeign可简化跨服务调用代码,让微服务之间的远程调用更简单,实现类似单体架构的调用便捷性。
连接池
最佳实践
OpenFeign使用问题及优化方案总结
1. OpenFeign使用问题引入
1.1当前使用方式存在的问题
- 多业务重复编写:在购物车和订单业务(未来拆分)中,都需编写类似查询商品服务的代码,造成代码重复编写,浪费资源。
- 功能变更影响大:商品服务功能变化时,所有编写了相关Feign客户端的微服务都需修改代码。
1.2优化目标
- 避免代码重复编写。
- 避免重复代码修改。
2. 优化方案一
2.1具体操作
- 商品微服务转变:将商品微服务(item service)变为纯pom类型模块。
- 创建子模块:在其下创建三个子模块,分别为item DQ(放实体类)、item p i(放API接口,如商品查询的Feign客户端)、item子模块(写商品服务业务代码)。
- 其他微服务引用:其他微服务(如购物车、订单服务)通过引用这两个模块坐标,实现远程调用商品服务功能。
2.2优点
- 代码编写优化:解决代码重复编写问题,由商品服务开发者维护DT和Feign客户端,更为合理。
- 低耦合:不同微服务间耦合度低,便于团队独立维护。
2.3缺点
- 项目结构复杂:每个微服务拆分成多个模块,会使项目结构变得复杂,如单体项目拆成20个微服务时,模块数量会从20个变为60个。
3. 优化方案二
3.1具体操作
- 创建通用API模块:名称为HMAPI,不属于任何微服务,是与其他模块同级的通用模块。
- 定义包及内容:模块内定义三个包(Client、config、dto),Client包中放整个商城每个微服务要暴露的客户端接口,DTO包放所有需要公共访问的DTO。
- 微服务引用:其他微服务(如购物车、订单服务)直接引用HMAPI模块依赖,即可调用相关功能。
3.2优点
- 代码重复解决:解决代码重复编写问题。
- 通用性强:具备代码通用性,方便统一管理。
3.3缺点
- 耦合度增加:代码耦合度相对较高,不同微服务接口需在同一模块维护。
4. 课堂演示选择及操作(基于方案二)
4.1创建模块
- 创建HM - API
4.2引入依赖
- 引入原购物车服务中有关OpenFeign和load balance依赖。
4.3创建包及拷贝代码
- 创建com.hm.api包及子包client、dt,将购物车服务中的DT和Feign客户端相关代码拷贝至对应包中。
4.4处理购物车服务报错
- 删除购物车服务中原有DT和客户端代码,在pom文件中引入HM - API模块依赖,解决业务报错。
5. 测试及问题解决
5.1测试出错
- 重启购物车服务测试时,出现错误,提示cart service实现类构造函数参数找不到bean。
5.2原因分析
- Feign客户端接口未被扫描到,其bean由动态代理实现,需被扫描包扫描,而购物车服务启动类扫描包与通用模块扫描包不同。
5.3解决方法
5.4测试成功
- 再次重启测试,成功访问接口,证明问题解决。
6. 总结与易错点强调
6.1两种模式总结
- 通用API模块模式:所有微服务对外暴露接口及相关DTO定义在通用模块,其他服务引用即可。
- 微服务拆分模式:在微服务内部创建子模块分别放DTO、Feign接口和实现类,供其他服务引用。
6.2选择建议
- 根据项目结构选择合适模式,如项目为聚合结构,可选择通用API模块模式;若项目结构为每个微服务是独立project,可选择微服务拆分模式。
6.3易错点
- 引用其他模块定义的Feign客户端时,默认扫描包扫不到,需在启动类的Feign开关上指定Feign客户端对应的扫描包,否则无法正确扫描创建对象使用。
OpenFeign日志输出与相关知识总结
-
日志输出问题提出
- 项目开发中日志输出重要,能帮助定位和解决问题。
- 以查询购物车功能为例,其远程调用商品服务时,当前仅看到一条SQL语句日志,未看到OpenFeign远程调用相关日志,不利于调试。
-
OpenFeign日志记录规范
- 默认输出条件:OpenFeign默认仅在thin client所在包的日志级别为debug时输出日志。
- 项目日志级别:项目中已将
com.hm
包定义为debug级别,但OpenFeign仍未输出日志,是因为其自身日志级别默认为NONE
,不记录任何信息。
-
OpenFeign日志级别介绍
- NONE:默认值,不记录任何日志信息。
- BASIC:仅记录请求方法、URL、显示状态码及执行时间等基础信息(即请求行部分信息,不包括请求头和请求体)。
- HEADERS:在BASIC基础上,额外记录请求和响应的头信息。
- FULL:记录请求行、请求头、请求体、响应行、响应头和响应体,涵盖HTTP协议所有相关数据。
-
OpenFeign日志级别配置步骤
- 定义日志级别bean:定义一个类,在类中声明一个类型为
log.level
(OpenFeign提供的日志级别枚举类型)的bean,并设置所需日志级别(如FULL)。此时该bean未生效,因为所在类缺少@Configuration
注解。 - 配置生效方式
- 局部配置:将配置类放到
@FeignClient
注解中,仅对该客户端生效。 - 全局配置:将配置类放到
@EnableFeignClients
注解上,对所有客户端生效。
- 局部配置:将配置类放到
- 通用模块配置示例:在通用模块定义配置类
DefaultFeignConfig
,设置日志级别为FULL,在启动类添加@EnableFeignClients(defaultConfiguration = DefaultFeignConfig.class)
实现全局生效。重启服务后,日志输出内容增多,方便调试,但日常运行不建议开启,因其输出内容多会影响性能。
- 定义日志级别bean:定义一个类,在类中声明一个类型为
-
OpenFeign知识回顾总结
- 远程调用步骤
- 引用OpenFeign和负载均衡器的依赖。
- 基于
@EnableFeignClients
注解开启OpenFeign效果。 - 编写
FeignClient
接口,基于Spring MVC注解定义方法,OpenFeign利用动态代理自动实现。 - 注入客户端进行调用。
- 连接池配置方法:引入依赖并在
yml
文件中打开OpenFeign连接池开关。 - 最佳实践方案
-
-拆分微服务为多个子模块,如在DTO模块放实体类、client模块放Feign接口、base模块放业务代码,其他微服务按需引用DT和client模块。
- 额外创建一个模块专门存放所有微服务的
client dt
,其他微服务引用该模块。课堂中采用在微服务里创建独立模块的方式。
- 额外创建一个模块专门存放所有微服务的
- 输出日志级别配置:定义类并在其中定义日志级别的bean(不加
@Configuration
注解),然后将配置类声明在@FeignClient
或@EnableFeignClients
注解上。
- 远程调用步骤
相关文章:
【微服务】1、引入;注册中心;OpenFeign
微服务技术学习引入 - 微服务自2016年起搜索指数持续增长,已成为企业开发大型项目的必备技术,中高级java工程师招聘多要求熟悉微服务相关技术。微服务架构介绍 概念:微服务是一种软件架构风格,以专注于单一职责的多个响应项目为基…...
SQL Server 数据库 忘记密码
1、先用windows 身份验证 连接 2、安全性--登录名 3、设置 身份验证 4、重启电脑 5、登录 登陆成功!!! ------------------------------------------------------------------ --1、查询登录账号信息 ------------------------------------------------------------------ -- …...
Tableau数据可视化与仪表盘搭建-安装教程
下载 tableau.com/zh-cn/support/releases 滚动到最下方的下载 在下载的同时 我们点击登录,去注册一个tableau的账号 下面点击我们下载好的tableau安装程序 不要自定义安装,会有路径问题 点击试用14天 点击激活 激活学生 tableau.com/zh-cn/academic…...
UGUI 优化DrawCall操作记录(基于Unity2021.3.18)
UGUI中相同材质相同Shader相同贴图的UI元素可以合并DrawCall。 1.使用图集 Unity性能优化---使用SpriteAtlas创建图集进行批次优化_unity2021.3.33 spriteatlas优化-CSDN博客 2.Canvas的子物体在场景树中的索引位置和不同图集不影响UI合批且UI网格没有重叠,如下图…...
DeepSeek v3为何爆火?如何用其集成Milvus搭建RAG?
最近,DeepSeek v3(一个MoE模型,拥有671B参数,其中37B参数被激活)模型全球爆火。 作为一款能与Claude 3.5 Sonnet,GPT-4o等模型匹敌的开源模型DeepSeek v3不仅将其算法开源,还放出一份扎实的技术…...
网络编程原理:回显服务器与客户端通信交互功能
文章目录 路由器及网络概念网络通信基础TCP/IP 五层协议封装和分用封装分用 网络编程(网络协议)UDP类 API使用实现回显通信程序回显服务器(UDP代码)回显客户端(UDP代码) TCP API使用回显服务器(TCP代码)回显客户端(TCP代码) 路由器及网络概念 网络发展是…...
#渗透测试#漏洞挖掘#WAF分类及绕过思路
免责声明 本教程仅为合法的教学目的而准备,严禁用于任何形式的违法犯罪活动及其他商业行为,在使用本教程前,您应确保该行为符合当地的法律法规,继续阅读即表示您需自行承担所有操作的后果,如有异议,请立即停…...
西安电子科技大学初/复试笔试、面试、机试成绩占比
西安电子科技大学初/复试笔试、面试、机试成绩占比 01通信工程学院 02电子工程学院 03计算机科学与技术学院 04机电工程学院 06经济与管理学院 07数学与统计学院 08人文学院 09外国语学院 12生命科学与技术学院 13空间科学与技术学院 14先进材料与纳米科技学院 15网络与信息安…...
【Python学习(六)——While、for、循环控制、指数爆炸】
Python学习(六)——While、for、循环控制、指数爆炸 本文介绍了While、for、循环控制、指数爆炸,仅作为本人学习时记录,感兴趣的初学者可以一起看看,欢迎评论区讨论,一起加油鸭~~~ 心中默念:Py…...
中间件自动化测试框架cmdlinker
背景 作为一个中间件的测试工程师,如何对于中间件提供的命令进行自动化的回归,这一直是一个难题,市面上好像缺乏了对于命令进行自动化回归的合理解决方案。 常见方式有下面两种: 直接写字符串的命令,然后使用各种编程…...
写一个类模板三个模板参数K,V,M,参数是函数(函数参数、lambda传参、函数指针)
cal是类的成员函数。cal的3个入参是func1(K),func2(K,V),func3(K,V,M),请写出cal,并在main函数中调用cal 在您给出的要求中,cal成员函数并不直接…...
STM32-笔记35-DMA(直接存储器访问)
一、什么叫DMA? DMA(Direct Memory Access,直接存储器访问)提供在外设与内存、存储器和存储器之间的高速数据传输使用。它允许不同速度的硬件装置来沟通,而不需要依赖于CPU,在这个时间中,CPU对于…...
数势科技:解锁数据分析 Agent 的智能密码(14/30)
一、数势科技引领数据分析变革 在当今数字化浪潮中,数据已然成为企业的核心资产,而数据分析则是挖掘这一资产价值的关键钥匙。数势科技,作为数据智能领域的领军者,以其前沿的技术与创新的产品,为企业开启了高效数据分析…...
ES6中定义私有属性详解
在ES6中,定义私有属性的方式相对传统的JavaScript有所不同。ES6并没有提供直接的语法来定义私有属性,但可以通过几种方法间接实现私有属性。 1. 使用Symbol来模拟私有属性 Symbol是一种新的数据类型,可以作为对象的键,并且它的值…...
@Cacheable 注解爆红(不兼容的类型。实际为 java. lang. String‘,需要 ‘boolean‘)
文章目录 1、org.springframework.cache.annotation.Cacheable2、javax.persistence.Cacheable Cacheable(value "findPAUserById", key "#id")public Optional<PAUser> findById(Integer id) {return paUserRepository.findById(id);}我真的要笑死…...
离散数学 期末笔记
命题符号化 使用等值演算法证明 求公式范式 在自然推理体系中构造下列推理的证明 在一阶逻辑中将下列命题符号化 设A、B、C、D是 Z 的子集 证明下列集合恒等式 二元关系 性质 没有空的 没有漏的 没有重复 函数...
物联网控制期末复习
第3章 物联网控制系统的过程通道设计 3.1 模拟量输出通道 3.1.1单模拟量输出通道的构成 计算机控制系统的模拟量输出通道将计算机产生的数字控制信号转换为模拟信号(电压或电流)作用于执行机构,以实现对被控对象的控制。 多D/A结构&#…...
Hypium纯血鸿蒙系统 HarmonyOS NEXT自动化测试框架
1、什么是Hypium Hypium是华为官方为鸿蒙操作系统开发的一款以python为语言的自动化测试框架。 引用华为官网介绍如下: DevEco Testing Hypium(以下简称Hypium)是HarmonyOS平台的UI自动化测试框架,支持开发者使用python语言为应用编写UI自动化测试脚本…...
李宏毅机器学习课程笔记01 | 1.Introduction of Machine/Deep Learning
笔记是在语雀上面做的,粘贴在CSND上可能存在格式错误 机器学习的本质就是借助机器寻找一个转换函数 根据函数的输出类型,可以将机器学习进行分类 regression 回归任务:函数输出时一个数值classification 分类任务:人类设定好选项…...
探索Docker Compose:轻松管理多容器应用
探索Docker Compose:轻松管理多容器应用 在现代软件开发中,容器化已经成为构建、部署和扩展应用的主流方式。而Docker Compose作为Docker生态系统的重要组成部分,可以简化多容器应用的管理。本文将深入探讨Docker Compose的核心功能及应用场…...
java中static和const和final的区别
static 关键字 static 关键字用于声明类的成员(方法或变量)为静态成员。静态成员属于类本身,而不是类的实例。换句话说,静态成员可以通过类名直接访问,而不需要实例化对象。 静态变量:属于类的所有对象共…...
[Win32/ATL]_[初级]_[处理WM_PAINT消息注意事项]
场景 在开发Win32/WTL程序时,遇到了使用CFolderDialog(atldlgs.h)打不开目录选择对话框的情况。具体表现是执行了窗口的DoModal,却没有窗口弹出来。 可以确定执行操作是在主线程,并不是工作线程。调试时暂停看堆栈,知道到DoModal方法里的SHB…...
【DevOps】Jenkins项目发布
Jenkins项目发布 文章目录 Jenkins项目发布前言资源列表基础环境一、Jenkins发布静态网站1.1、项目介绍1.2、部署Web1.3、准备gitlab1.4、配置gitlab1.5、创建项目1.6、推送代码 二、Jenkins中创建gitlab凭据2.1、创建凭据2.2、在Jenkins中添加远程主机2.3、获取gitlab项目的UR…...
Lua迭代器如何使用?
在Lua中,迭代器是一种用于遍历集合元素的重要工具。掌握迭代器的使用方法,对于提高Lua编程的效率和代码的可读性具有重要意义。 1.迭代器概述 12.1.1 迭代器介绍 迭代器是一种设计模式,它提供了一种访问集合元素的方法,而不需要…...
cesium小知识:3D tiles 概述、特点、示例
Cesium 的 3D Tiles 是一种高效的、流式传输的三维地理空间数据格式,专为在Web浏览器中快速渲染大规模三维场景而设计。3D Tiles 支持多种几何类型,包括点云、多边形、模型等,并且可以包含丰富的属性信息和层次细节(LOD, Level of Detail)结构,以确保不同设备和网络条件下…...
PTA DS 基础实验3-2.1 一元多项式求导
基础实验3-2.1 一元多项式求导 分数 20 全屏浏览 切换布局 作者 DS课程组 单位 浙江大学 设计函数求一元多项式的导数。 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。 注意:…...
【玩转全栈】----用户管理案例
目录 案例需求: 成果显示: 源码展示: 部分源码解释及注意 1、info_list.html文件 2、info_add.html文件 3、models.py文件 4、views.py文件 经过前面的学习,相信您对Django、MySQL,以及他们之间的连接已经非常熟悉了&a…...
文件上传漏洞利用与绕过姿势总结
文章目录 攻击与绕过方式一、条件竞争二、二次渲染结合文件包含绕过1、gif2、png3、jpg 三、.htaccess解析绕过四、文件后缀名绕过1、文件特殊后缀名大小写绕过2、::$DATA绕过3、双后缀名绕过4、点绕过5、空格绕过 五、文件头绕过六、短标签绕过七、MIME(Content-Type)绕过八、…...
Java十六
2-9-1Request和Response介绍 Request继承体系 ServletRequest————Java提供的请求对象根接口 Http ServletRequest————Java提供的对Http协议封装的请求对象接口 RequestFacade————Tomcat定义的实现类 1.Tomcat需要解析请求数据,封装为request对象,并且创建requ…...
人工智能在事件管理中的应用
随着科技的不断发展,人工智能(AI)正在深入到各行各业,运维领域也不例外。在事件管理中,AI通过其强大的数据分析和自动化能力,帮助团队更高效地处理系统事件,提升业务的稳定性和用户体验。 什么是事件管理? 事件管理是IT运维的重要组成部分,其核心目标是快速响应和处…...
Launcher3版本确定
Launcher3有几个不同的版本,引入的代码和资源文件有所不同,我们需要确认当前设备中使用的是哪个 查看bp脚本可以看到会生成四个app /packages/apps/Launcher3$ grep -nr -E "android\_app\ \{" -A 1 ./Android.bp 184:android_app { 185- …...
算法题(25):只出现一次的数字(三)
审题: 该题中有两个元素只出现一次并且其他元素都出现两次,需要返回这两个只出现一次的数,并且不要求返回顺序 思路: 由于对空间复杂度有要求,我们这里不考虑哈希表。我们采用位运算的方法解题 方法:位运算 首先&#…...
atrust异常导致ERR_NETWORK_CHANGED
首先因为工作需要不断安装卸载不同版本深信服的atrust。那么可能遇到和我一样的问题。 深信服的这种东西有点毛病,以前只是偶尔导致我局域网无法访问,我停止atrust后,他还有后台程序在后台不断更改我的适配器,在我局域网需要固定…...
【Infineon AURIX】AURIX缓存(CACHE)变量访问指南
AURIX缓存变量访问指南 引言 本文分析Infineon AURIX控制器在调试过程中访问缓存内存变量的问题及解决方案重点探讨了变量缓存对调试的影响以及多种解决方法的优劣第1部分:问题描述与成因分析 主要症状 变量值发生变化,但实时内存访问显示初始值Watch窗口和Memory窗口中的变…...
轻量级通信协议 JSON-RPC 2.0 详解
目录 JSON-RPC 2.0 简介 请求对象 响应对象 通知 批量请求 错误码 使用场景 文档和版本控制 社区和支持 小结 参考资料 JSON-RPC 2.0 简介 JSON-RPC (JavaScript Object Notation - Remote Procedure Call) 是一种轻量级的远程过程调用协议,使用 JSON&am…...
[读书日志]从零开始学习Chisel 第一篇:书籍介绍,Scala与Chisel概述,Scala安装运行(敏捷硬件开发语言Chisel与数字系统设计)
简介:从20世纪90年代开始,利用硬件描述语言和综合技术设计实现复杂数字系统的方法已经在集成电路设计领域得到普及。随着集成电路集成度的不断提高,传统硬件描述语言和设计方法的开发效率低下的问题越来越明显。近年来逐渐崭露头角的敏捷化设…...
深入了解 StarRocks 表类型:解锁高效数据分析的密码
在当今数字化浪潮下,大数据分析成为企业决策、优化业务流程的关键利器。StarRocks 作为一款备受瞩目的高性能分析型数据库,其多样化的表类型为复杂的数据处理需求提供了精准解决方案。今天,就让我们一同深入探索 StarRocks 中的主键表、明细表…...
spring mvc源码学习笔记之四
pom.xml 内容如下 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/P…...
Spring Boot + Redis + Sa-Token
参考文献 Sa-Token实现分布式登录鉴权(Redis集成 前后端分离)-腾讯云开发者社区-腾讯云 介绍 StpInterface 是 Sa-Token 框架中的一个接口,属于 Sa-Token 身份认证与授权框架的一部分。该接口提供了一些方法来实现自定义的身份认证和授权管…...
【顶刊TPAMI 2025】多头编码(MHE)之Part 6:极限分类无需预处理
目录 1 标签分解方法的消融研究2 标签分解对泛化的影响3 讨论4 结论 论文:Multi-Head Encoding for Extreme Label Classification 作者:Daojun Liang, Haixia Zhang, Dongfeng Yuan and Minggao Zhang 单位:山东大学 代码:https:…...
Spring Certified Professional 2024 (2V0-72.22)
关于认证 Spring Certified Professional (2V0-72.22) 认证可证明您在 Spring Framework 方面的专业知识,Spring Framework 是构建企业级 Java 应用程序的领先平台。此认证在全球范围内得到认可,并证明您在 Spring 的各个方面都具有熟练程度,…...
asp.net core框架搭建4-部署IIS/Nginx/Docker
文章目录 系列文章一、Linux上部署Nginx1.1 Centos 安装配置环境1.2 使用Systemctl 控制Nginx 二、部署IIS三、部署Docker3.1 创建 Dockerfile 文件3.2 构建 Docker 镜像3.3 运行 Docker 容器3.4 检查容器运行情况 结束语 作者:xcLeigh 文章地址:https:/…...
改善 Kibana 中的 ES|QL 编辑器体验
作者:来自 Elastic Marco Liberati 随着新的 ES|QL 语言正式发布,Kibana 中开发了一种新的编辑器体验,以帮助用户编写更快、更好的查询。实时验证、改进的自动完成和快速修复等功能将简化 ES|QL 体验。 我们将介绍改进 Kibana 中 ES|QL 编辑器…...
webpack5基础(上篇)
一、基本配置 在开始使用 webpack 之前,我们需要对 webpack 的配置有一定的认识 1、5大核心概念 1)entry (入口) 指示 webpack 从哪个文件开始打包 2)output(输出) 制视 webpack 打包完的…...
C#设计模式(行为型模式):观察者模式
C#设计模式:观察者模式,让对象间通信更优雅 在软件开发中,我们经常会遇到一个对象的状态发生改变,其他对象需要自动更新或做出相应反应的场景。例如: GUI事件处理: 当用户点击按钮时,按钮需要…...
pg_wal 目录下 wal 日志文件异常累积过大
文章目录 背景当前配置分析解决过程1. 活动事务未完成2. 备份滞后或归档未完成3. 保留了过多的 WAL 文件4. 逻辑复制槽未释放5. 文件系统问题6. 强制触发 WAL 清理结果lsof D 是啥意思检查进程从名字来看, 该 wal 文件是最小的文件(一般也是最老的 wal 文件)pg_archivecleanup …...
【人工智能】用Python实现深度卷积生成对抗网络(DCGAN):原理、实现与优化
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 深度卷积生成对抗网络(DCGAN)是一种结合了卷积神经网络(CNN)和生成对抗网络(GAN)的深度学习模型,广泛应用于图像生成、图像增强、以…...
领域驱动设计(4)—绑定模型与实现
(4)—绑定模型与实现 模式:MODEL-DRIVEN DESIGN为什么模型对用户至关重要?模式:HANDS-ON MODELER 很多项目设计之初只考虑到模型如何设计,没有将模型如何实现、数据关系如何存储这些实现考虑在内,往往设计…...
logback日志框架源码分析
目录 (一)入口:slf4j选择日志框架 (二)日志框架初始化 (1)logback的3种配置方式 a、BasicConfigurator默认配置 b、SPI方式配置的Configurator实现类 c、通过配置文件初始化 (2)xml配置文件初始化 (三)Logger的创建 (四)打印日志 本文源码基于:logback版…...
Airflow:HttpSensor实现API驱动数据流程
数据管道工作流通常依赖于api来访问、获取和处理来自外部系统的数据。为了处理这些场景,Apache Airflow提供了HttpSensor,这是一个内置的Sensor,用于监视HTTP请求的状态,并在满足指定条件时触发后续任务。在这篇博文中,…...