Ubuntu24.04/Whisper/Docker Compose 本地部署

Ubuntu24.04/Whisper/Docker Compose 本地部署

简介

Whisper 是 OpenAI 于 2022 年 9 月开源的一款自动语音识别系统。它最突出的特点在于其鲁棒性,即使在面对口音、背景噪音或专业术语等复杂场景时,也能保持较高的识别准确性,在英语语音识别上已接近人类水平 。

核心技术与工作原理

Whisper 的强大能力源于其独特的技术设计,主要包括以下几点:

  • 端到端的 Transformer 架构:Whisper 采用编码器-解码器的 Transformer 模型架构 。输入音频被分割成30秒的片段并转换为对数梅尔频谱图,然后由编码器提取特征,解码器根据这些特征预测对应的文本 。
  • 大规模多任务训练:模型在从互联网收集的、高达68万小时的多语言(支持近百种语言)和多任务监督数据上进行训练,数据集的巨大规模和多样性是其强大泛化能力的基础 。训练时,模型会交替执行多项任务,如多语言语音转录、语音翻译(到英语)、语言识别以及生成带短语级时间戳的文本等 。
  • 统一的多任务格式:通过引入特殊的标记,Whisper 使用一个统一的模型来处理所有任务。这些标记指示模型当前需要执行的具体任务,这种设计使得单个模型能够替代传统语音处理流程中的多个阶段 。

模型规格与选择

Whisper 提供了多种规模的模型,以适应不同场景下对速度和精度的权衡需求 。下面的表格整理了可用的模型及其大致参数,你可以根据实际需求(如对准确率的要求、可用的计算资源)进行选择。

模型名称参数量磁盘空间适用场景
tiny约 39 M~75 MB快速演示,对资源极度敏感
base约 74 M~140 MB平衡速度与基本准确率
small约 244 M~480 MB良好准确率与速度的折中
medium约 769 M~1.5 GB追求较高准确率
large约 1550 M~3 GB最高准确率,支持所有任务

主要应用场景

凭借其高准确率和多语言支持,Whisper 可应用于多种场景:

  • 会议记录与转录:自动生成会议纪要,将音频内容转换为可编辑的文本,提高效率 。
  • 视频字幕生成:为视频内容自动生成字幕,提升内容的可访问性和传播效果 。
  • 多语言翻译与转录:支持将多种语言的语音直接转录或翻译成英语文本,便于跨语言沟通 。
  • 语音助手与智能客服:作为语音接口的核心,提升语音助手对指令理解的准确性 。
  • 无障碍技术:通过实时语音转文本服务,为听障人士提供沟通便利 。

如何使用 Whisper

Whisper 的使用非常灵活,主要有以下几种方式:

  • 命令行直接使用:安装后,可通过简单的命令处理音频文件,例如 whisper audio.wav --model small --language Chinese
  • 在 Python 代码中调用:在 Python 项目中集成语音识别功能通常只需几行代码,非常方便 。
  • 通过 API 调用:OpenAI 也提供了 Whisper 的 API 接口,适合不希望本地部署的云端应用 。

总结与优势

总而言之,Whisper 的核心优势可以概括为三点:

  1. 高鲁棒性:得益于海量多样的训练数据,在嘈杂环境、口音等方面表现出色 。
  2. 多功能性:一个模型支持转录、翻译、时间戳等多种任务,覆盖近百种语言 。
  3. 开放与便捷:完全开源,支持本地部署以保护数据隐私,并提供从命令行到 API 的多种易用接口 。

本地部署

  • 运行效果:使用 small 模型以及使用精确的转录参数;整体识别还可以,但依旧有很多同韵母的字和同音字会识别错误;使用 medium 模型会出现一个奇怪的问题,转录文字为繁体字;large 模型运行时间较长(3060 显卡)
  • 优化:音频预处理、优化转录参数、阶段处理
    • 结果也大差不差,最终生成的文本或多或少都有点问题,还是直接交给大模型根据语义做修正并分析吧
  • 转 FastAPI 服务
      • 增加 fastapi、uvicorn、python-multipart 依赖
      • 修改 Dockerfile 程序挂载
      • 修改 docker-compose.yml 端口映射

测试语句:

curl -X POST "http://localhost:7862/transcribe" -F "[email protected]"

更新配置:

# whisper_fastapi.pyfrom fastapi import FastAPI, File, UploadFile, HTTPException from fastapi.responses import JSONResponse import whisper import tempfile import os import numpy as np from scipy import signal import librosa import uvicorn import soundfile as sf # 初始化FastAPI应用 app = FastAPI( title="Whisper音频转录API", description="基于OpenAI Whisper的高级音频转录服务", version="1.0.0")# 初始化全局变量 model =Nonedefload_whisper_model():global model if model isNone: model = whisper.load_model("large")return model defpreprocess_audio(audio_path):""" 音频预处理:重采样、降噪、标准化 """try:# 加载音频 y, sr = librosa.load(audio_path, sr=16000)# 重采样到16kHz# 应用高通滤波器去除低频噪声 b, a = signal.butter(4,100,'highpass', fs=sr) y = signal.filtfilt(b, a, y)# 音频标准化 y = y / np.max(np.abs(y))# 保存处理后的临时文件 temp_path = tempfile.mktemp(suffix='.wav') sf.write(temp_path, y, sr)return temp_path except Exception as e:print(f"音频预处理失败: {str(e)}")return audio_path # 如果预处理失败,返回原始文件@app.on_event("startup")asyncdefstartup_event():"""应用启动时加载模型"""print("正在加载Whisper模型...") load_whisper_model()print("Whisper模型加载完成!")@app.post("/transcribe", summary="音频转录", description="上传音频文件并返回转录文本")asyncdeftranscribe_audio(file: UploadFile = File(...)):""" 转录音频文件为文本,使用优化参数 - **file**:音频文件,支持MP3、WAV、OGG、M4A、FLAC等格式 """# 更灵活的文件类型检查 valid_extensions ={'.mp3','.wav','.ogg','.m4a','.flac','.aac','.m4b'} file_extension = os.path.splitext(file.filename)[1].lower()if file_extension notin valid_extensions:raise HTTPException( status_code=400, detail=f"不支持的文件类型: {file_extension}。请上传音频文件: {valid_extensions}") temp_path =None processed_audio =Nonetry:# 保存上传文件到临时位置with tempfile.NamedTemporaryFile( delete=False, suffix=file_extension )as temp_file: content =awaitfile.read() temp_file.write(content) temp_path = temp_file.name # 音频预处理 processed_audio = preprocess_audio(temp_path)# 加载模型 model = load_whisper_model()# 使用优化的转录参数 result = model.transcribe( processed_audio, language="zh",# 指定中文语言 task="transcribe", beam_size=5,# 增加束搜索大小以提高准确性 best_of=5,# 生成多个候选结果选择最佳 temperature=0.0,# 使用确定性输出 patience=1.0,# 束搜索耐心参数 suppress_tokens=[-1]# 抑制不必要的token)# 返回转录结果return JSONResponse(content={"status":"success","text": result["text"],"language": result.get("language","zh"),"file_name":file.filename })except Exception as e:raise HTTPException(status_code=500, detail=f"转录过程中出现错误: {str(e)}")finally:# 清理临时文件if temp_path and os.path.exists(temp_path): os.unlink(temp_path)if processed_audio and processed_audio != temp_path and os.path.exists(processed_audio): os.unlink(processed_audio)@app.get("/health", summary="健康检查", description="检查服务是否正常运行")asyncdefhealth_check():"""健康检查端点"""return JSONResponse(content={"status":"healthy","model_loaded": model isnotNone})@app.get("/", summary="根端点", description="API基本信息")asyncdefroot():"""根端点,返回API基本信息"""return{"message":"Whisper音频转录API服务","version":"1.0.0","endpoints":{"transcribe":"/transcribe (POST)","health":"/health (GET)","docs":"/docs (GET)","redoc":"/redoc (GET)"},"model":"large","supported_languages":"近百种语言,支持中文转录"}if __name__ =="__main__": uvicorn.run( app, host="0.0.0.0", port=7862)
FROM nvidia/cuda:12.4.1-cudnn-devel-ubuntu22.04 # 设置工作目录 WORKDIR /app RUN sed -i 's/archive.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list && \ sed -i 's/security.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list # 安装系统依赖 RUN apt-get update && apt-get install -y \ ffmpeg \ python3 \ python3-pip \ python3-venv \ && rm -rf /var/lib/apt/lists/* \ && ln -sf /usr/bin/python3 /usr/bin/python # 复制依赖文件 COPY requirements.txt . # 安装Python依赖 RUN pip install --no-cache-dir -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/ # 复制应用代码(修改为 FastAPI 文件) COPY whisper_fastapi.py . # 暴露 FastAPI 端口 EXPOSE 7862 # 设置环境变量:模型缓存路径 ENV WHISPER_MODEL_CACHE=/root/.cache/whisper # 启动应用(修改为 FastAPI 启动命令) CMD ["uvicorn", "whisper_fastapi:app", "--host", "0.0.0.0", "--port", "7862"] 
# docker-compose.ymlservices:whisper-api:build: . container_name: whisper-fastapi ports:-"7862:7862"volumes:# 持久化缓存模型- ./model_cache:/root/.cache/whisper # 可选:挂载音频文件目录- ./audio_files:/app/audio_files environment:- WHISPER_MODEL=medium restart: unless-stopped # 可选:设置资源限制deploy:resources:reservations:devices:-driver: nvidia count:2capabilities:[gpu]
在这里插入图片描述


