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

Fastapi 日志处理

uvicorn 日志处理总结:

一、日志的结构

日志结构如下:

{"version": 1,"disable_existing_loggers": false,"formatters": {},"handlers": {},"loggers": {}
}

loggers 用于定义日志处理最顶层的标识,必须有一个uvicorn,是所有日志处理的父类

handlers用于日志输出目的地配置,如输出到终端、文件等

formatters用于日志具体格式的配置,如时间戳、请求类型、状态码等

二、logger中配置的继承关系

logger中存在继承关系,uvicorn是父类,uvicorn.error是子类 uvicorn也是子类。子类可以继承父类的配置,比如uvicorn.error没有配置handlers,那么就会继承uvicorn的配置。

uvicorn 记录器会处理所有 Uvicorn 生成的日志,包括错误日志。

"uvicorn": {"handlers": ["default", "default_file"],"level": "INFO","propagate": false},"uvicorn.error": {"level": "INFO"},"uvicorn.access": {"handlers": ["access", "access_file"],"level": "INFO","propagate": false}}

三、formatters 中的两种错误日志

formatters 中包含两种日志格式:default 和 access,两者功能不同。这两者是uvicorn默认,也可以自定义其他格式。

  • default: 用于记录 Uvicorn 的常规日志,包括服务器启动、停止、错误信息等。
  • access:用于记录 HTTP 请求的访问日志,包括客户端 IP、请求方法、请求路径、响应状态码等。

四、错误日志

uvicorn 会在default中将所有的日志都输出,包括错误日志。如果想单独处理错误日志,可以在loggers中定义错误日志记录器uvicorn.error,然后在handlers中指定错误日志的输出目的地,最后使用default格式输出。可以选择将错误日志同时输出到uvicorn和uvicorn.error两个记录器中,也可以选择只输出到uvicor.error记录器中。

uvicorn 日志系统

Uvicorn 的日志配置文件可以使用 JSON、YAML 或 INI 三种格式。以下是对 Uvicorn 日志配置文件的详细解析:

1. 基本结构

Uvicorn 的日志配置文件遵循 Python 的 logging 模块的配置格式,其基本结构如下:

{"version": 1,"disable_existing_loggers": false,"formatters": {},"handlers": {},"loggers": {}
}

2. 配置项详解

2.1 version
  • 类型: 整数
  • 默认值: 1
  • 说明: 指定配置文件的版本,目前 Uvicorn 只支持版本 1。
2.2 disable_existing_loggers
  • 类型: 布尔值
  • 默认值: false
  • 说明: 是否禁用已存在的日志记录器。如果设置为 true,则会禁用所有已存在的日志记录器,除非它们在 loggers 部分被显式配置。
2.3 formatters
  • 类型: 字典
  • 说明: 定义日志格式化器,用于格式化日志消息。每个格式化器是一个字典,包含以下键:
    • (): 指定格式化器类的路径。
    • fmt: 日志格式字符串。
    • datefmt: 日期格式字符串(可选)。
    • style: 格式化风格,可以是 %{$(可选)。

例如:

"formatters": {"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null},"access": {"()": "uvicorn.logging.AccessFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s %(client_addr)s - '%(request_line)s' %(status_code)s"}
}
2.4 handlers
  • 类型: 字典
  • 说明: 定义日志处理器,用于将日志消息输出到不同的目的地。每个处理器是一个字典,包含以下键:
    • class: 指定处理器类的路径。
    • formatter: 指定使用的格式化器名称。
    • stream: 指定输出流(对于 StreamHandler)。
    • filename: 指定日志文件路径(对于 FileHandlerTimedRotatingFileHandler)。
    • when: 指定日志文件轮转的时间间隔(对于 TimedRotatingFileHandler)。
    • backupCount: 指定备份文件的数量(对于 TimedRotatingFileHandler)。
    • encoding: 指定文件编码(可选)。

例如:

"handlers": {"default": {"formatter": "default","class": "logging.StreamHandler","stream": "ext://sys.stderr"},"default_file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/app.log","when": "midnight","encoding": "utf-8","backupCount": 10},"access": {"formatter": "access","class": "logging.StreamHandler","stream": "ext://sys.stdout"},"access_file": {"formatter": "access","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/access.log","when": "midnight","encoding": "utf-8","backupCount": 10}
}
2.5 loggers
  • 类型: 字典
  • 说明: 定义日志记录器,用于控制日志的输出。每个记录器是一个字典,包含以下键:
    • handlers: 指定使用的处理器名称列表。
    • level: 指定日志级别,如 INFODEBUGERROR 等。
    • propagate: 是否将日志消息传递给父记录器。

