当前位置: 首页 > news >正文

Spring Cloud Gateway深度解析:原理、架构与生产实践

文章目录

  • 前言
  • 一、概述
  • 二、核心架构设计及设计原理
    • 2.1 分层架构模型
      • 网络层(I/O模型)
      • 核心处理层
    • 2.2 核心组件协作流程
      • 路由定位阶段
      • 过滤器执行阶段
    • 2.3 响应式编程模型实现
      • Reactor上下文传递
      • 背压处理机制
    • 2.4 动态路由设计原理
    • 2.5 异常处理体系
    • 2.6 关键路径优化
  • 三、生产环境最佳实践
    • 3.1 动态路由配置
    • 3.2 流量控制
    • 3.3 安全防护
    • 3.4 可观测性
    • 3.5 灰度发布方案
  • 总结
  • 参考资料


前言

在云原生架构的演进浪潮中,微服务体系的稳定性建设始终面临着三大核心挑战:流量治理服务容错数据一致性。这三个维度构成了分布式系统可靠性的"铁三角",而Spring Cloud Gateway、Sentinel、Seata正是对应这三个领域的旗舰级解决方案。

Spring Cloud Gateway作为统一流量入口,扮演着微服务体系的"智能路由器"角色,不仅需要精准路由十万级QPS的请求,更要承担起安全防护、流量调度等关键职责。而在这背后,Sentinel 如同一位经验丰富的交通指挥官,通过细粒度的流量控制(QPS/并发数)、熔断降级(异常比例/响应时间)等策略,确保系统在突发流量或服务异常时仍能保持优雅降级。当请求穿透网关进入服务内部,Seata 则化身为分布式事务的"公证人",通过AT/TCC/SAGA等模式,在服务拆分带来的数据孤岛间架起可靠的一致性桥梁。

之前已经带领大家深入了解了Sentinel和Seata,这篇就带大家深入解析Spring Cloud Gateway。


一、概述

Spring Cloud Gateway是Spring Cloud生态系统中的第二代API网关,基于响应式编程模型构建,专为微服务架构设计。相较于第一代网关Zuul,它在性能(支持异步非阻塞IO)、功能扩展性和可维护性方面有显著提升,官方性能测试显示其吞吐量是Zuul 1.x的1.6倍以上。

核心特性:

  • 动态路由配置
  • 集成Spring Cloud服务发现
  • 精细化流量控制(限流/熔断)
  • 安全防护(JWT/OAuth2)
  • 支持WebSocket协议
  • 可观测性(Metrics/Tracing)

二、核心架构设计及设计原理

2.1 分层架构模型

分层架构模型

网络层(I/O模型)

基于Netty的Reactor模式:

  • 主从Reactor线程组设计
    • bossGroup:处理连接请求(默认1线程)
    • workerGroup:处理I/O读写(默认CPU核心数*2)
  • 零拷贝优化:使用PooledByteBuf减少内存复制

核心处理层

HandlerMapping阶段:

public class RoutePredicateHandlerMapping extends AbstractHandlerMapping {protected Mono<?> getHandlerInternal(ServerWebExchange exchange) {// 路由匹配逻辑}
}
  • 路由匹配优先级控制(Ordered接口实现)
  • 内置11种Predicate工厂(如PathRoutePredicateFactory)
    Filter执行阶段:
public class FilteringWebHandler implements WebHandler {public Mono<Void> handle(ServerWebExchange exchange) {return new DefaultGatewayFilterChain(combinedFilters).filter(exchange);}
}
  • 过滤器链采用责任链模式
  • 过滤器分为"pre"和"post"两种类型

2.2 核心组件协作流程

核心组件协作流程

路由定位阶段

路由表结构:

public class Route implements Ordered {private final String id;private final URI uri;private final int order;private final Predicate<ServerWebExchange> predicate;private final List<GatewayFilter> gatewayFilters;
}
  • 使用RouteLocator接口获取所有路由
  • 匹配时按order值升序排列

过滤器执行阶段

过滤器类型对比:

类型作用范围执行顺序典型应用
GlobalFilter全局通过@Order控制认证、日志
GatewayFilter路由级路由配置顺序路径改写、限流
DefaultFilter默认最先执行请求头处理

关键内置过滤器:

