【云原生】Spring Cloud Gateway的底层原理与实践方法探究

 🎉🎉欢迎光临🎉🎉

🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀

🌟特别推荐给大家我的最新专栏《Spring 狂野之旅:从入门到入魔》 🚀

本专栏带你从Spring入门到入魔!

这是苏泽的个人主页可以看到我其他的内容哦👇👇

努力的苏泽icon-default.png?t=N7T8http://suzee.blog.csdn.net/

目录

引言

介绍API网关和其在云原生应用中的重要性

        概述Spring Cloud Gateway作为API网关的特点和优势

Spring Cloud Gateway简介:

网关路由器(Gateway Router)

过滤器(Filters)

负载均衡器(Load Balancer)

Spring Cloud Gateway的底层原理

Reactor模式

网络I/O模型

动态路由

实践方法:使用Spring Cloud Gateway构建API网关

创建Spring Cloud Gateway项目的步骤和依赖配置:

实现基本的路由配置和请求转发:

应用过滤器实现请求鉴权和日志记录:

配置负载均衡器以实现服务的负载均衡:

性能调优和扩展

1. 缓存机制

在上述示例中,@Cacheable注解指定了缓存的名称为"myCache",并以param作为缓存的键。如果相同的param参数被重复调用,将直接从缓存中获取数据,而不是访问后端服务。

2. 熔断器

3. 高可用部署


  1. 引言

    • 介绍API网关和其在云原生应用中的重要性

      在云原生应用中,API网关是一个关键的组件,用于提供统一的入口点和访问控制,以便对后端微服务进行路由、负载均衡、安全认证等操作。API网关充当了客户端和后端服务之间的门户,简化了客户端与服务之间的通信,并提供了一些重要的功能和特性,如请求转发、认证授权、监控和限流等。

        概述Spring Cloud Gateway作为API网关的特点和优势

Spring Cloud Gateway是Spring Cloud生态系统中的一个API网关组件,它基于Spring Framework 5、Spring Boot 2和Reactor等技术栈构建而成。Spring Cloud Gateway具有以下特点和优势:

  1. 基于非阻塞式编程模型:Spring Cloud Gateway使用了基于响应式编程的Reactor库,使得它可以处理大量并发请求而不阻塞线程,提高了性能和吞吐量。

  2. 动态路由:Spring Cloud Gateway支持动态路由配置,可以根据请求的路径、参数、标头等信息来动态地将请求路由到不同的后端服务。

  3. 过滤器链:Spring Cloud Gateway采用过滤器链的方式,可以在请求进入网关和响应离开网关时应用各种过滤器,如认证、鉴权、请求转换、限流等。

  4. 集成性:Spring Cloud Gateway与Spring Cloud生态系统中的其他组件无缝集成,如服务发现与注册(Eureka、Consul)、负载均衡(Ribbon)、断路器(Hystrix)等。

  5. 可插拔的架构:Spring Cloud Gateway的架构设计可插拔,可以根据需求扩展和定制各种功能和组件,使其更加灵活和可扩展。

Spring Cloud Gateway简介:

Spring Cloud Gateway是一个基于Spring Framework 5和Spring Boot 2的API网关组件,它提供了一种简单而强大的方式来管理和路由微服务的请求。Spring Cloud Gateway的核心概念包括路由(Route)、断言(Predicate)和过滤器(Filter)。

  1. 路由(Route):路由定义了请求的目标地址和规则,包括目标URL、请求谓词(如GET、POST)、请求头、请求参数等。通过配置多个路由规则,可以将请求转发到不同的后端服务。

  2. 断言(Predicate):断言用于匹配请求的条件,只有满足条件的请求才会被路由到相应的后端服务。断言可以基于请求的路径、参数、标头等信息进行匹配。

  3. 过滤器(Filter):过滤器用于在请求进入网关和响应离开网关时进行处理,如认证、鉴权、请求转换、限流等。Spring Cloud Gateway提供了一系列内置的过滤器,同时也支持自定义过滤器。