在这里插入图片描述

Gradio 服务

# whisper_gradio.pyimport gradio as gr import whisper import tempfile import os import numpy as np from scipy import signal import librosa # 初始化全局变量 model =Nonedefload_whisper_model():global model if model isNone: model = whisper.load_model("medium")return model defpreprocess_audio(audio_path):""" 音频预处理:重采样、降噪、标准化 """try:# 加载音频 y, sr = librosa.load(audio_path, sr=16000)# 重采样到16kHz# 应用高通滤波器去除低频噪声 b, a = signal.butter(4,100,'highpass', fs=sr) y = signal.filtfilt(b, a, y)# 音频标准化 y = y / np.max(np.abs(y))# 保存处理后的临时文件 temp_path = tempfile.mktemp(suffix='.wav') librosa.output.write_wav(temp_path, y, sr)return temp_path except Exception as e:print(f"音频预处理失败: {str(e)}")return audio_path # 如果预处理失败,返回原始文件deftranscribe_audio(audio_file):""" 转录音频文件为文本,使用优化参数 """# 加载模型 model = load_whisper_model()# 安全检查上传的文件if audio_file isNone:return"错误:请上传一个音频文件。"try:# 音频预处理 processed_audio = preprocess_audio(audio_file)# 使用优化的转录参数 result = model.transcribe( processed_audio, language="zh",# 指定中文语言 task="transcribe", beam_size=5,# 增加束搜索大小以提高准确性 best_of=5,# 生成多个候选结果选择最佳 temperature=0.0,# 使用确定性输出 patience=1.0,# 束搜索耐心参数 suppress_tokens=[-1]# 抑制不必要的token)# 清理临时文件if processed_audio != audio_file:try: os.unlink(processed_audio)except:passreturn result["text"]except Exception as e:returnf"转录过程中出现错误:{str(e)}"# 创建Gradio界面with gr.Blocks(title="Whisper音频转录")as demo: gr.Markdown("# 🎤 Whisper音频转录") gr.Markdown("上传MP3、WAV、OGG等音频文件,使用优化的参数将其转换为文本")with gr.Row():with gr.Column(): audio_input = gr.Audio( sources=["upload"],type="filepath", label="上传音频文件", interactive=True) submit_btn = gr.Button("开始转录", variant="primary")with gr.Column(): text_output = gr.Textbox( label="转录结果", placeholder="转录文本将显示在这里...", lines=10, max_lines=15)# 处理提交动作 submit_btn.click( fn=transcribe_audio, inputs=audio_input, outputs=text_output )# 附加说明 gr.Markdown(""" ### 使用说明 1. 点击"上传音频文件"或拖放文件到上传区域 2. 支持格式:MP3, WAV, OGG, M4A, FLAC等 3. 点击"开始转录"按钮 4. 等待转录结果出现在右侧文本框中 **注意**:首次使用需要下载Whisper Large模型,请耐心等待。转录过程可能需要较长时间。 """)if __name__ =="__main__": demo.launch( server_name="0.0.0.0", server_port=7862, share=False)

Docker 配置

FROM nvidia/cuda:12.4.1-cudnn-devel-ubuntu22.04 # 设置工作目录 WORKDIR /app RUN sed -i 's/archive.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list && \ sed -i 's/security.ubuntu.com/mirrors.aliyun.com/g' /etc/apt/sources.list # 安装系统依赖 RUN apt-get update && apt-get install -y \ ffmpeg \ python3 \ python3-pip \ python3-venv \ && rm -rf /var/lib/apt/lists/* \ && ln -sf /usr/bin/python3 /usr/bin/python # 复制依赖文件 COPY requirements.txt . # 安装Python依赖 RUN pip install --no-cache-dir -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/ # 复制应用代码 COPY whisper_gradio.py . # 暴露Gradio默认端口 EXPOSE 7862 # 设置环境变量:禁用Gradio分析,缓存模型 ENV GRADIO_ANALYTICS_ENABLED=False ENV WHISPER_MODEL_CACHE=/root/.cache/whisper # 启动应用 CMD ["python", "whisper_gradio.py"] 
# docker-compose.ymlservices:whisper-app:build: . ports:-"29999:7862"volumes:# 可选:持久化缓存模型,避免每次重启下载- ./cache:/root/.cache/whisper environment:- GRADIO_SERVER_NAME=0.0.0.0 - GRADIO_SERVER_PORT=7862 restart: unless-stopped 
# requirements.txt torch openai-whisper gradio ffmpeg-python pydub scipy librosa numpy soundfile fastapi uvicorn python-multipart 

