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

Python httpx库终极指南

一、发展历程与技术定位

1.1 历史演进

  • 起源httpx 由 Encode 团队开发,于 2019 年首次发布,目标是提供一个现代化的 HTTP 客户端,支持同步和异步操作,并兼容 HTTP/1.1 和 HTTP/2。
  • 背景
    • requests 库虽然功能强大,但缺乏对异步和 HTTP/2 的原生支持。
    • httpx 应运而生,弥补了 requests 的不足,同时保持了类似的 API 设计。
  • 核心优势
    • 同步和异步双模式。
    • 支持 HTTP/2。
    • 类型提示完善,兼容 Python 3.6+。
版本里程碑特性发布时间
0.1初始版本发布2019.01
0.18正式支持 HTTP/22020.09
0.21顶层异步 API 引入2021.03
0.24完整类型注解支持2021.10
0.26WebSocket 正式支持2022.04

1.2 设计哲学

  • 双模式统一:同一 API 同时支持同步和异步编程范式
  • 协议现代化:原生支持 HTTP/2 和 WebSocket
  • 类型安全:100% 类型提示覆盖,兼容 mypy 静态检查
  • 生态集成:成为 FastAPI/Starlette 官方推荐客户端

1.3 适用场景

  • 需要异步 HTTP 请求的 Web 应用
  • 高并发 API 调用场景
  • HTTP/2 服务交互
  • 需要严格类型检查的大型项目

二、核心功能与基础用法

核心特性

  • 同步与异步:同一 API 支持同步 httpx.get() 和异步 await httpx.AsyncClient().get()
  • HTTP/2 支持:通过 http2=True 启用。
  • 连接池管理:自动复用连接,提升性能。
  • 类型安全:代码完全类型注释,IDE 友好。
  • WebSocket 支持:通过 httpx.WebSocketSession 实现。
  • 文件上传与流式传输:支持大文件分块上传和流式响应。

2.1 安装配置

# 基础安装
pip install httpx# 完整功能安装(HTTP/2 + 代理支持)
pip install "httpx[http2,socks]"

2.2 请求方法全景

import httpx# 同步客户端
with httpx.Client() as client:# RESTful 全方法支持client.get(url, params={...})client.post(url, json={...})client.put(url, data={...})client.patch(url, files={...})client.delete(url)# 异步客户端
async with httpx.AsyncClient() as client:await client.get(...)

2.3 响应处理

response = httpx.get("https://api.example.com/data")# 常用属性和方法
print(response.status_code)     # HTTP 状态码
print(response.headers)         # 响应头
print(response.text)            # 文本内容
print(response.json())          # JSON 解码
print(response.content)         # 二进制内容
print(response.stream())        # 流式访问

三、高级特性与性能优化

3.1 HTTP/2 多路复用

# 启用 HTTP/2
client = httpx.Client(http2=True)
response = client.get("https://http2.example.com")
print(response.http_version)  # 输出: "HTTP/2"

3.2 连接池配置

