《AI大模型应知应会100篇》第50篇:大模型应用的持续集成与部署(CI/CD)实践
第50篇:大模型应用的持续集成与部署(CI/CD)实践
🧾 摘要
在AI大模型开发中,随着模型版本迭代频繁、依赖复杂、部署环境多样,构建一套高效可靠的持续集成与持续交付(CI/CD)流程显得尤为重要。本文将从零开始讲解如何为一个大模型项目设计完整的CI/CD流水线,涵盖代码提交、测试、打包、部署到生产环境的全过程。
文章内容包含:
- 实战型CI/CD架构图
- GitHub Actions自动化配置示例
- Docker镜像优化技巧
- Kubernetes Helm部署模板
- 蓝绿发布与金丝雀发布的实现方法
- 监控告警系统集成方案
- 实际案例演示:一次完整变更流程
适合人工智能初中级开发者和工程师阅读参考。
🔍 核心概念与知识点
1. CI/CD流水线设计(🔧 实战)
大模型项目的典型CI/CD流程
💡 说明:相比传统软件项目,大模型CI/CD增加了模型质量评估、性能测试等关键环节。
环境隔离策略
环境 | 用途 | 特点 |
---|---|---|
开发环境 | 本地调试 | 快速迭代,无需严格一致性 |
测试环境 | 自动化测试 | 接近生产配置 |
预发环境 | 全链路验证 | 完全模拟生产 |
生产环境 | 对外服务 | 高可用、高安全 |
基础设施即代码(IaC)工具选择
工具 | 描述 | 适用场景 |
---|---|---|
Terraform | 支持多云基础设施管理 | 跨平台资源编排 |
Ansible | 无Agent部署,适合轻量任务 | 快速搭建服务器 |
Pulumi | 支持多种编程语言定义资源 | 开发者友好 |
Helm | Kubernetes包管理器 | K8s应用部署 |
版本管理策略(Semantic Versioning)
建议采用语义化版本号 MAJOR.MINOR.PATCH
:
v1.2.3
1
: 主要功能更新或重大变更2
: 新增非破坏性功能3
: Bug修复或小改进
✅ 最佳实践:每次合并到main分支时自动生成新版本标签,并记录变更日志。
2. 自动化测试体系(🧪 实战)
模型性能测试框架(🚀 吞吐量 & 延迟测试)
使用Locust进行API吞吐量测试:
from locust import HttpUser, task, betweenclass ModelUser(HttpUser):wait_time = between(0.1, 0.5)@taskdef predict(self):payload = {"prompt": "请解释什么是量子计算","max_new_tokens": 100}self.client.post("/predict", json=payload)
运行命令:
locust -f performance_test.py
访问 http://localhost:8089
查看并发测试结果。
模型输出质量评估(✅ BLEU / ROUGE / Accuracy)
使用datasets
库进行自动化评估:
from datasets import load_metricbleu = load_metric("bleu")
references = [["the cat is on the mat"]]
predictions = ["the cat is on the mat"]
result = bleu.compute(predictions=predictions, references=references)
print(result)
输出:
{'bleu': 1.0, 'precisions': [1.0, 1.0, 1.0, 1.0], 'brevity_penalty': 1.0, 'length_ratio': 1.0, 'length_penalty': 1.0}
回归测试设计(🔁 功能回归验证)
编写Pytest测试用例确保输出一致性:
import pytest
from model_service import ModelServicemodel = ModelService(model_name="gpt2")def test_regression():output = model.generate("你好")assert "你好" in output
执行命令:
pytest regression_test.py -v
A/B测试框架(🔀 多模型对比)
使用Flask实现简单的A/B路由:
from flask import Flask
import randomapp = Flask(__name__)models = {"A": "ModelV1", "B": "ModelV2"}@app.route("/predict")
def predict():group = random.choice(["A", "B"])result = f"调用 {models[group]}"return {"group": group, "result": result}if __name__ == "__main__":app.run()
3. 部署与发布策略(📦 实战)
蓝绿部署(🔵🟢 Zero-downtime)
# k8s-bluegreen.yaml
apiVersion: apps/v1
kind: Deployment
metadata:name: model-service-green
spec:replicas: 3selector:matchLabels:app: model-serviceversion: greentemplate:metadata:labels:app: model-serviceversion: greenspec:containers:- name: model-containerimage: registry.example.com/model:v1.0.0
---
apiVersion: service/v1
kind: Service
metadata:name: model-service
spec:selector:app: model-serviceversion: greenports:- protocol: TCPport: 80targetPort: 5000
✅ 切换方式:修改Service中的version标签即可切换流量。
金丝雀发布(⏳ 渐进式上线)
使用Argo Rollouts实现渐进式发布:
apiVersion: argoproj.io/v1alpha1
kind: Rollout
metadata:name: model-rollout
spec:replicas: 5strategy:canary:steps:- setWeight: 20- pause: {}- setWeight: 40- pause: {duration: 60}- setWeight: 100template:spec:containers:- name: modelimage: registry.example.com/model:v2.0.0
📈 效果:逐步将20% -> 40% -> 100%流量迁移到新版本。
回滚机制(↩️ 快速恢复)
通过Git Tag快速回退版本:
git checkout v1.0.0
git tag -d latest
git push origin :latest
git tag latest
git push origin --tags
🛠️ 在CI中监听Tag事件并重新部署旧版本。
特性开关(⚙️ Feature Toggle)
使用Flask实现动态开关:
FEATURE_FLAGS = {"new_model": False
}@app.route("/toggle/new-model")
def toggle_new_model():FEATURE_FLAGS["new_model"] = not FEATURE_FLAGS["new_model"]return {"status": FEATURE_FLAGS["new_model"]}
4. 监控与反馈循环(📊 实战)
部署后监控指标(📈 Prometheus)
指标 | 描述 |
---|---|
http_requests_total{status} | 请求总数及状态码 |
model_latency_seconds | 模型响应延迟 |
gpu_usage_percent | GPU利用率 |
tokens_per_second | 吞吐量 |
Prometheus告警规则示例:
groups:
- name: model-alertsrules:- alert: HighErrorRateexpr: rate(http_requests_total{status=~"5.."}[5m]) > 0.1for: 2mlabels:severity: warningannotations:summary: "高错误率"description: "5xx错误率超过10%"
用户反馈收集(💬 反馈闭环)
前端埋点上报用户满意度评分:
fetch('/feedback', {method: 'POST',body: JSON.stringify({query_id: "abc123", rating: 4})
});
后端记录至数据库:
@app.route('/feedback', methods=['POST'])
def record_feedback():data = request.jsondb.insert("feedback", data)return {"status": "ok"}
异常检测(🚨 自动识别问题)
使用Prometheus + Alertmanager实现实时告警:
receivers:
- name: slack-webhookslack_configs:- api_url: https://hooks.slack.com/services/TOKENchannel: '#alerts'text: "{{ range .Alerts }}{{ .Status }}: {{ .Labels.alertname }}\n{{ end }}"
🛠️ 工具链与配置示例
GitHub Actions CI/CD配置文件(.github/workflows/ci-cd.yml
)
name: Model CI/CD Pipelineon:push:branches:- mainjobs:build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v3- name: Set up Pythonuses: actions/setup-python@v4with:python-version: '3.10'- run: pip install -r requirements.txt- run: python train.py- run: python test.py- run: docker build -t registry.example.com/model:${{ github.sha }}- run: docker push registry.example.com/model:${{ github.sha }}deploy:needs: buildruns-on: ubuntu-lateststeps:- run: helm upgrade --install model-release ./helm-chart --set image.tag=${{ github.sha }}
Dockerfile优化技巧(适用于大模型)
FROM nvidia/cuda:12.1-base# 安装基础依赖
RUN apt-get update && apt-get install -y git curl wget# 安装Python
RUN apt-get install -y python3-pip# 设置工作目录
WORKDIR /app# 缓存依赖提升构建速度
COPY requirements.txt .
RUN pip install -r requirements.txt# 拷贝代码
COPY . .# 使用缓存加速模型加载
ENV HF_HOME=/cache/huggingface
RUN mkdir -p $HF_HOMECMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "5000"]
Helm Chart部署模板(helm-chart/values.yaml
)
image:repository: registry.example.com/modeltag: latestpullPolicy: IfNotPresentreplicaCount: 3service:type: ClusterIPport: 80targetPort: 5000resources:limits:cpu: "4"memory: "16Gi"nvidia.com/gpu: 1
📊 实战案例研究
一次完整变更流程(🛠️ 从提交到部署)
- 代码提交:开发者提交PR至
main
分支; - CI阶段:GitHub Actions自动运行单元测试、模型推理测试;
- 构建镜像:生成带SHA哈希的新Docker镜像;
- 推送镜像:上传至私有镜像仓库;
- 部署预发:使用Helm部署到预发集群;
- 人工审核:团队确认后触发生产部署;
- 蓝绿切换:通过K8s Service切换流量;
- 监控告警:查看新版本是否稳定运行;
- 回滚准备:保留上一版本以备不时之需。
复杂依赖管理(📦 多模型协同部署)
对于依赖多个子模型的大项目,可使用以下结构:
models/
├── encoder/
│ └── model.pth
├── decoder/
│ └── model.pth
└── tokenizer/└── vocab.json
在Docker中统一挂载:
COPY models/ /models/
ENV MODEL_PATH=/models
生产问题诊断(🔍 日志+追踪)
使用OpenTelemetry采集分布式追踪数据:
from opentelemetry import trace
from opentelemetry.exporter.jaeger.thrift import JaegerExporter
from opentelemetry.sdk.trace import TracerProvider
from opentelemetry.sdk.trace.export import BatchSpanProcessortrace.set_tracer_provider(TracerProvider())
jaeger_exporter = JaegerExporter(agent_host_name="jaeger",agent_port=6831,
)
trace.get_tracer_provider().add_span_processor(BatchSpanProcessor(jaeger_exporter))tracer = trace.get_tracer(__name__)
with tracer.start_as_current_span("model_inference"):# 执行推理逻辑
👥 团队协作与最佳实践
Git工作流(🌀 分支策略推荐)
✅ 推荐使用 GitFlow 或 GitHub Flow。
代码审查重点(🔍 AI项目特别关注)
类别 | 审查重点 |
---|---|
模型部分 | 训练参数合理性、过拟合风险 |
数据处理 | 数据泄露、清洗逻辑 |
API接口 | 输入输出格式、异常处理 |
性能 | 并发控制、资源占用情况 |
文档自动化(📚 自动生成API文档)
使用FastAPI内置Swagger UI:
from fastapi import FastAPIapp = FastAPI()@app.get("/predict")
async def predict(prompt: str, max_new_tokens: int = 100):"""生成文本- **prompt**: 输入提示词- **max_new_tokens**: 最大生成长度"""return {"response": "Hello World"}
访问 /docs
查看交互式文档。
🧠 总结与扩展思考
CI/CD成熟度模型(📉 从初级到高级)
阶段 | 特征 |
---|---|
L1 | 手动构建与部署 |
L2 | 自动化测试 |
L3 | 自动化部署 |
L4 | 金丝雀发布 + 回滚 |
L5 | 全链路可观测 + 自动修复 |
DevOps与MLOps的融合
维度 | DevOps | MLOps | 融合要点 |
---|---|---|---|
关注点 | 应用部署 | 模型生命周期 | 模型注册、实验跟踪 |
工具 | Jenkins/GitLab CI | MLflow/Kubeflow | 统一CI/CD平台 |
流程 | Code → Build → Deploy | Data → Train → Evaluate | 加入模型评估阶段 |
持续交付对团队文化的影响
- 提升交付效率
- 减少人为失误
- 增强质量保障意识
- 促进跨职能协作
📦 附录:安装与部署指南
Prometheus + Grafana部署
# 安装Prometheus
helm repo add prometheus-community https://prometheus-community.github.io/helm-charts
helm install prometheus prometheus-community/kube-prometheus-stack# 安装Node Exporter(用于采集GPU信息)
kubectl apply -f https://raw.githubusercontent.com/NVIDIA/gpu-monitoring-tools/master/exporters/node-feature-discovery/nfd.yaml
📚 参考资料
- GitHub Actions官方文档:https://docs.github.com/en/actions
- Helm官方文档:https://helm.sh/docs/
- Argo Rollouts文档:https://argoproj.github.io/argo-rollouts/
- OpenTelemetry官方文档:https://opentelemetry.io/docs/
📣 下一篇预告
第51篇:大模型服务的可观测性设计 —— 日志、监控、追踪三位一体
敬请关注!
📌 欢迎订阅专栏《AI大模型应知应会100篇》持续更新中!
相关文章:
《AI大模型应知应会100篇》第50篇:大模型应用的持续集成与部署(CI/CD)实践
第50篇:大模型应用的持续集成与部署(CI/CD)实践 🧾 摘要 在AI大模型开发中,随着模型版本迭代频繁、依赖复杂、部署环境多样,构建一套高效可靠的持续集成与持续交付(CI/CD)流程显得尤…...
Python基于Django的在线考试系统【附源码、文档说明】
博主介绍:✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇&…...
windows操作系统开机自启(自动启动) 运行窗口 shell:startup 指令调出开机自启文件夹
打开 “运行” 窗口,输入 shell:startup 把需要开机自启程序的快捷启动方式复制到启动文件夹 (注意:一定要复制快捷启动方式,可以右键启动的文件,发送到桌面快捷方式,如果直接把启动的文件放进去ÿ…...
笔记本外接显示器检测不到hdmi信号
原因:AMD显卡驱动挂了。 其他 异常特征:显示亮度被禁用,无法调整。 修复步骤: ① ②点击更新驱动程序...
论软件的可靠性设计
目录 摘要(300~330字) 正文(2000~2500字,2200字为宜) 背景介绍(500字做左右) 论点论据(1500字做左右)...
【Linux】基础开发工具
L i n u x Linux Linux 环境下的开发工具非常丰富,是程序员和开发人员进行高效开发的必备基础。 L i n u x Linux Linux 环境下的开发工具主要包括 y u m yum yum 软件包管理器、 v i m vim vim 文本编辑器、 g c c / g gcc/g gcc/g 编译器、 g d b gdb gdb 调试工…...
【编程干货】本地用 Ollama + LLaMA 3 实现 Model Context Protocol(MCP)对话服务
模型上下文协议(MCP)本身提供的是一套标准化的通信规则和接口,简化了客户端应用的开发。 MCP 实际上是一套规范,官方把整套协议分成「传输层 协议层 功能层」三大块,并对初始化握手、能力协商、数据/工具暴露、安全…...
华为策略路由
路由策略:是对路由条目进行控制,通告控制路由条目影响报文的转发路径。路由策略为控制平面。 策略路由:是根据报文特征,认为的控制报文从某个即可转发出去,不修改路由表。即策略路由为在转发平面。 路由策略 策略路由…...
Spring Boot3 实现定时任务 每10分钟执行一次,同时要解决分布式的问题 区分不同场景
在Spring Boot 3中实现分布式定时任务,确保多实例环境下任务仅执行一次,可以采用以下方案: 方案一:Redis分布式锁(推荐) import org.springframework.data.redis.core.StringRedisTemplate; import org.sp…...
山东大学项目实训-创新实训-法律文书专家系统-项目报告(四)
项目简介 法律文书专家系统是一个 Web 应用,提供法律文书摘要提取、法律预测报告生成和法律考试问题答疑三大核心功能。用户需要登录或注册后,进入主页面选择所需功能,进行相应的操作。 用户群体 律师:需要快速提取法律文书摘要…...
sqli-labs靶场通关保姆级教学(Get传输篇)Less-1Less-10
sqli-labs靶场通关保姆级教学(Get传输篇)Less-1~Less-10(纯手注) sqli - labs 靶场是一个专门用于网络安全学习和测试 SQL 注入漏洞的开源靶场。包含报错盲注、布尔盲注、基于联合查询的 SQL 注入等多种类型的 SQL 注入漏洞&…...
Day17 聚类算法(K-Means、DBSCAN、层次聚类)
一、聚类算法 1. K-Means 聚类 原理:K-Means 是一种基于划分的聚类算法,目标是将 n n n 个样本划分到 k k k 个簇中,使得簇内样本的相似度尽可能高,簇间样本的相似度尽可能低。算法通过迭代的方式,不断更新簇的质心…...
构建 Web 浏览 AI Agent:Pydantic + MCP 实现指南
在当今快节奏的数字世界中,高效地从网站提取和总结信息可以成为改变游戏规则的利器。大型语言模型(LLM)提供了令人难以置信的能力,但它们本身并不知道如何浏览网络或获取实时内容。 本文演示如何创建一个由Python驱动的AI Agent,它能够阅读和总结网站内容,使其成为研究人员…...
解决 pnpm dev 运行报错的坎坷历程
解决 pnpm dev 运行报错的坎坷历程 在项目开发过程中, 在clone完别人的代码后启动项目时:nodejs 和 pnpm版本都没问题 ,但是 无法运行 pnpm dev 命令启动项目时,往往会遇到各种各样的报错问题。最近在处理 yudao-ui-admin-vue3 项…...
从贴牌到品牌:出海官网如何让中国制造“贵”起来?
在全球经济一体化的当下,中美关税战如同一记重锤,给国际贸易格局带来了巨大震荡。自贸易摩擦爆发以来,双方多次调整关税政策,涉及的商品种类不断增多,税率持续攀升,众多中国企业的出口业务遭受重创…...
ultralytics框架进行RT-DETR目标检测训练
自DETR提出以来,其采用匈牙利匹配方式真正的实现了端到端检测效果,避免了NMS等后处理过程,同时,相较CNN的局部特征提取,其凭借着Transformer强大的全局特征提取能力,在目标检测领域可谓大杀四方,…...
SQLite基本函数
目录 1 核心函数和聚合函数 1.1 核心函数 1.2 聚合函数 2 字符串函数 3 日期和时间函数 4 数学函数 5 JSON函数 (SQLite 3.9.0) 6 窗口函数 (SQLite 3.25.0) 7 加密和安全函数 8 其他实用函数 9 C#代码示例:使用SQLite函数 9.1 准备工作 9.2 代码实现…...
使用Java和LangChain4j实现人工智能:从分类到生成式AI
人工智能(AI)从科幻小说中的梦想逐步演变为现实,驱动了从语音助手到自动驾驶汽车的各种应用。AI 的发展主要基于两种方法:基于编码的传统方法和基于机器学习的现代方法。机器学习通过神经网络和大量训练数据实现分类、生成等任务&…...
数据分析指标体系
目录 1. 构建业务公式,用量化逻辑串联业务 1.1 明确公式结果 1.2 拆解业务过程 1.3 构建计算关系(yaxb) 经典的成交额业务公式 小疑问: 如何让自己的指标看起来更专业? 量化业务过程的量化,到底是什…...
分布式、高并发-Day04
以下是 Day 4 详细学习内容(CAS 与原子操作实战,30 分钟完整计划),包含原理解析、分步代码实战和性能对比: 📖 今日学习目标 掌握 CAS(Compare-And-Swap)无锁算法的核心原理学会使…...
计算机中的逻辑运算
目录 一、总览 二、详情 1. 基本逻辑运算(与、或、非): 2. 其他常用的逻辑运算(异或、同或、与非、或非): 在计算机中,逻辑运算是构成数字电路和计算机程序基础的关键操作。它们处理的是真值…...
Dify - Stable Diffusion
Stable Diffusion 是一种基于文本提示生成图像的工具,Dify 已经实现了访问 Stable Diffusion WebUI API 的接口,因此你可以直接在 Dify 中使用它。以下是在 Dify 中集成 Stable Diffusion 的步骤。 1. 初始化本地环境 推荐使用装有较强 GPU 的机器来安…...
weapp-vite - 微信小程序工具链的另一种选择
weapp-vite - 微信小程序工具链的另一种选择 前言 weapp-vite 是由 笔者 icebreaker 开发的一个基于 vite 的现代化微信小程序开发工具链。我给它设定的目标初心是: 为小程序开发者带来笑容。 自从在 2024 年的 8 月正式发布之后,到现在也过了将近 9 个月的时间。…...
图形化编程重塑 IoT 边缘开发:技术革新与生态竞合新范式
本文以图形化编程技术为核心,深度剖析其在 IoT 边缘开发中的创新应用与行业变革。通过对传统开发困局的系统解构,结合 iVX 项目等典型案例,揭示图形化编程如何通过可视化逻辑设计、自动代码生成及 AI 驱动架构,实现开发效率与应用…...
node-sass安装失败解决方案
1、python环境问题 Error: Cant find Python executable "python", you can set the PYTHON env variable. 提示找不到python2.7版本, 方法一:可安装一个python2.7或引用其他已安装的python2.7 通过设置环境变量可以解决; 方法二&…...
PDF内容搜索--支持跨文件夹多文件、组合词搜索
平时我们接触到的PDF文档特别多,需要对PDF文档做一些处理,那么今天给大家带来的这两个软件非常的棒,可以帮你提升处理文档的效率。 PDF内容搜索 快速检索 我用夸克网盘分享了「PDF搜索PDF 转长图.zip」,点击链接即可保存。打开「…...
我用cursor 搭建了临时邮箱服务-Temp Mail 365
用业余时间搭建了一个临时邮箱,对于后端程序员出身的我,对前端了解的不太多,有了cursor的帮助,补齐了自己的短板,搭建了这个服务,下面对临时邮箱架构设计与安全性做一个分析。 https://temp-mail-365.com 临…...
RN学习笔记 ✅
太无聊了最近,找点事做,学一下RN丰富一下技术栈🫡。但是开发APP除了RN,还有一种选择就是WebView,但是基于WebView的APP的性能被普遍认为不如RN,因为WebView本质上是一个容器,用于在应用中嵌入网…...
使用原生 CSS 实现轮播
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、核心新特性1. ::scroll-button()2. ::scroll-marker()二、基础实现步骤1. 创建滚动容器2. 添加滚动按钮3. 集成滚动标记三、高级功能1. 滚动驱动动画2. 状态查询3. 响应式布局四、展示前言 最新!原生CSS也可以实现轮播…...
C语言进阶—函数(static,递归,回调,指针,内联,变参,结构体尺寸)
目录 一 static函数 1. static变量 1.静态局部变量 2.静态全局变量 2. static函数 二 递归函数 三 指针函数&函数指针 1. 指针函数 2. 函数指针 四 回调函数 五 内联函数 1. 核心特性表 2. 优缺点分析表 3. 用场景建议 3.1 推荐使用场景 3.2 应避免场景 六…...
碰一碰发视频源码搭建的定制化开发实践
在数字化营销与信息交互的浪潮中,碰一碰发视频技术以其便捷性和高效性,成为吸引用户的重要手段。然而,通用的碰一碰发视频系统往往难以满足企业多样化的业务需求。通过对源码进行定制化开发,可以打造出契合特定场景的专属系统。本…...
代码mark:脚本获取包含全角字符的字符串的长度
脚本获取包含全角字符的字符串的长度 function myLen(s) { var r 0; for (var i 0; i < s.length; i) { var c s.charCodeAt(i); // Shift_JIS: 0x0 ~ 0x80, 0xa0 , 0xa1 ~ 0xdf , 0xfd ~ 0xff // Unicode : 0x0 &…...
FPGA----基于ZYNQ 7020实现petalinux并运行一个程序
引言:上一节我们讲到了使用Alinx 7020b自带的sd卡中的petalinux进行epics的编译,但此种方案个性化程度不足。如:我们项目需要FPGA侧的配合,那么我们需要重新编译petalinx。 注意:本文的知识点来自下面两篇文章&#x…...
微服务架构详解
微服务架构的思想本质 我们为什么需要微服务架构,它一定是为了解决我们某些问题才出现了。这篇文章我们讨论下微服务架构模式所解决的问题,带来的挑战,以及他的核心思想本质。 1 早期的服务架构 上图是一个典型的服务分层架构:…...
error:0308010C:digital envelope routines::unsupported
npm run dev 报错: \node_modules\webpack\hot\dev-server.jsnode:internal/crypto/hash:71 this[kHandle] new _Hash(algorithm, xofLen); Error: error:0308010C:digital envelope routines::unsupported opensslErrorStack: [ error:03000086:digital env…...
Blender 初学者指南 以及模型格式怎么下载
glbxz.com glbxz.com 可以直接下载Blender格式模型 第 1 步:打开 这就是 blender 打开时的样子。 您面对的是左侧和右侧的工具栏,顶部是文件作,底部是时间轴,中间是 3D 视图。 Blender 的默认起始网格是一个立方体,…...
开个帖子记录一下自己学spring源码的过程
一、写在开头 简单记录下来时路,以后也能回头看看鼓励下自己。我以前不喜欢拍照,觉得没什么意思,有一天百度云盘给我推不知道什么时候从相册推到百度云相册的照片,那是我口罩时期在家上体育课的照片,我现在回头望过去…...
【coze】工作流(B站视频总结改写)
【coze】工作流(B站视频总结改写) 1.创建智能体2.工作流2.1 获取视频文案2.2 串联试运行2.3 二次创作(大模型)2.4 MD格式2.5 输出2.6 发布并调用 关于工作流: 简单业务, 如果智能体的逻辑比较简单…...
文化符号与隐形的社会话语权力:解码布尔迪厄理论下的意识形态操控机制
文化符号与隐形的社会话语权力:解码布尔迪厄理论下的意识形态操控机制 引言:符号背后的权力博弈 在当代社会,文化符号早已超越其表层的审美或实用功能,成为维系社会等级、塑造意识形态的隐形权力工具。从故宫博物院的金色琉璃瓦…...
一个关于fsaverage bem文件的说明
MNE文档:基于模板 MRI 的 EEG 前向算子 Head model and forward computation 在了解了脑图谱发展的过程之后,对脑的模版有了更深的认识,所以,对于之前使用的正向的溯源文件,进行一下解析,查看包含的信息&a…...
如何解决Kafka集群中Broker磁盘IO瓶颈?
针对Kafka集群Broker磁盘IO瓶颈问题,这里从实际运维场景出发给出解决方案: 1. 分区负载均衡优化 分区迁移策略 # 查看Topic分区分布(识别热点Broker) kafka-topics --bootstrap-server broker1:9092 --describe --topic high_t…...
42 python http之urllib库
作为办公室牛马,日常工作中总少不了和网络数据打交道。比如从公司内部系统抓取数据做报表。Python urllib 库用于操作网页 URL,并对网页的内容进行抓取处理 一、Urllib 基础入门 urllib 是 Python 内置的一个强大的处理 URL 和网络请求的库,它包含了多个模块,每个模块都有…...
如何把阿里云a账号下面的oss迁移到阿里云b账号下面(同区域)
1.登录a账号进入bucket选择同区域复制 2.登录b账号进入bucket选择bucket授权策略,选择接受复制对象,手动输入,然后是a账号的id和角色名字即可。 3.然后在去a账号保存下同步任务,开始同步了就。...
cuda多维线程的实例
1、注意:在多维中的变化时与平常的不一样,如下图所示,横向变换x,纵向变换y 2、cuda内置变量: 1、thread(线程): 一个线程可作为一个运算单元,多个thread可组成一个block(…...
哈希表的设计
1. 哈希表的基本原理 哈希表是一种通过 哈希函数 将元素的键(Key)映射到存储位置的数据结构。 哈希函数 的作用:通过键值计算存储位置,公式一般为 index hash(key) % capacity。 哈希冲突:不同的键可能被映射到同一…...
前端取经路——入门取经:初出师门的九个CSS修行
大家好,我是老十三,一名前端开发工程师。CSS就像前端修行路上的第一道关卡,看似简单,实则暗藏玄机。在今天的文章中,我将带你一起应对九大CSS难题,从Flexbox布局到响应式设计,从选择器优先级到B…...
网络安全等级保护有关工作事项[2025]
公安部发布公网安〔2025〕1846号文件,关于对网络安全等级保护有关共工作事项的进一步说明 一、备案相关问题 1、如何执行系统备案动态更新工作? 全面梳理与重新填报: 答复:运营者需**全面梳理已备案系统**的情况,对于已完成定…...
柯西不等式应用题
第一种方法是作两个相似三角形ABC和CDE,求出AE长度为3。那么BD最大长度为3。 方法二:柯西不等式(a+b)(c+d)≥(ac+bd) (1√(5-2x&…...
聚焦多种检测场景,华大基因推出全流程本地化检测综合解决方案
“从毫米到微米,神秘的微观世界被发现;从微米到纳米,生命的本源被不断认知。”在时代背景及战略机遇的多重影响下,精准医学已成为新兴的发展趋势,对医学模式的发展具有重要的意义。一直以来,华大基因都致力…...
职场口语之名词从句
目录 一、主语从句 二、宾语从句 三、表语从句 四、同位语从句 一、主语从句 1. Who will win the game is uncertain. 谁将赢得这场比赛还不确定。 2. Why he was late isnt clear. 他为什么迟到还不清楚。 3. What we should do next is important. 我们接下来应该做什么…...