  • LoadBalancerClientFilter:服务发现集成
  • NettyRoutingFilter:实际请求转发
  • ForwardRoutingFilter:本地forward转发

2.3 响应式编程模型实现

Reactor上下文传递

public class AuthFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {return Mono.subscriberContext().flatMap(ctx -> {String token = ctx.get("authToken");// 验证逻辑});}
}

背压处理机制

主要用于 ‌平衡生产者(客户端)与消费者(后端服务)之间的请求处理速率‌,防止网关或下游服务因请求积压导致系统过载。通过Flux实现请求/响应流控。
关键参数配置:

spring:cloud:gateway:httpclient:response-timeout: 5smax-in-memory-size: 10MB

2.4 动态路由设计原理

配置更新机制:

public interface RouteDefinitionLocator {Flux<RouteDefinition> getRouteDefinitions();
}// 动态更新示例
public class NacosRouteDefinitionLocator implements RouteDefinitionLocator {// 监听Nacos配置变化
}

路由缓存优化:
使用CachingRouteLocator减少匹配开销
缓存刷新策略:

@RefreshScope
public class RouteConfiguration {// 配置变更时自动刷新
}

2.5 异常处理体系

异常处理体系
自定义错误处理:

@Bean
public ErrorWebExceptionHandler customExceptionHandler() {return (exchange, ex) -> {// 定制JSON错误响应};
}

2.6 关键路径优化

热点代码分析:
路由匹配算法:AntPathMatcher vs PathPatternParser

spring.mvc.pathmatch.matching-strategy=path_pattern_parser

连接池配置:

spring:cloud:gateway:httpclient:pool:type: ELASTICmax-connections: 1000acquire-timeout: 2000

设计模式应用

  • 工厂模式:RoutePredicateFactory体系
  • 责任链模式:过滤器链执行
  • 观察者模式:配置动态更新
  • 装饰器模式:CachingRouteLocator

通过这种架构设计,Spring Cloud Gateway在保持高性能(官方基准测试可达30,000+ RPS)的同时,提供了极佳的扩展性和灵活性,成为现代微服务架构中API网关的理想选择。

三、生产环境最佳实践

3.1 动态路由配置

集成Nacos实现动态更新:

@Bean
public RouteDefinitionLocator nacosRouteDefinitionLocator() {return new NacosRouteDefinitionRepository(...);
}

3.2 流量控制

使用Redis+Lua实现分布式限流:

public class RedisRateLimiter implements GatewayFilterFactory {// 基于令牌桶算法实现
}

配置示例:

filters:- name: RequestRateLimiterargs:redis-rate-limiter.replenishRate: 100 # 每秒生成100个令牌redis-rate-limiter.burstCapacity: 200  # 桶最大容量为200个令牌

3.3 安全防护

JWT鉴权实现:

public class JwtAuthFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {String token = exchange.getRequest().getHeaders().getFirst("Authorization");// JWT验证逻辑}
}

3.4 可观测性

集成Prometheus+Grafana监控:

management:endpoints:web:exposure:include: prometheusmetrics:tags:application: ${spring.application.name}

监控关键指标:

  • gateway.requests(请求总数)
  • gateway.errors(错误统计)
  • gateway.response.time(响应时间百分位)

3.5 灰度发布方案

基于Header的流量染色:

public class GrayReleaseFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {if (exchange.getRequest().getHeaders().containsKey("X-Gray")) {// 路由到灰度环境}}
}

总结

Spring Cloud Gateway作为现代微服务架构的核心组件,通过合理配置和优化,可实现每秒数万级请求的处理能力。生产实践中需重点关注:

  • 动态配置能力
  • 全链路监控
  • 安全防护体系
  • 弹性容量规划

建议定期进行压力测试,结合具体业务场景持续优化配置参数,并保持对社区最新动态的关注。

参考资料

  • 官方文档
  • 测试示例

相关文章:

Spring Cloud Gateway深度解析:原理、架构与生产实践

文章目录 前言一、概述二、核心架构设计及设计原理2.1 分层架构模型网络层&#xff08;I/O模型&#xff09;核心处理层 2.2 核心组件协作流程路由定位阶段过滤器执行阶段 2.3 响应式编程模型实现Reactor上下文传递背压处理机制 2.4 动态路由设计原理2.5 异常处理体系2.6 关键路…...

Trae 04.22版本深度解析:Agent能力升级与MCP市场对复杂任务执行的革新

我正在参加Trae「超级体验官」创意实践征文&#xff0c;本文所使用的 Trae 免费下载链接&#xff1a;Trae - AI 原生 IDE 目录 引言 一、Trae 04.22版本概览 二、统一对话体验的深度整合 2.1 Chat与Builder面板合并 2.2 统一对话的优势 三、上下文能力的显著增强 3.1 W…...

股指期货模型,简单易懂的套利策略

在股指期货投资领域&#xff0c;有不少实用的模型和策略&#xff0c;今天咱们就用大白话来唠唠其中几个重要的概念。 一、跨期套利&#xff1a;合约间的“差价游戏” 跨期套利简单来说&#xff0c;就是投资者以赚取期货合约之间的价差为目的&#xff0c;在同一个期货品种的不…...

MySQL 故障排查与生产环境优化

目录 1. MySQL单实例故障排查 2. MySQL 主从故障排查 3. MySQL 优化 3.1 硬件方面 3.2 MySQL 配置文件 3.3 SQL 方面 1. MySQL单实例故障排查 &#xff08;1&#xff09; 故障现象1 ERROR 2002 (HY000): Cant connect to local MySQL server through socket /data/mysql…...

Java泛型 的详细知识总结

一、泛型的核心作用 类型安全&#xff1a;在编译期检查类型匹配&#xff0c;避免运行时的ClassCastException。代码复用&#xff1a;通过泛型逻辑统一处理多种数据类型。消除强制转换&#xff1a;减少显式的类型转换代码。 二、泛型基础语法 1. 泛型类/接口 定义&#xff1a…...

k8s 配置 Kafka SASL_SSL双重认证

说明 kafka提供了多种安全认证机制&#xff0c;主要分为SASL和SSL两大类。 SASL&#xff1a; 是一种身份验证机制&#xff0c;用于在客户端和服务器之间进行身份验证的过程&#xff0c;其中SASL/PLAIN是基于账号密码的认证方式。 SSL&#xff1a; 是一种加密协议&#xff0c;…...

电商虚拟户:重构资金管理逻辑,解锁高效归集与智能分账新范式

一、电商虚拟户的底层架构与核心价值 在数字经济浪潮下&#xff0c;电商交易的复杂性与日俱增&#xff0c;传统账户体系已难以满足平台企业对资金管理的精细化需求。电商虚拟户作为基于银行或持牌支付机构账户体系的创新解决方案&#xff0c;通过构建“主账户子账户”的虚拟账户…...

从混乱到高效:我们是如何重构 iOS 上架流程的(含 Appuploader实践)

从混乱到高效&#xff1a;我们是如何重构 iOS 上架流程的 在开发团队中&#xff0c;有一类看不见却至关重要的问题&#xff1a;环境依赖。 特别是 iOS App 的发布流程&#xff0c;往往牢牢绑死在一台特定的 Mac 上。每次需要发版本&#xff0c;都要找到“那台 Mac”&#xff…...

01 基本介绍及Pod基础

01 查看各种资源 01-1 查看K8s集群的内置资源 [rootmaster01 ~]# kubectl api-resources NAME SHORTNAMES APIVERSION NAMESPACED KIND bindings v1 …...

DAY31-文件的规范拆分和写法

知识点回顾 规范的文件命名规范的文件夹管理机器学习项目的拆分编码格式和类型注解 &#xff08;一&#xff09;文件拆分 思考&#xff1a;如何把一个文件&#xff0c;拆分成多个具有着独立功能的文件&#xff0c;然后通过import的方式&#xff0c;来调用这些文件。这样具有几个…...

[创业之路-369]:企业战略管理案例分析-9-战略制定-差距分析的案例之华为

一、综合案例 在战略制定中&#xff0c;华为通过差距分析明确战略方向&#xff0c;以应对市场挑战和实现长期发展目标。 以下为具体案例与分析&#xff1a; 1、案例背景 华为在通信设备领域崛起过程中&#xff0c;始终将差距分析作为战略制定的核心环节。面对国际竞争对手&…...

【华为鸿蒙电脑】首款鸿蒙电脑发布:MateBook Fold 非凡大师 MateBook Pro,擎云星河计划启动

文章目录 前言一、HUAWEI MateBook Fold 非凡大师&#xff08;一&#xff09;非凡设计&#xff08;二&#xff09;非凡显示&#xff08;三&#xff09;非凡科技&#xff08;四&#xff09;非凡系统&#xff08;五&#xff09;非凡体验 二、HUAWEI MateBook Pro三、预热&#xf…...

深入理解Redis Cluster:架构、原理与实践

Redis 是一个高性能的键值存储数据库&#xff0c;广泛应用于缓存、会话存储、消息队列等场景。随着数据量和并发量的增长&#xff0c;单机 Redis 可能面临性能瓶颈和单点故障问题。为了解决这些问题&#xff0c;Redis 提供了 Redis Cluster&#xff0c;一种分布式解决方案&…...

分析 redis 的 exists 命令有一个参数和多个参数的区别

在 redis 中&#xff0c;exists 命令是用来查询某个或多个 key 是否存在的&#xff0c;返回存在的 key 的个数。 由于 redis 是按照键值对方式存储数据的&#xff0c;于是一个 key 只能对应一组数据&#xff0c;那么上述的 key 的个数指的即是需要查询的 key 中有几个 key 是存…...

[概率论基本概念1]什么是经验分布

一、说明 描述一个概率模型&#xff0c;有密度函数很好描述。如果写不出密度函数&#xff0c;退而用分布函数也能完整刻画&#xff0c;因此&#xff0c;分布函数表示比密度函数表示更加宽泛普适。本片讲述经验分布拟合分布函数的基础概念。 二、经验分布直观解释 在统计学中…...

使用Java实现Navicat密码的加密与解密

在日常开发过程中&#xff0c;我们有时需要处理各种软件保存的凭据信息&#xff0c;比如数据库连接密码等。这篇文章将介绍如何使用Java对Navicat保存的数据库密码进行加密和解密。 一、背景介绍 Navicat是一款强大的数据库管理工具&#xff0c;支持多种数据库系统。为了保护…...

怎么样进行定量分析

本文章将教会你如何对实验结果进行定量分析&#xff0c;其需要一定的论文基础&#xff0c;文末有论文撰写小技巧&#xff0c;不要看基础原理的人可以直接调到文章末尾。 一、什么是定量分析 定量分析是一种基于数据和数学模型的分析方法&#xff0c;它在众多领域中发挥着至关…...

python学习day2

今天主要学习了变量的数据类型&#xff0c;以及如何使用格式化符号进行输出。 一、认识数据类型 在python里为了应对不同的业务需求&#xff0c;也把数据分为不同的类型。 代码如下&#xff1a; """ 1、按类型将不同的变量存储在不同的类型数据 2、验证这些…...

FreeMarker

概述&#xff1a;FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据&#xff0c; 并用来生成输出文本(HTML网页&#xff0c;电子邮件&#xff0c;配置文件&#xff0c;源代码等)的通用工具。 它不是面向最终用户的&#xff0c;而是一个Java类库&#xff0c;是一款程序…...

JDK 21新特性详解

JDK 21新特性详解&#xff1a;现代Java开发的重大更新 Java开发工具包(JDK)21作为最新的长期支持(LTS)版本&#xff0c;于2023年9月发布&#xff0c;带来了许多令人兴奋的新特性。作为Java开发者&#xff0c;了解这些新功能对于保持技术竞争力至关重要。本文将详细介绍JDK 21中…...

使用MCP驱动IDA pro分析样本

最近国外的牛人开发了一个ida pro的mcp server&#xff0c;项目的地址为mrexodia/ida-pro-mcp: MCP Server for IDA Pro&#xff0c;实现了通过自然对话来分析样本。 今天我们试用一下。 MCP Server for IDA Pro项目简介 这个mcp server提供下面这些工具&#xff0c;基本涵盖…...

Web前端开发:@media(媒体查询)

什么是媒体查询&#xff1f; 媒体查询是CSS3的一个功能&#xff0c;允许你根据设备的特性&#xff08;如屏幕宽度、设备方向、分辨率等&#xff09;应用不同的CSS样式。简单来说&#xff0c;就是让网页在不同设备上&#xff08;手机、平板、电脑&#xff09;自动调整布局和样式…...

psotgresql18 源码编译安装

环境&#xff1a; 系统&#xff1a;centos7.9 数据库&#xff1a;postgresql18beta1 #PostgreSQL 18 已转向 DocBook XML 构建体系&#xff08;SGML 未来将被弃用&#xff09;。需要安装 XML 工具链&#xff0c;如下&#xff1a; yum install -y docbook5-style-xsl libxsl…...

如何在VSCode中更换默认浏览器:完整指南

引言 作为前端开发者&#xff0c;我们经常需要在VSCode中快速预览HTML文件。默认情况下&#xff0c;VSCode会使用系统默认浏览器打开文件&#xff0c;但有时我们可能需要切换到其他浏览器进行测试。本文将详细介绍如何在VSCode中更换默认浏览器。 方法一&#xff1a;使用VSCo…...

Python Day26 学习

继续NumPy的学习 数组的索引 一维数组的索引 创建及输出 arr1d np.arange(10) # 数组: [0 1 2 3 4 5 6 7 8 9] arr1d array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]) 取出数组的第一个元素&#xff0c;最后一个元素 代码实现 arr1d[0] arr1d[-1] 取出数组中索引为3&#x…...

2025年PMP 学习二十一 14章 项目立项管理

2025年PMP 学习二十一 14章 项目立项管理 项目立项管理 项目建议 (Project Proposal)项目可行性分析 (Project Feasibility Analysis)项目审批 (Project Approval)项目招投标 (Project Tendering)项目合同谈判和签订 (Project Contract Negotiation and Signing) 文章目录 20…...

Ubuntu开机自启服务

一、准备启动脚本 在你的项目文件夹&#xff08;例如 /home/ubuntu/Plant_Diease_Recongnization_Server_1&#xff09;中创建一个启动脚本 run_ui_main.sh&#xff1a; #!/usr/bin/env bash # run_ui_main.sh&#xff1a;激活 yolov8 环境并启动 ui_main.py# 设置 Anaconda/…...

使用Docker部署React应用与Nginx

这个教程将帮助您使用Docker部署一个带有React的Nginx容器&#xff0c;并通过卷(volumes)将本地代码绑定到Docker容器中。这种设置非常适合开发环境&#xff0c;因为它允许您在本地编辑代码&#xff0c;而容器中的应用会自动更新。 步骤概述 创建Nginx配置文件创建Dockerfile…...

基于SpringBoot的小型民营加油站管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

Triton介绍和各平台支持情况分析

文章目录 &#x1f49e;Triton介绍&#x1f9e0; Triton 是什么&#xff1f;&#x1f50d; Triton 的核心特点&#x1f680; Triton 在 PyTorch 中的作用&#x1f4e6; Triton 的典型使用场景&#x1f9ea; 示例&#xff1a;Triton 编写的向量加法&#xff08;GPU 并行&#xf…...

HTTPS核心机制拆解

目录 引言 HTTPS和HTTP的区别 常见加密方式 数据摘要 数字证书与数据签名 HTTPS请求过程 结语 引言 HTTPS是什么&#xff1f;是一个应用层协议&#xff0c;在HTTP协议的基础上引入了一层加密层。为什么需要HTTPS&#xff1f;答案是显而易见的&#xff0c;要加密&#xf…...

我的食物信使女友

第一章&#xff1a;初识那是一个普通的周三下午&#xff0c;阳光透过咖啡馆的玻璃窗洒在木质的桌子上&#xff0c;空气中弥漫着咖啡的香气和轻柔的爵士乐。我坐在角落的一个位置&#xff0c;手中捧着一本已经翻了几十页的小说&#xff0c;但心思却完全不在文字上。我的生活就像…...

【D1,2】 贪心算法刷题

文章目录 不同路径 II整数拆分 不同路径 II 初始化的时候不能整列初始化为1&#xff0c;因为如果有障碍物&#xff0c;后面的都不能到达 也不能整列初始化为0&#xff0c;因为状态转移的时候第一行第一列都没有检查&#xff0c;因此不能部分初始化 整数拆分 需要考虑几种情况…...

C++多态的详细讲解

【本节目标】 1. 多态的概念 2. 多态的定义及实现 3. 抽象类 4. 多态的原理 5. 单继承和多继承关系中的虚函数表 前言 需要声明的&#xff0c;本博客中的代码及解释都是在 vs2013 下的 x86 程序中&#xff0c;涉及的指针都是 4bytes 。 如果要其他平台下&#xff0c;部…...

UE5在Blueprint中判断不同平台

在Unreal Engine 5的蓝图中&#xff0c;可以通过以下方法判断当前运行的平台&#xff08;如Android、Windows、iOS等&#xff09;&#xff0c;并根据平台执行不同的逻辑&#xff1a; 方法1&#xff1a;使用 Get Platform Name 节点 步骤&#xff1a; 在蓝图图表中右键点击&am…...

多卡跑ollama run deepseek-r1

# 设置环境变量并启动模型 export CUDA_VISIBLE_DEVICES0,1,2,3 export OLLAMA_SCHED_SPREAD1 # 启用多卡负载均衡 ollama run deepseek-r1:32b 若 deepseek-r1:32b 的显存需求未超过单卡容量&#xff08;如单卡 24GB&#xff09;&#xff0c;Ollama 不会自动启用多卡 在run…...

MAC电脑中右键后复制和拷贝的区别

在Mac电脑中&#xff0c;右键菜单中的“复制”和“拷贝”操作在功能上有所不同&#xff1a; 复制 功能&#xff1a;在选定的位置创建一个与原始文件相同的副本。快捷键&#xff1a;CommandD用于在当前位置快速复制文件&#xff0c;CommandC用于将内容复制到剪贴板。效果&…...

打卡第二十二天

知识点回顾&#xff1a; LDA线性判别PCA主成分分析t-SNE降维 还有一些其他的降维方式&#xff0c;也就是最重要的词向量的加工&#xff0c;我们未来再说。 作业&#xff1a; 自由作业&#xff1a;探索下什么时候用到降维&#xff1f;降维的主要应用&#xff1f;或者让AI给你出…...

【Unity 2023 新版InputSystem系统】新版InputSystem 如何进行人物移动(包括配置、代码详细实现过程)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、InputSystem配置二、GameInput 游戏输入脚本1.实现思路2.完整代码三、Player 游戏人物移动脚本1.实现思路2.完整代码四、场景脚本设置1.组件设置五、问题解决1.人物一直下落2.人物跳跃时,…...

Python实现的在线词典学习工具

Python实现的在线词典学习工具 源码最初来自网络&#xff0c;根据实际情况进行了修改。 主要功能&#xff1a; 单词查询 通过Bing词典在线获取单词释义&#xff08;正则提取网页meta描述&#xff09;&#xff0c;支持回车键快速查询 内置网络请求重试和异常处理机制 在线网页…...

软考 系统架构设计师系列知识点之杂项集萃(63)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之杂项集萃&#xff08;62&#xff09; 第102题 以下关于系统性能评估方法的描述&#xff0c;错误的是&#xff08;&#xff09;。 A. 指令执行速度法常用每秒百万次指令运算&#xff08;MIPS&#xff09;评估系统性能…...

python重庆旅游系统-旅游攻略

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…...

如何使用GIT管理项目代码

介绍 ​ Git是目前世界上最流行甚至最好的开源分布式版本控制系统&#xff0c;不论是很小的项目还是很大的项目&#xff0c;它都能有效并且高效的处理项目版本管理&#xff0c;初衷是为了帮助管理linux内核代码而开发的一个开放源码的版本控制软件。 GIT常用分支名称 分支分…...

Android 11.0 动画缩放默认值改为0.5的功能实现

1.前言 在11.0的系统rom定制化开发中,在关于设置动画的时候,系统有相关参数要求,设置默认的 动画缩放默认值等功能,来实现相关功能,接下来分析下相关的动画默认缩放值的设置功能实现 2.动画缩放默认值改为0.5的功能实现的核心类 frameworks/base/packages/SettingsProv…...

第35周Zookkeeper+Dubbo 面试题精讲

面试题精讲 一、算法面试答题思路 理解思路的重要性:算法面试比基础面试更复杂,需先想清楚思路,与面试官沟通确认题目条件(如数据范围、是否包含负数/零等),这有助于理清解题思路并展示技术实力。变量命名清晰:算法中变量命名要明确含义和范围,避免使用模糊的变量名,…...

Mergekit——任务向量合并算法Ties解析

Mergekit——高频合并算法 TIES解析 Ties背景Ties 核心思想具体流程总结 mergekit项目地址 Mergekit提供模型合并方法可以概况为三大类&#xff1a;基本线性加权、基于球面插值、基于任务向量&#xff0c;今天我们来刷下基于任务向量的ties合并方法&#xff0c;熟悉原理和代码。…...

初识 Redis

什么是 Redis&#xff1f; 在 Redis 官网中有介绍&#xff0c; Redis 就是一个存储空间&#xff0c;只不过这个存储空间是在内存上的&#xff0c;这也就代表存储在 Redis 中的数据访问起来会非常快&#xff0c;但也会有一个弊端&#xff0c;也就是内存资源是非常少的&#xff…...

python打卡训练营打卡记录day30

一、导入官方库 我们复盘下学习python的逻辑&#xff0c;所谓学习python就是学习python常见的基础语法学习你所处理任务需要用到的第三方库。 1.1标准导入&#xff1a;导入整个库 这是最基本也是最常见的导入方式&#xff0c;直接使用import语句。 # 方式1&#xff1a;导入整…...

FART 主动调用组件设计和源码分析

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ 现有脱壳方法存在的问题 脱壳粒度集中在 DexFile 整体&#xff0c;当前对 apk 保护的粒度在函数粒度&#xff0c;这就导致了脱壳与加固的不对等&#xff0c;无…...

windows使用ollama部署deepseek及qwen

ollama 参考文档 ollama 官方文档 GitHub仓库 基础环境&#xff1a; NVIDIA 1660TI 6G 下载 ollma是一款开源工具&#xff0c;支持在本地计算机&#xff08;无需联网&#xff09;快速部署和运行大型语言模型&#xff08;LLM&#xff09;&#xff0c;如 LLaMA、Mistral、G…...