# 优化连接参数
custom_client = httpx.Client(limits=httpx.Limits(max_keepalive_connections=20,  # 长连接上限max_connections=100,           # 总连接数keepalive_expiry=30            # 空闲时间(s)),timeout=10.0                       # 默认超时
)

3.3 重试策略实现

from tenacity import retry, stop_after_attempt, wait_exponential@retry(stop=stop_after_attempt(3), wait=wait_exponential())
def reliable_request():response = httpx.get("https://unstable-api.example.com")response.raise_for_status()return response

四、企业级功能扩展

4.1 分布式追踪

# OpenTelemetry 集成
from opentelemetry.instrumentation.httpx import HTTPXClientInstrumentorHTTPXClientInstrumentor().instrument()async def tracked_request():async with httpx.AsyncClient() as client:await client.get("https://api.example.com")  # 自动生成追踪 Span

4.2 安全实践

# 证书配置
secure_client = httpx.Client(verify="/path/to/ca-bundle.pem",  # 自定义 CAcert=("/path/to/client-cert.pem", "/path/to/client-key.pem")
)# 敏感信息处理
import os
client = httpx.Client(headers={"Authorization": f"Bearer {os.environ['API_TOKEN']}"}
)

4.3 代理配置

# SOCKS 代理
from httpx_socks import AsyncProxyTransportproxy_transport = AsyncProxyTransport.from_url("socks5://user:pass@host:port")
async with httpx.AsyncClient(transport=proxy_transport) as client:await client.get("https://api.example.com")

五、与 Requests 的对比

5.1 功能对比表

功能httpxrequests
异步支持✅ 原生❌ 仅同步
HTTP/2
类型提示完整支持部分支持
WebSocket
连接池配置精细化控制基础配置

5.2 性能对比数据

# 基准测试结果(1000 请求)
| 场景          | requests (s) | httpx 同步 (s) | httpx 异步 (s) |
|---------------|--------------|-----------------|-----------------|
| 短连接 HTTP/1 | 12.3         | 11.8 (+4%)      | 2.1 (+83%)      |
| 长连接 HTTP/2 | N/A          | 9.5             | 1.7             |

六、完整代码案例

6.1 异步高并发采集

import httpx
import asyncioasync def fetch(url: str, client: httpx.AsyncClient):response = await client.get(url)return response.text[:100]  # 截取部分内容async def main():urls = [f"https://httpbin.org/get?q={i}" for i in range(10)]async with httpx.AsyncClient(timeout=10.0) as client:tasks = [fetch(url, client) for url in urls]results = await asyncio.gather(*tasks)for url, result in zip(urls, results):print(f"{url}: {result}")asyncio.run(main())

6.2 OAuth2 客户端

from httpx import OAuth2, AsyncClientasync def oauth2_flow():auth = OAuth2(client_id="CLIENT_ID",client_secret="SECRET",token_endpoint="https://auth.example.com/oauth2/token",grant_type="client_credentials")async with AsyncClient(auth=auth) as client:# 自动处理 Token 获取和刷新response = await client.get("https://api.example.com/protected")return response.json()

6.3 文件分块上传

import httpx
from tqdm import tqdmdef chunked_upload(url: str, file_path: str, chunk_size: int = 1024*1024):with open(file_path, "rb") as f:file_size = f.seek(0, 2)f.seek(0)with tqdm(total=file_size, unit="B", unit_scale=True) as pbar:with httpx.Client(timeout=None) as client:  # 禁用超时while True:chunk = f.read(chunk_size)if not chunk:breakresponse = client.post(url,files={"file": chunk},headers={"Content-Range": f"bytes {f.tell()-len(chunk)}-{f.tell()-1}/{file_size}"})pbar.update(len(chunk))return response.status_code

七、架构建议

7.1 客户端分层设计

HTTP/1.1
HTTP/2
业务逻辑层
服务抽象层
HTTPX 客户端池
传输层
协议实现
同步传输
异步传输

7.2 监控指标

指标类别具体指标
连接池活跃连接数/空闲连接数
性能平均响应时间/99 分位值
成功率2xx/3xx/4xx/5xx 比例
流量请求量/响应体积

八、迁移指南

8.1 从 Requests 迁移

# 原 Requests 代码
import requestsresp = requests.get("https://api.example.com/data",params={"page": 2},headers={"X-API-Key": "123"}
)# 等效 httpx 代码
import httpxresp = httpx.get("https://api.example.com/data",params={"page": 2},headers={"X-API-Key": "123"}
)

8.2 常见差异处理

  1. 超时设置

    # Requests
    requests.get(url, timeout=(3.05, 27))# httpx
    httpx.get(url, timeout=30.0)  # 统一超时控制
    
  2. 会话管理

    # Requests
    with requests.Session() as s:s.get(url)# httpx
    with httpx.Client() as client:client.get(url)
    

九、最佳实践

  1. 客户端复用:始终重用 Client 实例提升性能
  2. 超时设置:全局超时 + 各操作单独配置
  3. 类型安全:结合 Pydantic 进行响应验证
  4. 异步优先:在高并发场景使用 AsyncClient
  5. 监控告警:关键指标埋点 + 异常报警

十、调试与故障排除

10.1 请求日志记录

import logging
import httpx# 配置详细日志记录
logging.basicConfig(level=logging.DEBUG)# 自定义日志格式
httpx_logger = logging.getLogger("httpx")
httpx_logger.setLevel(logging.DEBUG)# 示例请求
client = httpx.Client(event_hooks={"request": [lambda req: print(f">>> 发送请求: {req.method} {req.url}")],"response": [lambda res: print(f"<<< 收到响应: {res.status_code}")],
})
client.get("https://httpbin.org/get")

10.2 常见错误处理

try:response = httpx.get("https://example.com",timeout=3.0,follow_redirects=True  # 自动处理重定向)response.raise_for_status()
except httpx.HTTPStatusError as e:print(f"HTTP 错误: {e.response.status_code}")print(f"响应内容: {e.response.text}")
except httpx.ConnectTimeout:print("连接超时,请检查网络或增加超时时间")
except httpx.ReadTimeout:print("服务器响应超时")
except httpx.TooManyRedirects:print("重定向次数过多,请检查 URL")
except httpx.RequestError as e:print(f"请求失败: {str(e)}")

十一、高级认证机制

11.1 JWT 自动刷新

from httpx import Auth, AsyncClient
import timeclass JWTAuth(Auth):def __init__(self, token_url, client_id, client_secret):self.token_url = token_urlself.client_id = client_idself.client_secret = client_secretself.access_token = Noneself.expires_at = 0async def async_auth_flow(self, request):if time.time() > self.expires_at - 30:  # 提前30秒刷新await self._refresh_token()request.headers["Authorization"] = f"Bearer {self.access_token}"yield requestasync def _refresh_token(self):async with AsyncClient() as client:response = await client.post(self.token_url,data={"grant_type": "client_credentials","client_id": self.client_id,"client_secret": self.client_secret})token_data = response.json()self.access_token = token_data["access_token"]self.expires_at = time.time() + token_data["expires_in"]# 使用示例
auth = JWTAuth(token_url="https://auth.example.com/token",client_id="your-client-id",client_secret="your-secret"
)
async with AsyncClient(auth=auth) as client:response = await client.get("https://api.example.com/protected")

11.2 AWS Sigv4 签名

# 需要安装 httpx-auth
from httpx_auth import AwsAuthauth = AwsAuth(aws_access_key_id="AKIA...",aws_secret_access_key="...",aws_session_token="...",  # 可选region="us-west-2",service="execute-api"
)response = httpx.get("https://api.example.com/aws-resource",auth=auth
)

十二、流式处理进阶

12.1 分块上传大文件

import httpx
import os
from tqdm import tqdmdef upload_large_file(url, file_path, chunk_size=1024*1024):file_size = os.path.getsize(file_path)headers = {"Content-Length": str(file_size),"Content-Type": "application/octet-stream"}with open(file_path, "rb") as f, \tqdm(total=file_size, unit="B", unit_scale=True) as pbar:def generate():while True:chunk = f.read(chunk_size)if not chunk:breakpbar.update(len(chunk))yield chunkwith httpx.Client(timeout=None) as client:response = client.post(url,content=generate(),headers=headers)return response.status_code# 使用示例
upload_large_file("https://httpbin.org/post","large_file.zip",chunk_size=5*1024*1024  # 5MB 分块
)

12.2 实时流式响应处理

async def process_streaming_response():async with httpx.AsyncClient() as client:async with client.stream("GET", "https://stream.example.com/live-data") as response:async for chunk in response.aiter_bytes():# 实时处理数据块print(f"收到 {len(chunk)} 字节数据")process_data(chunk)  # 自定义处理函数

十三、自定义中间件与传输层

13.1 请求重试中间件

from httpx import AsyncClient, Request, Response
import httpxclass RetryMiddleware:def __init__(self, max_retries=3):self.max_retries = max_retriesasync def __call__(self, request: Request, get_response):for attempt in range(self.max_retries + 1):try:response = await get_response(request)if response.status_code >= 500:raise httpx.HTTPStatusError("Server error", request=request, response=response)return responseexcept (httpx.RequestError, httpx.HTTPStatusError) as e:if attempt == self.max_retries:raiseawait asyncio.sleep(2 ** attempt)return response  # 永远不会执行此处# 创建自定义客户端
client = AsyncClient(transport=httpx.AsyncHTTPTransport(retries=3,middleware=[RetryMiddleware(max_retries=3)]
)

13.2 修改请求头中间件

def add_custom_header_middleware():async def middleware(request: Request, get_response):request.headers["X-Request-ID"] = str(uuid.uuid4())response = await get_response(request)return responsereturn middlewareclient = AsyncClient(event_hooks={"request": [add_custom_header_middleware()]}
)

十四、性能调优实战

14.1 性能分析工具

# 使用 cProfile 分析请求性能
import cProfile
import httpxdef profile_requests():with httpx.Client() as client:for _ in range(100):client.get("https://httpbin.org/get")if __name__ == "__main__":cProfile.run("profile_requests()", sort="cumtime")

14.2 连接池优化配置

optimized_client = httpx.AsyncClient(limits=httpx.Limits(max_connections=200,           # 最大连接数max_keepalive_connections=50,  # 保持活跃的连接数keepalive_expiry=60            # 空闲连接存活时间),timeout=httpx.Timeout(connect=5.0,                   # 连接超时read=20.0,                     # 读取超时pool=3.0                       # 连接池等待超时),http2=True                        # 启用 HTTP/2
)

十五、与异步框架深度集成

15.1 在 FastAPI 中使用

from fastapi import FastAPI, Depends
from httpx import AsyncClientapp = FastAPI()async def get_async_client():async with AsyncClient(base_url="https://api.example.com") as client:yield client@app.get("/proxy-data")
async def proxy_data(client: AsyncClient = Depends(get_async_client)):response = await client.get("/remote-data")return response.json()

15.2 集成 Celery 异步任务

from celery import Celery
from httpx import AsyncClientapp = Celery("tasks", broker="pyamqp://guest@localhost//")@app.task
def sync_http_request():with httpx.Client() as client:return client.get("https://api.example.com/data").json()@app.task
async def async_http_request():async with AsyncClient() as client:response = await client.get("https://api.example.com/data")return response.json()

十六、安全最佳实践

16.1 证书固定

# 使用指纹验证证书
client = httpx.Client(verify=True,limits=httpx.Limits(max_keepalive_connections=5),cert=("/path/client.crt", "/path/client.key"),# 证书指纹校验transport=httpx.HTTPTransport(verify=httpx.SSLConfig(cert_reqs="CERT_REQUIRED",ca_certs="/path/ca.pem",fingerprint="sha256:..."))
)

16.2 敏感数据防护

from pydantic import SecretStrclass SecureClient:def __init__(self, api_key: SecretStr):self.client = httpx.Client(headers={"Authorization": f"Bearer {api_key.get_secret_value()}"},timeout=30.0)def safe_request(self):try:return self.client.get("https://secure-api.example.com")except httpx.RequestError:# 记录错误但不暴露密钥log.error("API请求失败")# 使用
secure_client = SecureClient(api_key=SecretStr("s3cr3t"))

十七、实战案例:分布式爬虫

import httpx
import asyncio
from bs4 import BeautifulSoup
from urllib.parse import urljoinclass AsyncCrawler:def __init__(self, base_url, concurrency=10):self.base_url = base_urlself.seen_urls = set()self.semaphore = asyncio.Semaphore(concurrency)self.client = httpx.AsyncClient(timeout=10.0)async def crawl(self, path="/"):url = urljoin(self.base_url, path)if url in self.seen_urls:returnself.seen_urls.add(url)async with self.semaphore:try:response = await self.client.get(url)if response.status_code == 200:await self.parse(response)except httpx.RequestError as e:print(f"请求失败: {url} - {str(e)}")async def parse(self, response):soup = BeautifulSoup(response.text, "html.parser")# 提取数据print(f"解析页面: {response.url}")# 提取链接继续爬取for link in soup.find_all("a", href=True):await self.crawl(link["href"])async def run(self):await self.crawl()await self.client.aclose()# 启动爬虫
async def main():crawler = AsyncCrawler("https://example.com")await crawler.run()asyncio.run(main())

十八、扩展学习资源

18.1 官方文档

  • HTTPS 官方文档
  • HTTPX GitHub 仓库

18.2 推荐书籍

  • 点击链接购买《Python网络爬虫权威指南》
    在这里插入图片描述

18.3 进阶教程

  • Real Python 的 HTTPX 教程
  • TestDriven.io 的异步 HTTP 指南

总结

通过本指南的深度扩展,您已经掌握了:

  1. 高级调试技巧:包括日志配置和精细化错误处理
  2. 企业级认证方案:JWT自动刷新和AWS签名实现
  3. 流式处理最佳实践:大文件分块上传和实时流处理
  4. 自定义扩展能力:中间件开发和传输层定制
  5. 性能调优策略:连接池配置和性能分析工具使用
  6. 框架集成模式:与FastAPI、Celery等框架的深度整合
  7. 安全防护方案:证书固定和敏感数据处理
  8. 完整实战案例:分布式异步爬虫的实现

相关文章:

Python httpx库终极指南

一、发展历程与技术定位 1.1 历史演进 起源&#xff1a;httpx 由 Encode 团队开发&#xff0c;于 2019 年首次发布&#xff0c;目标是提供一个现代化的 HTTP 客户端&#xff0c;支持同步和异步操作&#xff0c;并兼容 HTTP/1.1 和 HTTP/2。背景&#xff1a; requests 库虽然功…...

#Redis黑马点评#(五)Redisson详解

目录 一 基于Redis的分布式锁优化 二 Redisson 1 实现步骤 2 Redisson可重入锁机制 3 Redisson可重试机制 4 Redisson超时释放机制 5 RedissonMultiLock解决主从一致性 三 Redis优化秒杀 一 基于Redis的分布式锁优化 二 Redisson Redisson是一个在Redis的基础上实现的…...

redis存储结构

一、存储结构 存储转换&#xff1a; string int&#xff1a;字符串长度 ≤ 20 且能转成整数raw&#xff1a;字符串长度 > 44embstr&#xff1a;字符串长度 ≤ 44附加&#xff1a;CPU 缓存中基本单位为 cacheline 64 字节 list quicklist&#xff08;双向链表&#xff09;zi…...

wordpress自学笔记 第三节 独立站产品和类目的三种展示方式

wordpress自学笔记 摘自 超详细WordPress搭建独立站商城教程-第三节 独立站产品和类目的三种展示方式&#xff0c;2025 WordPress搭建独立站教程#WordPress建站教程https://www.bilibili.com/video/BV1rwcteuETZ?spm_id_from333.788.videopod.sections&vd_sourcea0af3b…...

Python 自动化脚本开发秘籍:从入门到实战进阶(6/10)

摘要&#xff1a;本文详细介绍了 Python 自动化脚本开发的全流程&#xff0c;从基础的环境搭建到复杂的实战场景应用&#xff0c;再到进阶的代码优化与性能提升。涵盖数据处理、文件操作、网络交互、Web 测试等核心内容&#xff0c;结合实战案例&#xff0c;助力读者从入门到进…...

封装和分用(网络原理)

UDP/TCP协议知识及相关机制 优质好文推荐&#x1f446;&#x1f446; 我们如果想要了解封装与分用&#xff0c;先需要了解TCP/IP五层协议~~ 该图的右边就是TCP/IP五层协议~~需要先理解一下各层是什么含义~ 应用层&#xff1a;直接为用户应用程序提供网络服务和通信协议。它定…...

MySQL数据库容灾设计案例与SQL实现

MySQL数据库容灾设计案例与SQL实现 一、主从复制容灾方案 1. 配置主从复制 -- 在主库执行&#xff08;创建复制账号&#xff09; CREATE USER repl_user% IDENTIFIED BY SecurePass123!; GRANT REPLICATION SLAVE ON *.* TO repl_user%;-- 查看主库状态&#xff08;记录File…...

各类有关NBA数据统计数据集大合集

这些数据我已上传大家在CSDN上直接搜索就可以&#xff01; 一、【2022-2023 NBA球员统计】数据集 关键词: 篮球 描述: 语境 该数据集每场比赛包含2022-2023常规赛NBA球员统计数据。 请注意&#xff0c;由团队更改产生了重复的球员名称。 * [2021-2022 NBA播放器统计]&#…...

【基于 LangChain 的异步天气查询5】多轮对话天气智能助手

目录 项目概述 1. 天气查询功能 2. 多轮对话与聊天 3. 语音输入与输出 4. 历史记录管理 5. 项目结构 6. 核心功能流程 7. 项目特色 🗂️ 项目目录结构 📄 chat_runnable.py 📄 main.py 📄 history_manager.py 📄 weather_runnable.py 📄 tools.py �…...

图片转ICO图标工具

图片转ICO图标 可批量操作 下载地址&#xff1a; 链接&#xff1a;https://pan.quark.cn/s/6312c565ec98 这个工具是一个批量图片转ICO图标的神器&#xff0c;有了它&#xff0c;以后再也不用为ICO格式的转换烦恼&#xff01;而且这个软件特别小巧&#xff0c;完全不用安装。…...

istio in action之服务网格和istio组件

微服务和服务网格 微服务 微服务将大系统拆解成一个个独立的、小型的服务单元。每个服务可以独立部署、快速迭代&#xff0c;团队可以自主决策&#xff0c;大大降低了变更风险。当然&#xff0c;微服务不是万能药&#xff0c;它需要强大的自动化和DevOps实践作为支撑。而Isti…...

5 从众效应

引言 有一个成语叫做三人成虎&#xff0c;意思是说&#xff0c;有三个人谎报市上有老虎&#xff0c;听者就信以为真。这种人在社会群体中&#xff0c;容易不加分析地接受大多数人认同的观点或行为的心理倾向&#xff0c;被称为从众效应。 从众效应&#xff08;Bandwagon Effec…...

超市销售管理系统 - 需求分析阶段报告

1. 系统概述 超市销售管理系统是为中小型超市设计的信息化管理解决方案&#xff0c;旨在通过信息化手段实现商品管理、销售处理、库存管理、会员管理等核心业务流程的数字化&#xff0c;提高超市运营效率和服务质量&#xff0c;同时为管理者提供决策支持数据。 2. 业务需求分…...

懒人美食帮SpringBoot订餐系统开发实现

概述 快速构建一个订餐系统&#xff0c;今天&#xff0c;我们将通过”懒人美食帮”这个基于SpringBoot的订餐系统项目&#xff0c;为大家详细解析从用户登录到多角色权限管理的完整实现方案。本教程特别适合想要学习企业级应用开发的初学者。 主要内容 1. 用户系统设计与实现…...

【计算机视觉】基于Python的相机标定项目Camera-Calibration深度解析

基于Python的相机标定项目Camera-Calibration深度解析 1. 项目概述技术核心 2. 技术原理与数学模型2.1 相机模型2.2 畸变模型 3. 实战指南&#xff1a;项目运行与标定流程3.1 环境配置3.2 数据准备3.3 执行步骤3.4 结果验证 4. 常见问题与解决方案4.1 角点检测失败4.2 标定结果…...

彩票假设学习笔记

彩票假设 文章目录 彩票假设一、基本概念1. 核心观点2. 关键要素 二、彩票假设的用途三、训练流程四、意义和局限性1. 意义2. 局限性 五、总结 一、基本概念 彩票假设&#xff08;Lottery Ticket Hypothesis&#xff09;是由 Jonathan Frankle 和 Michael Carbin 在 2019 年的…...

《算法导论(第4版)》阅读笔记:p18-p31

《算法导论(第4版)》学习第 11 天&#xff0c;p18-p31 总结&#xff0c;总计 4 页。 一、技术总结 1. Fourier transform(傅里叶变换) In mathematics, the Fourier transform (FT) is an integral transform that takes a function as input then outputs another function…...

编程技能:字符串函数02,strcpy

专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏&#xff0c;故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 &#xff08;一&#xff09;WIn32 专栏导航 上一篇&#xff1a;编程技能&#xff1a;字符串函数01&#xff0c;引言 回到目录 …...

UOJ 164【清华集训2015】V Solution

Description 给定序列 a ( a 1 , a 2 , ⋯ , a n ) a(a_1,a_2,\cdots,a_n) a(a1​,a2​,⋯,an​)&#xff0c;另有序列 h h h&#xff0c;初始时 h a ha ha. 有 m m m 个操作分五种&#xff1a; add ⁡ ( l , r , v ) \operatorname{add}(l,r,v) add(l,r,v)&#xff1a;…...

数据库备份与策略【全量备份、增量备份、日志恢复】

数据库备份策略与SQL语句实现 一、基础备份SQL语句 1. 全量备份&#xff08;逻辑备份&#xff09; -- 备份单个数据库 mysqldump -u [username] -p[password] --single-transaction --routines --triggers --events --master-data2 [database_name] > backup.sql-- 备份…...

基于单片机的电子法频率计

一、电子计数法测频率原理 通过门控控制闸门开关&#xff0c;闸门时间T自己设定&#xff0c;计数器计数脉冲个数N&#xff08;也就是待测信号&#xff09;&#xff0c;N个脉冲的时间间隔为δt,倒数即为信号的频率f,由此 δtT/N fN/T——信号频率 根据公式&#xff0c;如果考虑…...

day22python打卡

复习日 仔细回顾一下之前21天的内容&#xff0c;没跟上进度的同学补一下进度。 作业&#xff1a; 自行学习参考如何使用kaggle平台&#xff0c;写下使用注意点&#xff0c;并对下述比赛提交代码 kaggle泰坦里克号人员生还预测https://www.kaggle.com/competitions/titanic/…...

前端项目打包部署流程j

1.打包前端项目(运行build这个文件) 2.打包完成后&#xff0c;控制台如下所示:(没有报错即代表成功) 3.左侧出现dist文件夹 4.准备好我们下载的nginx(可以到官网下载一个),然后在一个没有中文路径下的文件夹里面解压。 5.在继承终端内打开我们的项目&#xff0c;找到前面打包好…...

k8s的flannel生产实战与常见问题排查

关于 Kubernetes Flannel 插件的详细教程及生产环境实战指南&#xff0c;涵盖核心概念、安装配置、常见问题排查与优化策略 Flannel通信流程 一、Flannel 概述 Flannel 是 Kubernetes 最常用的 CNI&#xff08;Container Network Interface&#xff09;插件之一&#xff0c;…...

Linux `uname` 指令终极指南

Linux `uname` 指令终极指南 一、核心功能解析1. 命令语法2. 基础输出示例二、选项详解与使用场景三、实战应用技巧1. 系统信息快速获取2. 硬件平台验证3. 内核版本比较四、高级调优方法1. 内核编译优化2. 驱动模块管理3. 安全补丁验证五、系统诊断与排查1. 虚拟化环境检测2. 内…...

wget、curl 命令使用场景与命令实践

一、wget 常见场景与命令 定位&#xff1a;专注于 文件下载&#xff0c;支持递归下载、断点续传&#xff0c;适合批量或自动化下载任务。 1. 基础下载 # 下载文件到当前目录&#xff08;自动命名&#xff09; wget https://example.com/file.zip# 指定保存文件名 wget -O cu…...

RAII是什么?

RAII&#xff08;Resource Acquisition Is Initialization&#xff0c;资源获取即初始化&#xff09;是C编程中的一项非常重要且经典的设计思想&#xff0c;也是现代C资源管理的基石。它主要解决资源的自动管理与释放问题&#xff0c;从而帮助程序员避免资源泄漏、悬空指针等常…...

应急响应基础模拟靶机-security2

PS:杰克创建的流量包(result.pcap)在root目录下&#xff0c;请根据已有信息进行分析 1、首个攻击者扫描端口使用的工具是&#xff1f; 2、后个攻击者使用的漏洞扫描工具是&#xff1f; 3、攻击者上传webshell的绝对路径及User-agent是什么&#xff1f; 4、攻击者反弹shell的…...

【C/C++】const关键词及拓展

✅ C 中的 const 关键字 学习笔记 &#x1f4a1; 关键词&#xff1a;常量、编译时常量、性能优化、安全性、C11/C14/C17/C20 特性 &#x1f9e0; 一、const —— 常量修饰符 1.1 定义 const 是 “constant” 的缩写。表示一个变量一旦被初始化&#xff0c;其值就不能再改变。…...

什么是电路耦合以及如何解耦合

耦合&#xff08;Coupling&#xff09;是指两个或多个电路之间通过物理连接或电磁场交互产生的能量或信号传递现象。其本质是不同电路模块之间相互影响的机制&#xff0c;可能表现为信号传输、噪声干扰或能量传递。 一、解耦合的核心目标 电源噪声抑制&#xff1a;隔离开关电…...

【软件测试】基于项目驱动的功能测试报告(持续更新)

目录 一、项目的介绍 1.1 项目背景 二、测试目标 2.1 用户服务模块 2.1.1 用户注册模块 2.1.1.1 测试点 2.1.1.2 边界值分析法(等价类+边界值) 2.1.1.2.1 有效等价类 2.1.1.2.2 无效等价类 2.1.1.2.3 边界值 2.1.1.2.4 测试用例设计 2.1.2 用户登录 2.1.2.1 测试…...

Java面试常见技术问题解析

Java面试常见技术问题 1. Java基础 1.1 Java的特点是什么&#xff1f; Java是一种面向对象的编程语言&#xff0c;具有跨平台性、健壮性、安全性、多线程支持等特点。 1.2 什么是面向对象&#xff1f; 面向对象是一种编程范式&#xff0c;通过类和对象来组织代码&#xff…...

弹性Reasoning!通过RL训练控制推理预算,提升模型的推理能力和效率!

摘要&#xff1a;大型推理模型&#xff08;LRMs&#xff09;通过生成扩展的思维链&#xff08;CoT&#xff09;在复杂任务上取得了显著进展。然而&#xff0c;它们不受控制的输出长度对于实际部署构成了重大挑战&#xff0c;在实际部署中&#xff0c;对令牌、延迟或计算的推理时…...

Spyglass:在batch/shell模式下运行目标的顶层是什么?

相关阅读 Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm1001.2014.3001.5482 除了可以在图形用户界面(GUI)中运行目标外&#xff0c;使用Batch模式或Shell模式也可以运行目标&#xff0c;如下面的命令所示。 % spyglass -project test.prj -ba…...

新手在使用宝塔Linux部署前后端分离项目时可能会出现的问题以及解决方案

常见问题与解决方案 1. 环境配置错误 问题&#xff1a;未正确安装Node.js/Python/JDK等运行时环境解决&#xff1a; 通过宝塔面板的软件商店安装所需环境验证版本&#xff1a; node -v # 查看Node.js版本 python3 --version # 查看Python3版本2. 端口未正确开放 问题&am…...

信息系统项目管理师-软考高级(软考高项)​​​​​​​​​​​2025最新(十七)

个人笔记整理---仅供参考 第十七章项目干系人管理 17.1管理基础 17.2项目干系人管理过程 17.3识别干系人 17.4规划干系人参与 17.5管理人干系人参与 17.6监督干系人参与...

AI日报 · 2025年05月11日|传闻 OpenAI 考虑推出 ChatGPT “永久”订阅模式

1、Anthropic API 集成网页搜索功能&#xff0c;赋能 Claude 模型实时信息获取与研究能力 Anthropic 公司近日宣布&#xff0c;为其应用程序接口&#xff08;API&#xff09;引入了网页搜索工具&#xff0c;显著增强了旗下 Claude 系列模型获取和利用实时信息的能力。这一更新…...

【和春笋一起学C++】数组名作为函数参数实例

接上篇文章《【和春笋一起学C】函数——C的编程模块》&#xff0c;当使用数组名作为函数形参时&#xff0c;数组名会退化为指针&#xff0c;实际传递的是数组首元素的地址。 数组名在大多数情况下会退化为指针&#xff0c;以下两种情况除外&#xff1a; 当使用sizeof运算符时&a…...

多智体具身人工智能:进展与未来方向(上)

25年5月来自北理工、南大、西安交大、浙大和同济大学的论文“Multi-Agent Embodied AI: Advances And Future Directions”。 具身人工智能&#xff08;Embodied AI&#xff09;在智能时代先进技术的应用中扮演着关键角色。在智能时代&#xff0c;人工智能系统与物理实体相融合…...

C++类和对象--初阶

C类和对象—初阶 01. 面向对象与面向过程深度对比 面向过程&#xff1a;以过程为中心&#xff0c;关心问题解决的步骤。执行效率高&#xff0c;适合简单问题&#xff0c;内存占用小。但是代码复杂性高&#xff0c;维护成本高。 线性流程&#xff1a;点餐 → 烹饪 → 上菜 → …...

sunset:Solstice靶场

sunset:Solstice https://www.vulnhub.com/entry/sunset-solstice,499/ 1&#xff0c;将两台虚拟机网络连接都改为NAT模式 2&#xff0c;攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23.182&#xff0c;靶场IP192.168.23.244 3&#xff…...

1247. 后缀表达式

面白i题 ahh 我这朱脑子是写不出来的。大牛分析&#xff1a; 我的ac代码&#xff1a; #include<iostream> using namespace std; int ma-1e91,mi1e91; long long sum; long long sum1; int main(){int n,m; scanf("%d%d",&n,&m);for(int i0;i<(nm…...

基础框架搭建流程指南

一、搭建前准备阶段 1. 明确需求目标 确定业务场景类型&#xff08;Web/APP/微服务等&#xff09; 分析核心功能与非功能性需求&#xff08;性能/安全性/扩展性&#xff09; 预估用户量级与并发压力 2. 技术选型决策 开发语言选择&#xff08;Java/Python/Go等&#xff09…...

Vue.js 全局导航守卫:深度解析与应用

在 Vue.js 开发中&#xff0c;导航守卫是一项极为重要的功能&#xff0c;它为开发者提供了对路由导航过程进行控制的能力。其中&#xff0c;全局导航守卫更是在整个应用的路由切换过程中发挥着关键作用。本文将深入探讨全局导航守卫的分类、作用以及参数等方面内容。 一、全局…...

微服务架构实战:从服务拆分到RestTemplate远程调用

微服务架构实战&#xff1a;从服务拆分到RestTemplate远程调用 一 . 服务拆分1.1 服务拆分注意事项1.2 导入服务拆分 Demo1.3 小结 二 . 服务间调用2.1 注册 RestTemplate2.2 实现远程调用2.3 小结 三 . 提供方和消费方 在分布式系统设计中&#xff0c;微服务架构因其灵活性、可…...

10.二叉搜索树中第k小的元素(medium)

1.题目链接&#xff1a; 230. 二叉搜索树中第 K 小的元素 - 力扣&#xff08;LeetCode&#xff09;230. 二叉搜索树中第 K 小的元素 - 给定一个二叉搜索树的根节点 root &#xff0c;和一个整数 k &#xff0c;请你设计一个算法查找其中第 k 小的元素&#xff08;从 1 开始计数…...

八股文-js篇

八股文-js篇 1. 延迟执行js的方式2. js的数据类型3. null 和 undefined的区别4. 和 的区别5. js微任务和宏任务6. js作用域7. js对象9. JS作用域this指向原型8. js判断数组9. slice作用、splice是否会改变原数组10. js数组去重11. 找出数组最大值12. 给字符串新增方法实现功能…...

Nipype使用:从安装配置到sMRI处理

Nipype使用&#xff1a;从安装配置到sMRI处理 Nipype使用&#xff1a;从安装配置到sMRI处理一、Nipype及其依赖工具安装配置1.1 Nipype安装1.2 依赖工具安装与配置1.2.1 FreeSurfer1.2.2 ANTS1.2.3 FSL1.2.4 dcm2nii/MRIConvert 1.3 环境变量配置 二、Nipype进行sMRI预处理2.1 …...

常用的rerank模型有哪些?都有什么优势?

常用的Rerank模型分类及优势分析 重排序(Rerank)模型在信息检索、推荐系统、问答系统等场景中发挥关键作用,通过优化初步检索结果提升最终输出的相关性。以下是当前主流的Rerank模型分类及其核心优势的详细分析: 一、基于大语言模型(LLM)的Rerank模型 代表性模型: Ran…...

LLM框架

LLM&#xff08;Large Language Model&#xff0c;大型语言模型&#xff09;框架是一类用于开发、部署和优化大型语言模型的工具和平台。它们在自然语言处理&#xff08;NLP&#xff09;和人工智能&#xff08;AI&#xff09;领域中发挥着重要作用&#xff0c;帮助开发者高效地…...