例如:

"loggers": {"uvicorn": {"handlers": ["default", "default_file"],"level": "INFO","propagate": false},"uvicorn.error": {"level": "INFO"},"uvicorn.access": {"handlers": ["access", "access_file"],"level": "INFO","propagate": false}
}

3. 示例配置文件

以下是一个完整的 Uvicorn 日志配置文件示例,将日志输出到控制台和本地文件:

{"version": 1,"disable_existing_loggers": false,"formatters": {"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null},"access": {"()": "uvicorn.logging.AccessFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s %(client_addr)s - '%(request_line)s' %(status_code)s"}},"handlers": {"default": {"formatter": "default","class": "logging.StreamHandler","stream": "ext://sys.stderr"},"default_file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/app.log","when": "midnight","encoding": "utf-8","backupCount": 10},"access": {"formatter": "access","class": "logging.StreamHandler","stream": "ext://sys.stdout"},"access_file": {"formatter": "access","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/access.log","when": "midnight","encoding": "utf-8","backupCount": 10}},"loggers": {"uvicorn": {"handlers": ["default", "default_file"],"level": "INFO","propagate": false},"uvicorn.error": {"level": "INFO"},"uvicorn.access": {"handlers": ["access", "access_file"],"level": "INFO","propagate": false}}
}

4. 使用配置文件

在启动 Uvicorn 时,可以通过 --log-config 参数指定日志配置文件的路径。例如:

uvicorn run:app --host 0.0.0.0 --port 8000 --log-config ./uvicorn_config.json

或者在 Python 代码中使用 uvicorn.run 方法:

import uvicornif __name__ == "__main__":uvicorn.run(app='main:app', host="0.0.0.0", log_config='./uvicorn_config.json', port=8000, loop="asyncio")

希望这些信息对你有所帮助!

default 和 access 日志处理器

在 Uvicorn 中,defaultaccess 日志格式化器(formatter)的主要区别在于它们记录的内容和用途:

1. default 格式化器

  • 用途: 用于记录 Uvicorn 的常规日志,包括服务器启动、停止、错误信息等。
  • 内容: 通常包含日志级别、时间戳、线程名称、日志消息等。
  • 示例格式:
"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null
}

这里,%(asctime)s 表示时间戳,%(threadName)s 表示线程名称,%(levelprefix)s 表示日志级别前缀,%(message)s 表示日志消息。

2. access 格式化器

  • 用途: 用于记录 HTTP 请求的访问日志,包括客户端 IP、请求方法、请求路径、响应状态码等。
  • 内容: 通常包含客户端 IP 地址、请求行、响应状态码等。
  • 示例格式:
"access": {"()": "uvicorn.logging.AccessFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s %(client_addr)s - '%(request_line)s' %(status_code)s"
}

这里,%(asctime)s 表示时间戳,%(threadName)s 表示线程名称,%(levelprefix)s 表示日志级别前缀,%(client_addr)s 表示客户端 IP 地址,%(request_line)s 表示请求行(如 GET /path HTTP/1.1),%(status_code)s 表示响应状态码。

3. 配置示例

以下是一个完整的 Uvicorn 日志配置文件示例,展示了如何配置 defaultaccess 日志格式化器,并将它们分别输出到不同的处理器(handlers)和日志记录器(loggers):