Spring Cloud Gateway与传统的反向代理服务器的区别:

传统的反向代理服务器(如Nginx、Apache HTTP Server)通常是基于阻塞I/O模型实现的,每个请求都会占用一个线程,从而限制了系统的并发能力。而Spring Cloud Gateway采用了基于响应式编程的非阻塞I/O模型,可以处理大量并发请求而不阻塞线程,提高了性能和吞吐量。

另外,Spring Cloud Gateway具有动态路由和过滤器链的特性,可以根据请求的各种属性进行动态路由和处理。这使得Spring Cloud Gateway更加灵活和可扩展,可以根据需求进行定制化开发,满足不同场景下的需求。与传统的反向代理服务器相比,Spring Cloud Gateway在功能和性能上都具有更大的优势。

网关路由器(Gateway Router)

网关路由器是Spring Cloud Gateway的核心组件之一,它负责将客户端的请求路由到相应的后端服务。网关路由器基于配置信息来进行路由规则的匹配和转发。我们可以通过配置文件(如application.yml)或编程方式来定义路由规则。

以下是一个简单的示例代码,演示如何通过配置文件定义路由规则:

spring:cloud:gateway:routes:- id: my_routeuri: http://example.compredicates:- Path=/api/**

上述代码中,我们定义了一个名为my_route的路由规则,将匹配路径为/api/**的请求转发到http://example.com

过滤器(Filters)

过滤器是Spring Cloud Gateway的另一个核心组件,它提供了一种灵活的机制来处理请求和响应。过滤器可以用于修改请求或响应的内容、添加头信息、进行安全验证等操作。Spring Cloud Gateway内置了许多常用的过滤器,同时也支持自定义过滤器。

以下是一个示例代码,展示了如何使用过滤器进行请求转发前的预处理:

@Component
public class CustomFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 在请求转发前进行预处理// 可以修改请求信息、添加头信息等操作ServerHttpRequest modifiedRequest = exchange.getRequest().mutate().header("X-Custom-Header", "Custom Value").build();ServerWebExchange modifiedExchange = exchange.mutate().request(modifiedRequest).build();return chain.filter(modifiedExchange);}
}

 上述代码中,我们定义了一个自定义的过滤器CustomFilter,在filter方法中可以进行请求的修改和处理。在这个示例中,我们添加了一个自定义的头信息X-Custom-Header

负载均衡器(Load Balancer)

负载均衡器是Spring Cloud Gateway的另一个重要组件,它用于在后端服务之间分发请求,实现负载均衡的功能。Spring Cloud Gateway通过集成Spring Cloud LoadBalancer来实现负载均衡的机制。

以下是一个示例代码,展示了如何配置负载均衡器:

@Configuration
public class LoadBalancerConfiguration {@Beanpublic LoadBalancerClient loadBalancerClient() {return LoadBalancerClientFactory.getDefaultClient();}
}

上述代码中,我们通过LoadBalancerClientFactory.getDefaultClient()方法获取了默认的负载均衡器客户端。

Spring Cloud Gateway的底层原理

Reactor模式

Spring Cloud Gateway使用了Reactor模式来实现异步和非阻塞的处理。Reactor模式基于事件驱动和回调机制,通过使用Flux和Mono这两个反应式类型,实现了高效的请求处理和响应。

网络I/O模型

Spring Cloud Gateway支持多种网络I/O模型,如阻塞I/O、非阻塞I/O和异步I/O。它可以根据具体的需求选择适合的网络I/O模型。在性能优化方面,Spring Cloud Gateway使用了Netty作为底层服务器,以实现高性能的网络通信。

动态路由

Spring Cloud Gateway支持动态路由,它允许在运行时动态添加、修改和删除路由规则。这使得我们可以根据需求动态调整网关的路由策略,而无需重启应用程序。

动态路由的实现原理是通过与服务注册中心(如Eureka、Consul等)集成,监听服务的注册和注销事件,然后根据这些事件动态更新路由规则。这样,当有新的服务注册或注销时,Spring Cloud Gateway可以相应地调整路由规则,以确保请求能够正确地路由到新的服务实例。

以下是一个示例代码,展示了如何通过服务注册中心实现动态路由:

@Configuration
public class DynamicRoutingConfiguration {@Autowiredprivate DiscoveryClient discoveryClient;@Beanpublic RouteDefinitionLocator routeDefinitionLocator() {return new DiscoveryClientRouteDefinitionLocator(discoveryClient);}
}

上述代码中,我们通过DiscoveryClientRouteDefinitionLocator从服务注册中心获取路由定义,实现了动态路由的功能。

 

实践方法:使用Spring Cloud Gateway构建API网关

下面将使用一个具体的项目示例来说明如何使用Spring Cloud Gateway构建API网关。

创建Spring Cloud Gateway项目的步骤和依赖配置:

首先,创建一个Spring Boot项目,并添加必要的依赖。

步骤:

  • 使用Spring Initializr创建一个新的Spring Boot项目。
  • 在项目的pom.xml文件中添加以下依赖:

<dependencies><!-- Spring Cloud Gateway --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!-- 其他依赖... -->
</dependencies>
实现基本的路由配置和请求转发:

在Spring Cloud Gateway项目中,可以通过配置文件或编程方式进行路由配置和请求转发。

  • 配置文件方式:在项目的配置文件(如application.yml)中进行路由配置。
# application.yml
spring:cloud:gateway:routes:- id: route1uri: http://localhost:8081  # 转发到后端服务的地址predicates:- Path=/api/service1/**  # 匹配请求路径的条件- id: route2uri: http://localhost:8082predicates:- Path=/api/service2/**
  • 编程方式:编写配置类来进行路由配置。
@Configuration
public class GatewayConfiguration {@Beanpublic RouteLocator customRouteLocator(RouteLocatorBuilder builder) {return builder.routes().route("route1", r -> r.path("/api/service1/**").uri("http://localhost:8081")).route("route2", r -> r.path("/api/service2/**").uri("http://localhost:8082")).build();}
}
应用过滤器实现请求鉴权和日志记录:

Spring Cloud Gateway的过滤器功能可以用于实现请求鉴权、日志记录等需求。

  • 创建一个过滤器来实现请求鉴权:
@Component
public class AuthFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 实现请求鉴权逻辑// 如果鉴权失败,可以返回错误响应或重定向到登录页面// 鉴权通过,继续执行后续的过滤器和路由处理return chain.filter(exchange);}
}
  • 创建一个过滤器来实现日志记录:
@Component
public class LoggingFilter implements GlobalFilter {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 实现日志记录逻辑// 可以记录请求的路径、方法、参数等信息// 继续执行后续的过滤器和路由处理return chain.filter(exchange);}
}
配置负载均衡器以实现服务的负载均衡:

Spring Cloud Gateway可以与负载均衡组件(如Ribbon)结合使用,实现对后端服务的负载均衡。

  • 配置Ribbon负载均衡器:
@Configuration
public class RibbonConfiguration {@Bean@LoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}
}
  • 在路由配置中使用负载均衡器:
@Configuration
public class GatewayConfiguration {@Autowiredprivate RestTemplate restTemplate;@Beanpublic RouteLocator customRouteLocator(RouteLocatorBuilder builder) {return builder.routes().route("route1", r -> r.path("/api/service1/**").uri("lb://service1"))  // 使用负载均衡器,实现对service1服务的负载均衡.route("route2", r -> r.path("/api/service2/**").uri("lb://service2")).build();}
}

以上项目使用Spring Cloud Gateway构建API网关的基本步骤和配置。

性能调优和扩展

1. 缓存机制

缓存机制是提高性能的有效手段之一。在Spring Cloud Gateway中,你可以使用缓存来减少对后端服务的请求次数。以下是使用缓存的基本步骤:

  • 引入所需的依赖项:在pom.xml文件中添加以下依赖项,以支持缓存功能。
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId>
</dependency>
  • 配置缓存管理器:在配置类中添加@EnableCaching注解,启用缓存功能,并配置缓存管理器。
@Configuration
@EnableCaching
public class CacheConfig {@Beanpublic CacheManager cacheManager() {return new ConcurrentMapCacheManager("myCache");}
}

在上述示例中,我们使用ConcurrentMapCacheManager作为缓存管理器,并创建了一个名为"myCache"的缓存。

  • 使用缓存注解:在需要缓存的方法上添加@Cacheable注解,指定缓存的名称和缓存的键。
@RestController
public class MyController {@GetMapping("/data")@Cacheable(cacheNames = "myCache", key = "#param")public String getData(@RequestParam String param) {// 从后端服务获取数据的逻辑return data;}
}
在上述示例中,@Cacheable注解指定了缓存的名称为"myCache",并以param作为缓存的键。如果相同的param参数被重复调用,将直接从缓存中获取数据,而不是访问后端服务。

2. 熔断器

熔断器是一种用于提高系统稳定性的机制,当后端服务出现故障或超时时,可以快速失败并返回预设的错误响应,避免系统崩溃。在Spring Cloud Gateway中,你可以使用Hystrix来实现熔断器的功能。以下是使用熔断器的基本步骤:

  • 引入所需的依赖项:在pom.xml文件中添加以下依赖项,以支持Hystrix和熔断器功能。
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
  • 使用熔断器注解:在需要使用熔断器的方法上添加@HystrixCommand注解,指定熔断器的配置和处理逻辑。
@RestController
public class MyController {@GetMapping("/data")@HystrixCommand(fallbackMethod = "fallback")public String getData() {// 调用后端服务获取数据的逻辑return data;}public String fallback() {return "Fallback response";}
}

在上述示例中,@HystrixCommand注解指定了熔断器的回退方法为fallback()。当调用后端服务的逻辑出现故障时,将执行回退方法并返回预设的响应。

3. 高可用部署

将Spring Cloud Gateway部署为高可用的架构是确保系统可靠性和容错性的重要措施。以下是探讨将Spring Cloud Gateway部署为高可用架构的一些建议:

  • 使用负载均衡:使用负载均衡器将请求分发到多个Spring Cloud Gateway实例。可以使用诸如Nginx、HAProxy等负载均衡工具来实现。这样可以提高系统的吞吐量和可扩展性。
     

    • 首先,你需要安装和配置一个负载均衡器,比如Nginx或HAProxy。这里以Nginx为例。

    • 编辑Nginx配置文件,将请求分发到多个Spring Cloud Gateway实例。以下是一个简单的Nginx配置示例:

      http {upstream gateway {server gateway1.example.com:8080;server gateway2.example.com:8080;server gateway3.example.com:8080;}server {listen 80;server_name mydomain.com;location / {proxy_pass http://gateway;}}
      }

  • 高可用的注册中心:确保注册中心(如Eureka、Consul等)也是高可用的部署。这样可以保证Spring Cloud Gateway实例能够及时注册和发现服务。
     

    • 首先,你需要搭建一个高可用的注册中心,比如Eureka或Consul。这里以Eureka为例。

    • 在Spring Cloud Gateway项目的配置文件中,配置Eureka注册中心的地址和其他相关配置。以下是一个简单的配置示例:

      spring.application.name=gateway-service
      server.port=8080eureka.client.serviceUrl.defaultZone=http://eureka1.example.com:8761/eureka,http://eureka2.example.com:8761/eureka
      eureka.instance.prefer-ip-address=true

  • 异地多活部署:在不同的地理位置部署多个Spring Cloud Gateway实例,以提高系统的容灾能力。这样即使某个地区的实例发生故障,其他地区的实例仍然可以正常提供服务。
     

    • 在不同的地理位置部署多个Spring Cloud Gateway实例。

    • 配置每个实例的注册中心地址和其他相关配置。以下是一个简单的配置示例:

      spring.application.name=gateway-service
      server.port=8080eureka.client.serviceUrl.defaultZone=http://eureka1.example.com:8761/eureka,http://eureka2.example.com:8761/eureka
      eureka.instance.prefer-ip-address=true

  • 监控和日志:使用监控和日志工具来实时监测和记录Spring Cloud Gateway的运行状态和日志。这样可以及时发现和解决潜在的问题,提高系统的稳定性和可维护性。

    • 使用Spring Boot Actuator模块提供的监控和管理功能。在Spring Cloud Gateway项目的配置文件中,配置Actuator端点的相关配置。以下是一个简单的配置示例:
      management.endpoints.web.exposure.include=*
      management.endpoint.health.show-details=always

      在上述示例中,management.endpoints.web.exposure.include配置了暴露所有的Actuator端点,management.endpoint.health.show-details配置了健康检查端点显示详细信息。

    • 配置日志框架,如Logback或Log4j,以记录Spring Cloud Gateway的运行状态和日志。以下是一个简单的Logback配置示例:
      <configuration><appender name="console" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><logger name="org.springframework.cloud.gateway" level="INFO" additivity="false"><appender-ref ref="console" /></logger><root level="INFO"><appender-ref ref="console" /></root>
      </configuration>

      配置了一个名为"console"的控制台输出日志的appender,并将Spring Cloud Gateway的日志级别设置为INFO。

  • 异常处理和降级策略:定义合适的异常处理和降级策略,当后端服务出现故障或网络问题时,能够快速失败或返回预设的响应,避免系统崩溃。
     

    在Spring Cloud Gateway中,你可以通过定义全局过滤器或针对特定路由的过滤器来实现异常处理和降级策略。以下是一个简单的示例:

    • 创建一个全局异常处理器的过滤器类:
      import org.springframework.cloud.gateway.filter.GatewayFilterChain;
      import org.springframework.cloud.gateway.filter.GlobalFilter;
      import org.springframework.core.Ordered;
      import org.springframework.http.HttpStatus;
      import org.springframework.web.server.ServerWebExchange;
      import reactor.core.publisher.Mono;public class ExceptionHandlingFilter implements GlobalFilter, Ordered {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {return chain.filter(exchange).onErrorResume(throwable -> {exchange.getResponse().setStatusCode(HttpStatus.INTERNAL_SERVER_ERROR);return exchange.getResponse().setComplete();});}@Overridepublic int getOrder() {return Ordered.LOWEST_PRECEDENCE;}
      }

      在上述示例中,ExceptionHandlingFilter是一个实现了GlobalFilter接口的全局过滤器。它会捕获所有的异常并将响应的状态码设置为500。

    • 在Spring Cloud Gateway的配置类中注册该过滤器:
      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;@Configuration
      public class GatewayConfig {@Beanpublic ExceptionHandlingFilter exceptionHandlingFilter() {return new ExceptionHandlingFilter();}
      }

      GatewayConfig是一个Spring配置类,通过@Bean注解将ExceptionHandlingFilter注册为一个Bean。

 

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

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

相关文章

fly-barrage 前端弹幕库(2):弹幕内容支持混入渲染图片的设计与实现

如果弹幕内容只支持文字的话&#xff0c;只需要借助 canvas 绘图上下文的 fillText 方法就可以实现功能了。 但如果想同时支持渲染图片和文字的话&#xff0c;需要以下几个步骤&#xff1a; 设计一个面向用户的数据结构&#xff0c;用于描述弹幕应该渲染哪些文字和图片&#x…

应急响应-常规处置办法

网站中被植入Webshell&#xff0c;通常代表着网站中存在可利用的高危漏洞&#xff0c;攻击者利用这些漏洞&#xff0c;将Webshell写入网站&#xff0c;从而获取网站的控制权。一旦在网站中发现webshell文件&#xff0c;可采取以下步骤进行临时处置。 入侵确定时间 通过在网站…

迅为RK3568开发板驱动开发指南-输入子系统

《iTOP-RK3568开发板驱动开发指南》更新&#xff0c;本次更新内容对应的是驱动&#xff08;第十三篇 输入子系统&#xff09;视频&#xff0c;帮助用户快速入门&#xff0c;大大提升研发速度。 第13篇-输入子系统目录 第1篇 驱动基础篇 第2篇 字符设备基础 第3篇 并发与竞争 …

解决gogs勾选“使用选定的文件和模板初始化仓库”报错500,gogs邮件发送失败,gogs邮件配置不生效,gogs自定义模板等问题

解决gogs勾选“使用选定的文件和模板初始化仓库”报错500,gogs邮件发送失败,gogs邮件配置不生效,gogs自定义模板等问题 前几天出了教程本地部署gogs&#xff0c;在后期运行时发现两个问题&#xff1a; 第一&#xff1a;邮件明明配置了&#xff0c;后台显示未配置&#xff0c;…

这家宠物品牌的内容运营怎么做的?太好玩儿了吧

养宠的朋友应该多多少少对“诚实一口”这个牌子有所耳闻&#xff0c;2018年诚实一口品牌正式立项&#xff0c;虽然不算经典品牌&#xff0c;但在国内也是小有名气的宠物品牌。今天媒介盒子想和大家聊的不是产品&#xff0c;而是想聊聊作为成立时间不长的国产宠粮品牌是如何凭借…

【数据结构】栈OJ题《用栈实现队列》(题库+解析+代码)

1. 前言 通过前面栈的实现和详解大家对队列应该有一定熟悉了&#xff0c;现在上强度开始做题吧 栈详解&#xff1a;http://t.csdnimg.cn/9Fsbs 本体的做题思路也可以参考上一篇文章&#xff0c;就是有一点点不同。 用队列实现栈&#xff1a;http://t.csdnimg.cn/V2qjW 2. …

小型内衣裤洗衣机哪个牌子好?四大顶尖内衣洗衣机测评分享

要知道&#xff0c;内衣裤可能会残留我们身体分泌的尿液&#xff0c;或者是没有擦干净的便便&#xff0c;以及其他的一些分泌物&#xff0c;据科学家研究发现&#xff0c;内衣裤是含有很多细菌和病毒的地方&#xff0c;如果将内衣裤和衣服放在一起洗&#xff0c;导致这些细菌附…

Docker基础篇(六) dockerfile体系结构语法

FROM&#xff1a;基础镜像&#xff0c;当前新镜像是基于哪个镜像的 MAINTAINER &#xff1a;镜像维护者的姓名和邮箱地址 RUN&#xff1a;容器构建时需要运行的命令 EXPOSE &#xff1a;当前容器对外暴露出的端口号 WORKDIR&#xff1a;指定在创建容器后&#xff0c;终端默认登…

《Docker 简易速速上手小册》第4章 Docker 容器管理(2024 最新版)

文章目录 4.1 容器生命周期管理4.1.1 重点基础知识4.1.2 重点案例&#xff1a;启动并管理 Python Flask 应用容器4.1.3 拓展案例 1&#xff1a;调试运行中的容器4.1.4 拓展案例 2&#xff1a;优雅地停止和清理容器 4.2 容器数据管理与持久化4.2.1 重点基础知识4.2.2 重点案例&a…

C++力扣题目 42--接雨水 84--柱状图中最大的矩形

42. 接雨水 力扣题目链接(opens new window) 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 示例 1&#xff1a; 输入&#xff1a;height [0,1,0,2,1,0,1,3,2,1,2,1]输出&#xff1a;6解释&#xff…

一键解锁本地大型语言模型!Ollama框架让你轻松运行Gemma

想要在本地运行大型语言模型吗&#xff1f; Ollama框架提供了这样的机会。 这个框架是专为在Docker容器中部署LLM而设计的&#xff0c;简化了部署和管理流程。 安装Ollama后&#xff0c;你只需执行一条命令&#xff0c;即可在本地运行开源大型语言模型。 它将模型权重、配置…

Less预处理器教程

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes 觉得有帮助的同学&#xff0c;可以点心心支持一下哈 一、Less介绍 less官方文档 lesscss.org/ less中文文档 less.bootcss.com/ less是一种css预处理器&#xff0c;它扩展了css语言&#xff0c…

Docker复习笔记

Centos7安装Docker Docker官网:www.docker.com Docker官网仓库:hub.docker.com Docker文档是比较详细的 安装相关依赖 yum -y install gcc gcc-c yum install -y yum-utils 设置docker镜像仓库 yum-config-manager --add-repo https://download.docker.com/linux/centos/do…

OpenCV开发笔记(七十五):相机标定矫正中使用remap重映射进行畸变矫正

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://blog.csdn.net/qq21497936/article/details/136293833 各位读者&#xff0c;知识无穷而人力有穷&#xff0c;要么改需求&#xff0c;要么找专业人士&#xff0c;要么自己研究 红胖子(红模仿…

网络设备和网络软件

文章目录 网络设备和网络软件网卡交换机交换机的三个主要功能交换机的工作原理第二层交换和第三层交换交换机的堆叠和级联 路由器路由器工作原理 网关网关的分类 无线接入点(AP)调制解调器网络软件 网络设备和网络软件 网卡 网络接口卡又称网络适配器&#xff0c;简称网卡。网…

【计算机网络】数据链路层--以太网/MTU/ARP/RARP协议

文章目录 一、以太网1.以太网帧格式2.MAC地址3.局域网的转发原理 二、MTU1.什么是MTU2.MTU对IP协议的影响3.MTU对UDP影响4.MTU对于TCP协议的影响 三、ARP协议1.ARP协议的作用2.ARP数据报的格式3.ARP协议的工作流程 一、以太网 “以太网” 不是一种具体的网络, 而是一种技术标准…

论文阅读:《High-Resolution Image Synthesis with Latent Diffusion Models》

High-Resolution Image Synthesis with Latent Diffusion Models 论文链接 代码链接 What’s the problem addressed in the paper?(这篇文章究竟讲了什么问题&#xff1f;比方说一个算法&#xff0c;它的 input 和 output 是什么&#xff1f;问题的条件是什么) 这篇文章提…

音视频剪辑|Windows|抽帧和合帧

什么是抽帧&#xff1f; FFmpeg 抽帧&#xff08;Extracting frames&#xff09;的作用是从视频文件中按需提取单张或多张静止图像&#xff08;帧&#xff09;&#xff0c;并将它们保存为图片文件&#xff08;如 JPEG、PNG 等格式&#xff09;。这一功能在以下场合十分有用&am…

Python服务器监测测试策略与工具:确保应用的高可用性!

在构建高可用性的应用程序时&#xff0c;服务器监测测试是至关重要的一环。Python作为一种强大的编程语言&#xff0c;提供了丰富的工具和库来帮助我们进行服务器监测测试。本文将介绍一些关键的策略和工具&#xff0c;帮助你确保应用的高可用性。 1. 监测策略的制定&#xff…

Vue3 (unplugin-auto-import自动导入的使用)

安装 参考链接 npm i -D unplugin-auto-importvite.config.ts里面配置 import AutoImport from unplugin-auto-import/viteAutoImport({imports:[ vue,vue-router]})重新运行项目会生成一个auto-imports.d.ts的文件 /* eslint-disable */ /* prettier-ignore */ // ts-nochec…