Read more

AI 大模型落地系列|Eino 组件核心篇:用 Retriever 敲开RAG的大门

AI 大模型落地系列|Eino 组件核心篇:用 Retriever 敲开RAG的大门

声明:本文数据源于官方文档与官方实现,重点参考 Retriever 使用说明、components/retriever/interface.go、components/retriever/option.go 为什么很多人会用 Retriever,却没真正看懂 Retrieve * 1. Retriever 真正解决的,不只是“搜一下” * 2. Retrieve 动作的核心 * 3. 不要对公共 Option 理解,局限于几个小参数 * 3.1 `Index` * 3.2 `SubIndex` * 3.3 `TopK` * 3.4 `ScoreThreshold` * 3.5 `Embedding` * 3.6 不止公共 option,具体实现还能继续扩展

无线联邦学习:在保护隐私的无线网络中,让AI协同进化

无线联邦学习:在保护隐私的无线网络中,让AI协同进化

🔥作者简介: 一个平凡而乐于分享的小比特,中南民族大学通信工程专业研究生,研究方向无线联邦学习 🎬擅长领域:驱动开发,嵌入式软件开发,BSP开发 ❄️作者主页:一个平凡而乐于分享的小比特的个人主页 ✨收录专栏:无线通信技术,本专栏介绍无线通信相关技术 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖💖 无线联邦学习:在保护隐私的无线网络中,让AI协同进化 一、什么无线联邦学习? 想象这样一个场景:全国各地的医院都想联合训练一个AI模型来诊断疾病,但患者的医疗数据极其敏感,不能离开医院。传统方法是把所有数据集中到一个中心服务器,但这会造成隐私泄露风险。怎么办? 无线联邦学习就像一位“知识快递员”——它不收集原始数据,而是让各地的医院在本地训练模型,然后只把模型“更新心得”(梯度或参数)通过无线网络传给中心服务器,由服务器汇总大家的智慧,形成一个更强大的模型。 核心思想 * 数据不动模型动:原始数据永远留在本地设备 * 仅上传模型更新:只传输学习到的参数,而非数据本身 * 无线传输媒介:通过Wi-Fi、5G等无线网络进行通信 本地设备3 本地设备2 本地设

AI绘画风格迁移魔法:3分钟让普通照片变身艺术大作

想要让日常照片瞬间拥有梵高的星空漩涡,或是赛博朋克的霓虹质感吗?Stable Diffusion WebUI Forge让这一切变得触手可及。无需专业绘画技能,只需几个简单步骤,你就能成为数字艺术魔法师,将平凡的影像转化为惊艳的艺术作品。 【免费下载链接】stable-diffusion-webui-forge 项目地址: https://gitcode.com/GitHub_Trending/st/stable-diffusion-webui-forge 🎨 创意无限:探索AI绘画的奇幻风格世界 AI绘画最迷人的地方就在于它能打破艺术风格的界限。在Forge的画布系统中,你可以: * 古典艺术:梵高、莫奈、毕加索等大师风格一键应用 * 现代潮流:赛博朋克、蒸汽波、像素艺术任你挑选 * 混合创作:将不同风格元素叠加,创造独一无二的视觉体验 这张简洁的画布界面就是你的创意工作台,通过简单的拖拽和点击操作,就能开始你的艺术创作之旅。 ⚙️ 参数解密:新手必学的调参指南 对于初学者来说,掌握几个关键参数就能大幅提升作品质量: 参数名称推荐范围新手技巧CFG

DeepSeek-R1-Distill-Llama-70B:开源推理效率新高度

深度求索(DeepSeek)正式发布基于Llama-3.3-70B-Instruct蒸馏的开源大模型DeepSeek-R1-Distill-Llama-70B,该模型通过创新的强化学习与蒸馏技术结合,在保持700亿参数规模模型强大推理能力的同时,显著提升了实际应用中的运行效率,为开源社区提供了兼具高性能与部署灵活性的新一代推理模型。 【免费下载链接】DeepSeek-R1-Distill-Llama-70BDeepSeek-R1-Distill-Llama-70B:采用大规模强化学习与先验指令微调结合,实现强大的推理能力,适用于数学、代码与逻辑推理任务。源自DeepSeek-R1,经Llama-70B模型蒸馏,性能卓越,推理效率高。开源社区共享,支持研究创新。【此简介由AI生成】 项目地址: https://ai.gitcode.com/hf_mirrors/deepseek-ai/DeepSeek-R1-Distill-Llama-70B 当前大语言模型领域正面临“性能-效率”平衡的关键挑战。随着模型参数规模持续增长,虽然推理能力不断突破,但高算力需求和部署成本成为企业落地的主要