{"version": 1,"disable_existing_loggers": false,"formatters": {"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null},"access": {"()": "uvicorn.logging.AccessFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s %(client_addr)s - '%(request_line)s' %(status_code)s"}},"handlers": {"default": {"formatter": "default","class": "logging.StreamHandler","stream": "ext://sys.stderr"},"default_file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/app.log","when": "midnight","encoding": "utf-8","backupCount": 10},"access": {"formatter": "access","class": "logging.StreamHandler","stream": "ext://sys.stdout"},"access_file": {"formatter": "access","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/access.log","when": "midnight","encoding": "utf-8","backupCount": 10}},"loggers": {"uvicorn": {"handlers": ["default", "default_file"],"level": "INFO","propagate": false},"uvicorn.error": {"level": "INFO"},"uvicorn.access": {"handlers": ["access", "access_file"],"level": "INFO","propagate": false}}
}

4. 启动 Uvicorn

使用配置文件启动 Uvicorn:

uvicorn run:app --host 0.0.0.0 --port 8000 --log-config ./uvicorn_config.json

或者在 Python 代码中使用 uvicorn.run 方法:

import uvicornif __name__ == "__main__":uvicorn.run(app='main:app', host="0.0.0.0", log_config='./uvicorn_config.json', port=8000, loop="asyncio")

通过上述配置,default 日志将记录 Uvicorn 的常规日志,而 access 日志将记录 HTTP 请求的访问日志,两者分别输出到不同的文件中。

错误日志

在 Uvicorn 的日志配置中,如果 uvicorn.error 日志记录器没有显式配置 handlers,它将继承父记录器的处理器。默认情况下,uvicorn.error 的父记录器是 uvicorn,因此它会使用 uvicorn 记录器配置的处理器来记录日志。

默认行为

如果没有显式配置 uvicorn.errorhandlers,Uvicorn 会使用 uvicorn 记录器的处理器。例如,如果 uvicorn 记录器配置了控制台输出和文件输出,uvicorn.error 也会使用这些处理器。

示例配置

假设你的日志配置文件如下:

{"version": 1,"disable_existing_loggers": false,"formatters": {"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null}},"handlers": {"default": {"formatter": "default","class": "logging.StreamHandler","stream": "ext://sys.stderr"},"file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/app.log","when": "midnight","encoding": "utf-8","backupCount": 10}},"loggers": {"uvicorn": {"handlers": ["default", "file"],"level": "INFO","propagate": false},"uvicorn.error": {"level": "ERROR","propagate": true},"uvicorn.access": {"handlers": ["default"],"level": "INFO","propagate": false}}
}

解释

  • uvicorn** 记录器**:
    • 配置了两个处理器:default(控制台输出)和 file(文件输出)。
    • 日志级别为 INFO
    • propagate 设置为 false,表示不将日志消息传递给父记录器。
  • uvicorn.error** 记录器**:
    • 没有显式配置 handlers,但 propagate 设置为 true
    • 日志级别为 ERROR
    • 由于 propagatetrueuvicorn.error 会将日志消息传递给父记录器 uvicorn,因此会使用 uvicorn 配置的处理器 defaultfile

结果

  • 控制台输出:
    • uvicorn.error 的日志消息会输出到控制台。
  • 文件输出:
    • uvicorn.error 的日志消息会输出到 ./logs/app.log 文件中。

总结

如果 uvicorn.error 没有显式配置 handlers,它会继承父记录器 uvicorn 的处理器。通过设置 propagatetrue,可以确保 uvicorn.error 的日志消息被正确记录到控制台和文件中。如果 propagatefalse,则 uvicorn.error 不会记录任何日志,除非你显式配置了处理器。

错误日志

如果在 Uvicorn 的日志配置文件中没有显式配置 uvicorn.error 记录器,Uvicorn 仍然会记录错误日志,但具体记录方式取决于 uvicorn 记录器的配置。

默认行为

在默认情况下,uvicorn 记录器会处理所有 Uvicorn 生成的日志,包括错误日志。如果 uvicorn 记录器配置了处理器(handlers),这些处理器将用于记录所有日志,包括错误日志。

示例配置

假设你的日志配置文件如下:

{"version": 1,"disable_existing_loggers": false,"formatters": {"default": {"()": "uvicorn.logging.DefaultFormatter","fmt": "%(asctime)s %(threadName)s %(levelprefix)s  %(message)s","use_colors": null}},"handlers": {"default": {"formatter": "default","class": "logging.StreamHandler","stream": "ext://sys.stderr"},"file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "./logs/app.log","when": "midnight","encoding": "utf-8","backupCount": 10}},"loggers": {"uvicorn": {"handlers": ["default", "file"],"level": "INFO","propagate": false},"uvicorn.access": {"handlers": ["default"],"level": "INFO","propagate": false}}
}

解释

  • uvicorn** 记录器**:
    • 配置了两个处理器:default(控制台输出)和 file(文件输出)。
    • 日志级别为 INFO
    • propagate 设置为 false,表示不将日志消息传递给父记录器。
  • uvicorn.access** 记录器**:
    • 配置了 default 处理器(控制台输出)。
    • 日志级别为 INFO
    • propagate 设置为 false,表示不将日志消息传递给父记录器。

错误日志记录

  • 控制台输出:
    • 由于 uvicorn 记录器配置了 default 处理器,错误日志会输出到控制台。
  • 文件输出:
    • 由于 uvicorn 记录器配置了 file 处理器,错误日志会输出到 ./logs/app.log 文件中。

总结

即使没有显式配置 uvicorn.error 记录器,Uvicorn 仍然会记录错误日志,因为 uvicorn 记录器会处理所有日志,包括错误日志。错误日志将根据 uvicorn 记录器配置的处理器进行输出。

如果你希望更细粒度地控制错误日志的记录方式,可以显式配置 uvicorn.error 记录器,并为其指定特定的处理器。例如:

"uvicorn.error": {"handlers": ["error_file"],"level": "ERROR","propagate": false
}

这样,错误日志将只使用 error_file 处理器进行记录,而不会影响其他日志的记录方式。

handler中输出日志到文件

两种文件输出的配置方式:

 "file": {"formatter": "default","class": "logging.handlers.RotatingFileHandler","maxBytes": 209715200,"backupCount": 1,"mode": "w+","filename": "./log/api.log"},"file": {"formatter": "default","class": "logging.handlers.TimedRotatingFileHandler","filename": "app/server/log/api.log","when": "midnight","encoding": "utf-8","backupCount": 10}

相关文章:

Fastapi 日志处理

uvicorn 日志处理总结: 一、日志的结构 日志结构如下: {"version": 1,"disable_existing_loggers": false,"formatters": {},"handlers": {},"loggers": {} }loggers 用于定义日志处理最顶层的标识…...

FME实现矢量建筑面shp拉伸并贴纹理

文章目录 效果2、数据准备3、整理流程图4、操作步骤4.1 打开软件4.2 添加shp数据4.3 添加Extruder转换器4.4 添加AppearanceSetter转换器4.5 添加png纹理数据4.6 添加输出节点4.7 添加Logger节点4.8 执行5、执行结果效果 2、数据准备 (1)建筑面shp (2)纹理 test.png 其中s…...

仿腾讯会议项目实现——设置配置文件

目录 1、初始化配置 2、实现初始化配置的函数 3、修改配置文件内的ip地址 1、初始化配置 Ckernel.h 2、实现初始化配置的函数 3、修改配置文件内的ip地址 首先修改IP 运行出现设置的IP, 找到运行的配置文件,修改成自己当前的ip 将函数运行条件改成非…...

1187. 【动态规划】竞赛总分

题目描述 学生在我们USACO的竞赛中的得分越多我们越高兴。我们试着设计我们的竞赛以便人们能尽可能的多得分。 现在要进行一次竞赛,总时间T固定,有若干类型可选择的题目,每种类型题目可选入的数量不限,每种类型题目有一个si(解答…...

从零开始学Python游戏编程31-类3

2.6 run()方法 run()方法的作用是在while循环中调用以上方法,运行游戏。代码如图11所示。 图11 run()方法代码 其中,第43行控制while循环的是实例属性running,在图7所示的__init__()方法中定义;第44-46行代码分别调用了processI…...

Transformer 架构 - 解码器 (Transformer Architecture - Decoder)

一、解码器整体结构:多层堆叠设计 Transformer解码器由​​N个相同结构的解码器层堆叠而成​​(通常N=6),每层包含三个核心子模块(图1) 1 5 12 : ​​带掩码的多头自注意力层​​(Masked Multi-Head Self-Attention)​​编码器-解码器注意力层​​(Encoder-Deco…...

解锁健康生活:养生新主张

在生活节奏日益加快的当下,健康养生不再是中老年人的专属话题,越来越多的人开始意识到,它是维持生命活力、抵御疾病的重要保障。​ 中医养生讲究 “药食同源”,在饮食上,我们可以根据季节变化调整食谱。春天气候多变&…...

__call__ 方法

__call__ 是 Python 中的一个魔法方法,也称为类方法。 它的作用是将类的实例变成可调用对象,类似于像函数一样被调用。 __call__ 使用举例 class MyClass:def __call__(self, x, y):return x yobj MyClass() print(obj(1, 2)) 对比其他类/对象的使用…...

济南通过首个备案生活服务大模型,打造行业新标杆

近日,一则振奋人心的消息在人工智能领域传开:济南本土企业丽阳神州智能科技有限公司自主研发的 “丽阳雨露” 大模型成功通过国家网信办的备案。这一成果不仅是济南企业在科技创新道路上的重大突破,更标志着我国在生活服务领域的人工智能应用…...

UE5有些场景的导航生成失败解决方法

如果导航丢失,就在项目设置下将: 即可解决问题: 看了半个小时的导航生成代码发现,NavDataSet这个数组为空,导致异步构建导航失败。 解决 NavDataSet 空 无法生成如下: 当 NavDataSet 为空的化 如果 bAut…...

STM32使用rand()生成随机数并显示波形

一、随机数生成 1、加入头文件:#include "stdlib.h" 2、定义一个用作生成随机数种子的变量并加入到滴答定时器中不断自增:uint32_t run_times 0; 3、设置种子:srand(run_times);//每次生成随机数前调用一次为佳 4、生成一个随…...

继承的了解与学习

目录 1. 继承的概念及定义 1.1 继承的概念 1.2继承的名称 1.3继承方式 1.4继承类模板 2.基类和派生类之间的转化 3.继承中的作用域 4.派生类的默认成员函数 5.继承与友元 6.继承与静态函数 7.多继承与其菱形继承问题 8.虚继承 9.继承和组合 1. 继承的概念及定义 …...

如何精通C++编程?

如果从学生时代算起的话,我学习和使用C已经差不多快十年了,仍然不敢说自己已经掌握了C的全部特性,但或许能够给出一些有用的建议吧。 我学习C全靠自学,花费了不少的功夫,在这里分享一些学习心得,希望对大家…...

【科研绘图系列】R语言绘制多个气泡图组合图(bubble plot)

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据数据预处理画图函数画图系统信息介绍 【科研绘图系列】R语言绘制多个气泡图组合图(bubble plot) 加载R包 library(dplyr) library(tidyr) library(ggp…...

利用大模型实现地理领域文档中英文自动化翻译

一、 背景描述 在跨国性企业日常经营过程中,经常会遇到专业性较强的文档翻译的需求,例如法律文书、商务合同、技术文档等;以往遇到此类场景,企业内部往往需要指派专人投入数小时甚至数天来整理和翻译,效率低下&#x…...

Oracle 19c部署之手工建库(四)

#Oracle #19c #手工建库 手工创建Oracle数据库(也称为手工建库)是指在已经安装了Oracle数据库软件的基础上,通过手动执行一系列命令和步骤来创建一个新的数据库实例。这种方法与使用Database Configuration Assistant (DBCA)等工具自动创建数…...

Leetcode 2158. 每天绘制新区域的数量【Plus题】

1.题目基本信息 1.1.题目描述 有一幅细长的画,可以用数轴来表示。 给你一个长度为 n 、下标从 0 开始的二维整数数组 paint ,其中 paint[i] [starti, endi] 表示在第 i 天你需要绘制 starti 和 endi 之间的区域。 多次绘制同一区域会导致不均匀&…...

使用最新threejs复刻经典贪吃蛇游戏的3D版,附完整源码

基类Entity 建立基类Entity,实现投影能力、动画入场效果(从小变大的弹性动画)、计算自己在地图格位置的方法。 // 导入gsap动画库(用于创建补间动画) import gsap from gsap// 定义Entity基类 export default class …...

Google优化搜索体验:全新动态摘要功能(Beta)为欧洲用户带来更丰富的结果

Google持续推动搜索体验的创新,最新推出的动态摘要(Dynamic Snippets)功能(Beta版)为欧洲经济区(EEA)的用户和企业带来了全新的交互方式。2025年4月,Google更新了动态摘要的文档&…...

[苍穹外卖 | 项目日记] 第三天

前言 实现了新增菜品接口实现了菜品分页查询接口实现了删除菜品接口实现了根据id查询菜品接口实现了修改菜品接口 今日收获: 今日的这几个接口其实和之前写的对员工的操作是一样的,都是一整套Curd操作,所以今天在技术层面上并没有…...

【Python爬虫基础篇】--2.模块解析

目录 1.urllib库 1.1.request模块 1.1.1、urllib.request.urlopen() 函数 1.1.2.urllib.request.urlretrieve() 函数 1.2. error模块 1.3. parse 模块 2. BeautifulSoup4库 2.1.对象种类 2.2.对象属性 2.2.1.子节点 2.2.2.父节点 2.2.3.兄弟节点 2.2.4.回退和前进 …...

LabVIEW技巧——获取文件版本信息

获取可执行文件(exe)版本信息的几种方法 方法1. LabVIEW自带函数 labview自带了获取文件版本号的VI,但是没有开放到程序框图的函数选板中,在该目录下可以找到:...\LabVIEW 20xx\vi.lib\Platform\fileVersionInfo.llb…...

【软件工程】用飞书画各种图(流程图,架构图···)

笔者在做服务外包大赛的时候被文档内容的编写反复折磨,网上的工程图绘画工具要么是展示效果不佳,要么要收大几百的VIP费,最后发现飞书竟然可以直接绘画并插入示意图。 一、为什么选择飞书文档画流程图? 完全免费,无广…...

RFID图书管理系统如何重构数字化仓储管理新生态

引言 在图书馆与出版行业数字化转型进程中,RFID图书管理系统正打破传统人工管理的效率瓶颈,通过与数字化仓储管理系统的深度融合,实现从图书采购、入库到借阅的全链路智能化。本文结合RFID固定资产管理软件的应用逻辑,解析这一技…...

如何校验一个字符串是否是可以正确序列化的JSON字符串呢?

方法1:先给一个比较暴力的方法 try {JSONObject o new JSONObject(yourString); } catch (JSONException e) {LOGGER.error("No valid json"); } 方法2: Object json new cn.hutool.json.JSONTokener("[{\"name\":\"t…...

操作系统-PV

🧠 背景:为什么会有 PV? 类比:内存(生产者) 和 CPU(消费者) 内存 / IO / 磁盘 / 网络下载 → 不断“生产数据” 例如:读取文件、下载视频、从数据库加载信息 CPU → 负…...

工厂方法模式详解及c++代码实现(以自动驾驶感知模块中的应用为例)

模式定义 工厂方法模式(Factory Method Pattern)是一种创建型设计模式,通过定义抽象工厂接口将对象创建过程延迟到子类实现,实现对象创建与使用的解耦。该模式特别适合需要动态扩展产品类型的场景。 自动驾驶感知场景分析 自动驾…...

Jsp技术入门指南【五】详细讲解jsp结构页面

Jsp技术入门指南【五】详细讲解jsp结构页面 前言一、JSP页面的结构二、JSP页面的部件1. 指令(核心控制部件)2. 动作(页面交互部件,了解即可)3. 脚本(Java逻辑嵌入部件) 三、JSP指令详解1.1 JSP指…...

游戏APP如何抵御DDoS攻击与黑客勒索?实战防护全攻略

一、游戏行业安全挑战与攻击危害 游戏APP因高实时性、高并发及虚拟资产交易特性,成为DDoS攻击和勒索的重灾区,典型威胁包括: DDoS攻击瘫痪服务: UDP Flood:针对游戏服务器端口(如UDP 7777)发起…...

Mac 选择下载安装工具 x86 还是 arm64 ?

要确定你的 Mac 电脑应该选择下载安装工具的 x86 还是 arm64 版本,关键是判断你的 Mac 使用的是 Intel 处理器(x86 架构)还是 Apple Silicon(如 M1、M2 等,arm64 架构)。具体方法如下: 方法 1&…...

string函数的应用

字符串查找 find 方法 实例 string s "Hello World,C is awesome!";//查找子串 size_t pos1 s.find("World"); //pos16 size_t pos2 s.find("Python"); //pos2string::npos//查找字符 size_tpos3s.find(c); //pos313//从指定位置开始查找 size…...

使用Trae CN分析项目架构

架构分析后的截图 A区是打开的项目、B区是源码区、C区是AI给出当前项目的架构分析结果。 如何用 Trae CN 快速学习 STM32 嵌入式项目架构 在嵌入式开发领域,快速理解现有项目的架构是一项关键技能。Trae CN 作为一款强大的分析工具,能帮助开发者高效剖…...

每日一题(小白)暴力娱乐篇33

由题意可知我们今天要解决的问题是在1~2025中去找合适的数字,这里要找出一些特殊的数字,这些数字要满足以下条件,是三的倍数,是8的倍数,是38的倍数,老板就给要多给一个红包,我们循环然后相应条件…...

MyBatis框架

前言: MyBatis框架相比JDBC来说大大提升了我们写代码的效率,但是对初学者来说框架还是有点难以理解,所以本篇博客会十分详细的讲解MyBatis框架 目录 一.MyBatis概述 1.什么是映射? 2.什么是XML? 二.MyBatis框架搭建 1.创建一张表和表对…...

基于SpringBoot的新闻小程序开发与设计

概述 在信息爆炸的时代,高效获取新闻资讯成为现代人的刚需。幽络源平台今日分享一款基于SpringBoot框架开发的微信小程序新闻资讯系统,该系统采用前后端分离架构,实现了新闻分类管理、个性化推荐、用户收藏等功能,为新闻传播提供…...

IE之路专题12.BGP专题

BGP协议有哪些特点 BGP时边界网关协议(EGP),是一种用在自治系统之间传递路由信息的路由协议; 提供了丰富的路由属性以及强大的路由过滤和路由策略,实现灵活选路和路由控制; 策略方式更改属性或根据更新信息中属性实现过滤和策略 BGP是工作在传输层TCP之上的,使用TCP的端口号…...

文件包含(详解)

文件包含漏洞是一种常见的Web安全漏洞,其核心在于应用程序未对用户控制的文件路径或文件名进行严格过滤,导致攻击者能够包含并执行任意文件(包括本地或远程恶意文件)。 1. 文件包含原理 动态文件包含机制 开发者使用动态包含函数…...

智慧养老照护实训室:推动养老服务数字化转型实践

在人口老龄化加速与数字化浪潮席卷的当下,传统养老服务模式在效率、精准度及个性化服务上的局限日益明显。智慧养老成为行业转型的必然方向,但专业人才短缺与技术应用落地困难制约着发展。智慧养老照护实训室通过整合虚拟仿真等前沿技术,构建…...

NOIP2015提高组.信息传递

目录 题目算法标签: 并查集, T a r j a n Tarjan Tarjan算法, s c c scc scc强连通分量思路 T a r j a n Tarjan Tarjan算法求解代码 题目 517. 信息传递 算法标签: 并查集, T a r j a n Tarjan Tarjan算法, s c c scc scc强连通分量 思路 使用强连通分量算法求环上点…...

Wireshark 搜索组合速查表

文章目录 Wirshark使用记录基本语法规则搜索条件符号速查表捕获过滤器组合指令速查表筛选过滤器组合命令速查表Wireshark Frame 协议字段解析 Wirshark使用记录 官网地址:https://www.wireshark.org/ 基本语法规则 字段描述示例说明type用于指定数据包的类型&…...

AI当前状态:有哪些新技术

一、到目前为址AI领域出现的新技术 到目前为止,AI领域涌现了许多令人兴奋的新技术。以下是一些关键的进展,涵盖了从基础模型到实际应用的多个方面: 1. 更强大的大型语言模型 (LLMs): 性能提升: 新一代LLM,例如OpenAI的GPT-4o和…...

我的gittee仓库

日常代码: 日常代码提交https://gitee.com/xinxin-pingping/daily-code 有需要的宝子们可自行读取。...

RT-Thread开发文档合集

瑞萨VisionBoard开发实践指南 RT-Thread 文档中心 RT-Thread-【RA8D1-Vision Board】 RA8D1 Vision Board上的USB实践RT-Thread问答社区 - RT-Thread 【开发板】环境篇:05烧录工具介绍_哔哩哔哩_bilibili 【RA8D1-Vision Board】基于OpenMV 实现图像分类_哔哩哔哩_…...

SPWM-H桥逆变器工作原理

SPWM-H桥逆变器(Sinusoidal Pulse Width Modulation H-Bridge Inverter)是一种基于正弦脉宽调制(SPWM)技术的电力电子装置,用于将直流(DC)转换为交流(AC)。它广泛应用于光…...

【数据结构_10】二叉树(2)

一、根据树的遍历结果还原树 紧接着(1),我们继续来讨论:如果给了树的遍历结果,我们能否把这个树给还原出来呢? 如果只给一种遍历结果,那么我们无法对树进行还原。 只有给了我们先序中序&…...

day1-小白学习JAVA(mac版)---(jdk安装和环境变量配置)

JDK安装和环境变量配置 我的电脑系统一、下载JDK1、oracle官网下载适合的JDK安装包,选择Mac OS对应的版本。 二、安装三、配置环境变量1、终端输入/usr/libexec/java_home -V查询所在的路径,复制备用2、输入ls -a3、检查文件目录中是否有.bash_profile文…...

Muduo网络库实现 [十六] - HttpServer模块

设计思路 本模块就是设计一个HttpServer模块,提供便携的搭建http协议的服务器的方法。那么这个模块需要如何设计呢? 这还需要从Http请求说起。 首先从http请求的请求行开始分析,请求行里面有个方法。分为静态资源请求和功能性请求的。 静态…...

工业触摸显示器助力智慧工业实验室发展

工业触摸显示器作为智慧工业实验室的核心人机交互设备,凭借其卓越的性能和灵活性,为实验室的智能化、自动化发展提供了强有力的支持。以下从多个方面阐述工业触摸显示器如何助力智慧工业实验室的发展: 一、提升操作便捷性与效率 直观操作&a…...

k8s介绍与实践

第一节 理论 基础介绍,部署实践,操作实践,点击这里学习 第二节 dashboard操作 查看安装的dashboard服务信息 kubectl get pod,svc -n kubernetes-dashboard 网页登录地址:https://server_ip:30976/#/login 创建token kube…...

ATEngin开发记录_5_C++日志打印引发的崩溃?一次虚函数调用引发的内存错误排查记录

该系列只做记录 不做教程 所以文章简洁直接 会列出碰到的问题和解决方案 只适合C萌新 在使用 C 进行事件系统开发时,我遇到了一次由于调用虚函数 GetName() 输出日志而引发的崩溃问题。通过逐步排查、使用防御性编程和类型检查,最终定位到了隐藏的生命…...