用 Docker 部署语音识别服务(funasr)

第一步:构建并本地运行语音识别 API 服务

我们要先完成的,是 创建一个可以上传音频并返回识别文本的服务接口,它可以本地测试,并准备好后续 Docker 打包、Dify 调用。

bash 复制代码
mkdir funasr_service && cd funasr_service
touch app.py funasr_local.py requirements.txt Dockerfile
  1. 创建并编辑 app.py
python 复制代码
from fastapi import FastAPI, UploadFile, File
from fastapi.middleware.cors import CORSMiddleware
from funasr_local import infer
import os

app = FastAPI()

# 跨域支持
app.add_middleware(
    CORSMiddleware,
    allow_origins=["*"],  # 生产环境请替换为指定域名
    allow_credentials=True,
    allow_methods=["*"],
    allow_headers=["*"],
)

@app.get("/")
def index():
    return {"message": "FunASR Speech Recognition Service is running."}

@app.post("/recognize")
async def recognize_audio(file: UploadFile = File(...)):
    tmp_path = f"/tmp/{file.filename}"
    with open(tmp_path, "wb") as f:
        f.write(await file.read())

    try:
        text = infer(tmp_path)
    except Exception as e:
        return {"error": str(e)}

    os.remove(tmp_path)
    return {"text": text}

if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="0.0.0.0", port=5077)
  1. 创建并编辑 funasr_local.py
python 复制代码
from funasr import AutoModel

# 初始化模型(只加载一次)
model = AutoModel(
    model="paraformer-zh",
    model_revision="v2.0.9",    # 确保是有效版本
    disable_update=True,         # 禁止自动更新,启动更快
    vad_model="fsmn-vad",
    vad_model_revision="v2.0.4"
    # 去掉 punc_model 参数,避免加载失败
)

def infer(audio_path: str) -> str:
    """
    传入音频文件路径,返回识别文本
    """
    result = model.generate(input=audio_path)
    return result[0]['text']

3. 创建并编辑 requirements.txt

python 复制代码
fastapi
uvicorn
torch
torchaudio
torchvision
funasr  
python-multipart
  1. 创建Dockerfile
python 复制代码
# 使用官方 Python 3.10 轻量版镜像
FROM python:3.10-slim

# 设置工作目录
WORKDIR /app

# 复制项目文件到容器
COPY . /app

# 升级 pip 并安装依赖
RUN pip install --upgrade pip && \
    pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cpu && \
    pip install -r requirements.txt

# 暴露端口(根据你的服务端口)
EXPOSE 5077

# 启动命令,替换成你自己的启动脚本
CMD ["python", "app.py"]

5 。构建docker镜像

python 复制代码
cd D:\funasr_service
docker build -t funasr_service_image .

经过漫长的等待之后

执行命令

python 复制代码
docker run -d -p 5077:5077 --name funasr_service funasr_service_image

容器成功运行

  • -d:后台运行容器

  • -p 5077:5077:把容器的5077端口映射到主机的5077

  • --name funasr_service:容器名称

  • funasr_service_image:你构建的镜像

可以调用就行

如果因为那些地方不懂 可以直接私信联系博主获取调试好的tar文件 直接使用docker load就好 方便省事但不免费(博主也想加个鸡腿)

相关推荐
掘根2 小时前
【微服务即时通讯】入口网关子服务
运维·微服务·架构
STRUGGLE_xlf2 小时前
MAC电脑Docker Desktop部署n8n
macos·docker·eureka
曦月合一2 小时前
访问服务器json接口,将json字符串解析成json格式的demo
运维·服务器·json
开开心心_Every2 小时前
轻松加密文件生成exe,无需原程序解密
运维·服务器·网络·电脑·excel·consul·memcache
cool32002 小时前
二进制基于kubeasz部署 K8s 1.34.x 高可用集群实战指南-第三章:Harbor 私有镜像仓库部署(3-4)
云原生·容器·kubernetes
Lxinccode2 小时前
wsl(1) : docker里面的容器访问wsl的服务
运维·docker·容器·wsl容器访问宿主机
云川之下2 小时前
【k8s】rbac权限框架和鉴权、鉴权概念
云原生·容器·kubernetes
pzs02212 小时前
docker的使用
docker
失伟2 小时前
iSulad部署以及使用方案
运维·容器