最新资讯

  • 国内Ubuntu环境Docker部署 SenseVoice

国内Ubuntu环境Docker部署 SenseVoice

2025-04-28 07:01:47 2 阅读

国内Ubuntu环境Docker部署 SenseVoice


趁热搞定了 docker 部署 SenseVoice。在这里记录一下相关的文件。
SenseVoice是一个大模型语音识别库, 支持多种语言识别,速度快,准确率高,详细介绍请参考GitHub官网:
https://github.com/FunAudioLLM/SenseVoice

本笔记主要记录使用 docker 进行部署的相关文件,文件内容放在最后。

  • Dockerfile
  • compose.yaml
  • requirements.txt
  • start.sh
  • webui.py
  • model_download.py
部署过程
1. 下载必要的模型

model_download.py

import os
import argparse


parser = argparse.ArgumentParser(description='modelscope模型下载')

parser.add_argument('--model_name', type=str, help='the model name from modelscope, example AI-ModelScope/stable-diffusion-2-1', required=True)
parser.add_argument('--local_dir', type=str, help='the model cache path.', default=os.getcwd(), required=True)


if __name__ == '__main__':
    args = parser.parse_args()

    print(f"current workspace is {os.getcwd()}")
    print(f"the model_name is {args.local_dir}/{args.model_name}")
    print(f"the local_dir is {args.local_dir}")

    try:
        from modelscope import snapshot_download
        model_dir = snapshot_download(args.model_name, local_dir=args.local_dir)
    except ImportError:
        print("modelscope was not installed! try to install...")
        os.system("pip install modelscope")
    except Exception as e:
        print(f"An error occurred: {e}")

SenseVoice项目的根目录下创建一个 download_model.py 文件,并将上述内容写入。

执行以下命令分别下载 SenseVoiceSmall speech_fsmn_vad_zh-cn-16k-common-pytorch 模型。

python3 model_download.py --model_name=iic/SenseVoiceSmall --local_dir=models/iic/SenseVoiceSmall
python3 model_download.py --model_name=iic/speech_fsmn_vad_zh-cn-16k-common-pytorch --local_dir=models/iic/speech_fsmn_vad_zh-cn-16k-common-pytorch

2、docker部署
  • Dockerfile
  • compose.yaml
  • requirements.txt
  • start.sh
  • webui.py

请在 SenseVoice项目的根目录下创建一个 docker 文件夹,并将上述文件放入 docker 文件夹内。

修改 webui.py 文件18行的 model 变量为 models/iic/SenseVoiceSmall (上述1下载模型设置的本地路径); 20行的vad_model参数修改为 models/iic/speech_fsmn_vad_zh-cn-16k-common-pytorch

webui.py

# coding=utf-8

import os
import librosa
import base64
import io
import gradio as gr
import re

import numpy as np
import torch
import torchaudio
from argparse import ArgumentParser


from funasr import AutoModel

model = "models/iic/SenseVoiceSmall"
model = AutoModel(model=model,
				  vad_model="models/iic/speech_fsmn_vad_zh-cn-16k-common-pytorch",
				  vad_kwargs={"max_single_segment_time": 30000},
				  trust_remote_code=True,
				  )

import re

emo_dict = {
	"<|HAPPY|>": "😊",
	"<|SAD|>": "😔",
	"<|ANGRY|>": "😡",
	"<|NEUTRAL|>": "",
	"<|FEARFUL|>": "😰",
	"<|DISGUSTED|>": "🤢",
	"<|SURPRISED|>": "😮",
}

event_dict = {
	"<|BGM|>": "🎼",
	"<|Speech|>": "",
	"<|Applause|>": "👏",
	"<|Laughter|>": "😀",
	"<|Cry|>": "😭",
	"<|Sneeze|>": "🤧",
	"<|Breath|>": "",
	"<|Cough|>": "🤧",
}

emoji_dict = {
	"<|nospeech|><|Event_UNK|>": "❓",
	"<|zh|>": "",
	"<|en|>": "",
	"<|yue|>": "",
	"<|ja|>": "",
	"<|ko|>": "",
	"<|nospeech|>": "",
	"<|HAPPY|>": "😊",
	"<|SAD|>": "😔",
	"<|ANGRY|>": "😡",
	"<|NEUTRAL|>": "",
	"<|BGM|>": "🎼",
	"<|Speech|>": "",
	"<|Applause|>": "👏",
	"<|Laughter|>": "😀",
	"<|FEARFUL|>": "😰",
	"<|DISGUSTED|>": "🤢",
	"<|SURPRISED|>": "😮",
	"<|Cry|>": "😭",
	"<|EMO_UNKNOWN|>": "",
	"<|Sneeze|>": "🤧",
	"<|Breath|>": "",
	"<|Cough|>": "😷",
	"<|Sing|>": "",
	"<|Speech_Noise|>": "",
	"<|withitn|>": "",
	"<|woitn|>": "",
	"<|GBG|>": "",
	"<|Event_UNK|>": "",
}

lang_dict =  {
    "<|zh|>": "<|lang|>",
    "<|en|>": "<|lang|>",
    "<|yue|>": "<|lang|>",
    "<|ja|>": "<|lang|>",
    "<|ko|>": "<|lang|>",
    "<|nospeech|>": "<|lang|>",
}

emo_set = {"😊", "😔", "😡", "😰", "🤢", "😮"}
event_set = {"🎼", "👏", "😀", "😭", "🤧", "😷",}

def format_str(s):
	for sptk in emoji_dict:
		s = s.replace(sptk, emoji_dict[sptk])
	return s


def format_str_v2(s):
	sptk_dict = {}
	for sptk in emoji_dict:
		sptk_dict[sptk] = s.count(sptk)
		s = s.replace(sptk, "")
	emo = "<|NEUTRAL|>"
	for e in emo_dict:
		if sptk_dict[e] > sptk_dict[emo]:
			emo = e
	for e in event_dict:
		if sptk_dict[e] > 0:
			s = event_dict[e] + s
	s = s + emo_dict[emo]

	for emoji in emo_set.union(event_set):
		s = s.replace(" " + emoji, emoji)
		s = s.replace(emoji + " ", emoji)
	return s.strip()

def format_str_v3(s):
	def get_emo(s):
		return s[-1] if s[-1] in emo_set else None
	def get_event(s):
		return s[0] if s[0] in event_set else None

	s = s.replace("<|nospeech|><|Event_UNK|>", "❓")
	for lang in lang_dict:
		s = s.replace(lang, "<|lang|>")
	s_list = [format_str_v2(s_i).strip(" ") for s_i in s.split("<|lang|>")]
	new_s = " " + s_list[0]
	cur_ent_event = get_event(new_s)
	for i in range(1, len(s_list)):
		if len(s_list[i]) == 0:
			continue
		if get_event(s_list[i]) == cur_ent_event and get_event(s_list[i]) != None:
			s_list[i] = s_list[i][1:]
		#else:
		cur_ent_event = get_event(s_list[i])
		if get_emo(s_list[i]) != None and get_emo(s_list[i]) == get_emo(new_s):
			new_s = new_s[:-1]
		new_s += s_list[i].strip().lstrip()
	new_s = new_s.replace("The.", " ")
	return new_s.strip()

def model_inference(input_wav, language, fs=16000):
	# task_abbr = {"Speech Recognition": "ASR", "Rich Text Transcription": ("ASR", "AED", "SER")}
	language_abbr = {"auto": "auto", "zh": "zh", "en": "en", "yue": "yue", "ja": "ja", "ko": "ko",
					 "nospeech": "nospeech"}
	
	# task = "Speech Recognition" if task is None else task
	language = "auto" if len(language) < 1 else language
	selected_language = language_abbr[language]
	# selected_task = task_abbr.get(task)
	
	# print(f"input_wav: {type(input_wav)}, {input_wav[1].shape}, {input_wav}")
	
	if isinstance(input_wav, tuple):
		fs, input_wav = input_wav
		input_wav = input_wav.astype(np.float32) / np.iinfo(np.int16).max
		if len(input_wav.shape) > 1:
			input_wav = input_wav.mean(-1)
		if fs != 16000:
			print(f"audio_fs: {fs}")
			resampler = torchaudio.transforms.Resample(fs, 16000)
			input_wav_t = torch.from_numpy(input_wav).to(torch.float32)
			input_wav = resampler(input_wav_t[None, :])[0, :].numpy()
	
	
	merge_vad = True #False if selected_task == "ASR" else True
	print(f"language: {language}, merge_vad: {merge_vad}")
	text = model.generate(input=input_wav,
						  cache={},
						  language=language,
						  use_itn=True,
						  batch_size_s=60, merge_vad=merge_vad)
	
	print(text)
	text = text[0]["text"]
	text = format_str_v3(text)
	
	print(text)
	
	return text


audio_examples = [
    ["example/zh.mp3", "zh"],
    ["example/yue.mp3", "yue"],
    ["example/en.mp3", "en"],
    ["example/ja.mp3", "ja"],
    ["example/ko.mp3", "ko"],
    ["example/emo_1.wav", "auto"],
    ["example/emo_2.wav", "auto"],
    ["example/emo_3.wav", "auto"],
    #["example/emo_4.wav", "auto"],
    #["example/event_1.wav", "auto"],
    #["example/event_2.wav", "auto"],
    #["example/event_3.wav", "auto"],
    ["example/rich_1.wav", "auto"],
    ["example/rich_2.wav", "auto"],
    #["example/rich_3.wav", "auto"],
    ["example/longwav_1.wav", "auto"],
    ["example/longwav_2.wav", "auto"],
    ["example/longwav_3.wav", "auto"],
    #["example/longwav_4.wav", "auto"],
]



html_content = """

Voice Understanding Model: SenseVoice-Small

SenseVoice-Small is an encoder-only speech foundation model designed for rapid voice understanding. It encompasses a variety of features including automatic speech recognition (ASR), spoken language identification (LID), speech emotion recognition (SER), and acoustic event detection (AED). SenseVoice-Small supports multilingual recognition for Chinese, English, Cantonese, Japanese, and Korean. Additionally, it offers exceptionally low inference latency, performing 7 times faster than Whisper-small and 17 times faster than Whisper-large.

Usage

Upload an audio file or input through a microphone, then select the task and language. the audio is transcribed into corresponding text along with associated emotions (😊 happy, 😡 angry/exicting, 😔 sad) and types of sound events (😀 laughter, 🎼 music, 👏 applause, 🤧 cough&sneeze, 😭 cry). The event labels are placed in the front of the text and the emotion are in the back of the text.

Recommended audio input duration is below 30 seconds. For audio longer than 30 seconds, local deployment is recommended.

Repo

SenseVoice: multilingual speech understanding model

FunASR: fundamental speech recognition toolkit

CosyVoice: high-quality multilingual TTS model

"""
def launch(host, port): with gr.Blocks(theme=gr.themes.Soft()) as demo: # gr.Markdown(description) gr.HTML(html_content) with gr.Row(): with gr.Column(): audio_inputs = gr.Audio(label="Upload audio or use the microphone") with gr.Accordion("Configuration"): language_inputs = gr.Dropdown(choices=["auto", "zh", "en", "yue", "ja", "ko", "nospeech"], value="auto", label="Language") fn_button = gr.Button("Start", variant="primary") text_outputs = gr.Textbox(label="Results") gr.Examples(examples=audio_examples, inputs=[audio_inputs, language_inputs], examples_per_page=20) fn_button.click(model_inference, inputs=[audio_inputs, language_inputs], outputs=text_outputs) # demo.launch() demo.launch(server_name=host, server_port=port) if __name__ == "__main__": # iface.launch() parser = ArgumentParser() parser.add_argument('--host', default="0.0.0.0", type=str, help='Server bound address') parser.add_argument('--port', default=5306, type=int, help='Port number') args = parser.parse_args() launch(args.host, args.port)

然后执行 cd docker && docker compose -f compose.yaml up。访问 5306端口,出现以下界面即部署成功。

最后附上docker相关文件的内容:

Dockerfile

FROM nvidia/cuda:11.8.0-cudnn8-devel-ubuntu22.04

ENV LANG=C.UTF-8 LC_ALL=C.UTF-8

ENV DEBIAN_FRONTEN=noninteractive
SHELL ["/bin/bash", "-c"]

RUN apt-get update -y
RUN apt-get install -y libgl1-mesa-glx libglib2.0-0 gcc g++
RUN apt-get install -y net-tools wget curl git

RUN apt-get install -y make build-essential libssl-dev zlib1g-dev libbz2-dev libreadline-dev libsqlite3-dev libffi-dev liblzma-dev

# 从国内镜像源下载安装python
# wget https://www.python.org/ftp/python/3.10.13/Python-3.10.13.tar.xz && tar Jxf Python-3.10.13.tar.xz 
RUN wget https://mirrors.huaweicloud.com/python/3.10.13/Python-3.10.13.tar.xz && tar Jxf Python-3.10.13.tar.xz
RUN cd Python-3.10.13 && ./configure --with-system-ffi --enable-shared --enable-optimizations && make && make install && echo "/usr/local/lib" | tee /etc/ld.so.conf.d/python3.conf && ldconfig
RUN python3 -V && pip3 -V

# 设置国内镜像源
RUN pip3 config set global.index-url https://mirrors.aliyun.com/pypi/simple/ && pip3 config set install.trusted-host mirrors.aliyun.com

WORKDIR /workspace
COPY ./requirements.txt ./

RUN pip3 install -r requirements.txt
RUN apt-get install -y ffmpeg

compose.yaml

services:
  sense-voice:
    container_name: sense-voice
    image: sense-voice:1.0
    restart: always
    ports:
      - 5306:5306
    environment:
      - TZ=Asia/Tokyo
      - NVIDIA_VISIBLE_DEVICES=all
    volumes:
      - ../../SenseVoice:/workspace/SenseVoice
    # command: tail -f /dev/null
    command: sh -c "sh /workspace/SenseVoice/docker/start.sh"
    deploy:
      resources:
        reservations:
          devices:
            - driver: nvidia
              capabilities: [gpu]

requirements.txt

--extra-index-url https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud/pytorch/wheel/cu121/
# torch<=2.3
# torchaudio
torch==2.1.2
torchaudio==2.1.2
torchvision==0.16.2
modelscope
huggingface
huggingface_hub
funasr>=1.1.3
numpy<=1.26.4
gradio
fastapi>=0.111.1

start.sh

#! /bin/bash
cd SenseVoice && python3 webui.py --port=5306

以上。愿看到的小伙伴不迷路。

本文地址:https://www.vps345.com/4406.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge deepseek Ollama 模型联网 API CherryStudio 科技 ai java 语言模型 人工智能 个人开发 自然语言处理 python MCP 进程 操作系统 进程控制 Ubuntu 阿里云 网络 网络安全 网络协议 llama 算法 opencv 神经网络 ssh ubuntu RTSP xop RTP RTSPServer 推流 视频 运维开发 分布式 云原生 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 rust http 开发语言 fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse ssl harmonyos 华为 typescript 计算机网络 数据库 centos oracle 关系型 安全 c# 命名管道 客户端与服务端通信 docker 容器 DeepSeek-R1 API接口 cpu 内存 实时 使用 macos adb cuda cudnn anaconda flutter Hyper-V WinRM TrustedHosts vim 后端 信息与通信 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 ESP32 camera Arduino 电子信息 笔记 C 环境变量 进程地址空间 debian PVE tcp/ip github 创意 社区 mysql 自动化 物联网 iot go 代理模式 Windsurf 统信UOS 麒麟 bonding 链路聚合 机器学习 向日葵 面试 android 鸿蒙 ffmpeg 音视频 c++ Dell R750XS YOLO efficientVIT YOLOv8替换主干网络 TOLOv8 华为云 嵌入式硬件 单片机 温湿度数据上传到服务器 Arduino HTTP udp unity ESXi websocket 学习 WSL2 uni-app 目标检测 ollama 大模型 mac 开源 性能优化 jdk intellij-idea 架构 Dify 银河麒麟 kylin v10 麒麟 v10 php pycharm ide spring boot pytorch nginx dubbo .netcore sqlserver rust腐蚀 编辑器 鸿蒙系统 前端框架 深度学习 计算机视觉 ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 vSphere vCenter 软件定义数据中心 sddc golang 计算机外设 电脑 软件需求 aws googlecloud filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 HCIE 数通 智能路由器 外网访问 内网穿透 端口映射 node.js json html5 firefox GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 flask AI编程 AIGC kubernetes 学习方法 经验分享 程序人生 vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 numpy asm HarmonyOS Next pdf Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer ue4 着色器 ue5 虚幻 bash vscode pip NPS 雨云服务器 雨云 springsecurity6 oauth2 授权服务器 token sas express mongodb windows VMware创建虚拟机 live555 源码剖析 rtsp实现步骤 流媒体开发 远程 命令 执行 sshpass 操作 rsyslog VMware安装mocOS VMware macOS系统安装 list 数据结构 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 远程控制 远程看看 远程协助 visualstudio 腾讯云 unix 低代码 ArcTS 登录 ArcUI GridItem word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 arkUI C语言 驱动开发 硬件工程 嵌入式实习 conda ipython 串口服务器 AI AI大模型 程序员 Agent bootstrap html redis zabbix 监控 系统架构 Linux YOLOv8 NPU Atlas800 A300I pro asi_bench ecmascript nextjs react reactjs stm32 llm 本地部署 api 1024程序员节 进程信号 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 apache 产品经理 agi microsoft chatgpt DeepSeek firewalld 远程工作 spring vue 中间件 web安全 可信计算技术 安全架构 网络攻击模型 ollama下载加速 n8n 工作流 workflow pygame 小游戏 五子棋 课程设计 大数据 tomcat tcpdump thingsboard postgresql gpu算力 微服务 nvidia 机器人 视觉检测 prometheus virtualenv 软件工程 能力提升 面试宝典 技术 IT信息化 .net rabbitmq 直播推流 springcloud 僵尸进程 蓝耘科技 元生代平台工作流 ComfyUI dell服务器 VMware安装Ubuntu Ubuntu安装k8s k8s yum源切换 更换国内yum源 centos-root /dev/mapper yum clean all df -h / du -sh 京东云 嵌入式 linux驱动开发 arm开发 yum 服务器配置 生物信息学 fpga开发 jar gradle chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 缓存 react.js 前端面试题 持续部署 C# MQTTS 双向认证 emqx 远程连接 rdp 实验 c语言 跨域 kylin UOS 统信操作系统 jenkins maven svn 服务器繁忙 KylinV10 麒麟操作系统 虚拟机 Vmware mybatis ddos iBMC UltraISO qt stm32项目 matplotlib 飞牛NAS 飞牛OS MacBook Pro Docker Hub docker pull 镜像源 daemon.json llama3 Chatglm 开源大模型 transformer ping++ Ubuntu Server Ubuntu 22.04.5 深度优先 图论 并集查找 换根法 树上倍增 devops springboot Reactor 设计模式 C++ safari Mac 系统 mcu jupyter kafka zotero WebDAV 同步失败 爬虫 数据集 asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 QQ bot Docker 部署 ocr webrtc 智能手机 矩阵 并查集 leetcode 银河麒麟服务器操作系统 系统激活 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 sql KingBase gpt 博客 微信 微信小程序 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 负载均衡 Qwen2.5-coder 离线部署 小程序 grafana oceanbase rc.local 开机自启 systemd threejs 3D 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 虚拟化 MacOS录屏软件 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 NAS Termux Samba okhttp postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 交换机 telnet 远程登录 LDAP 实时音视频 IIS服务器 IIS性能 日志监控 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 intellij idea micropython esp32 mqtt rpc git ansible django sqlite 服务器管理 宝塔面板 配置教程 服务器安装 网站管理 r语言 数据挖掘 数据可视化 数据分析 客户端 java-ee 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 spring cloud hibernate 工业4.0 hadoop 漏洞 kind 微信开放平台 微信公众平台 微信公众号配置 安全威胁分析 豆瓣 追剧助手 迅雷 nas 其他 政务 分布式系统 监控运维 Prometheus Grafana unity3d kvm 恒源云 致远OA OA服务器 服务器磁盘扩容 gitlab CORS dns 大模型入门 金融 传统数据库升级 银行 网络用户购物行为分析可视化平台 大数据毕业设计 jmeter 软件测试 腾讯云大模型知识引擎 Deepseek arm k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 大模型微调 测试工具 多线程服务器 Linux网络编程 自动化运维 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 gitee 报错 MQTT mosquitto 消息队列 媒体 微信分享 Image wxopensdk pillow https AISphereButler rtsp rtp outlook kamailio sip VoIP 大数据平台 eureka 框架搭建 YOLOv12 WSL win11 无法解析服务器的名称或地址 RAID RAID技术 磁盘 存储 LLM Trae IDE AI 原生集成开发环境 Trae AI Kali Linux 黑客 渗透测试 信息收集 web3.py protobuf 序列化和反序列化 安装 多进程 AI代码编辑器 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 KVM 服务器主板 AI芯片 孤岛惊魂4 华为od OD机试真题 华为OD机试真题 服务器能耗统计 开发环境 SSL证书 代码调试 ipdb adobe Ark-TS语言 Python 网络编程 聊天服务器 套接字 TCP Socket Cookie opcua opcda KEPServer安装 xrdp 远程桌面 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 游戏服务器 TrinityCore 魔兽世界 wireshark Ubuntu 24.04.1 轻量级服务器 MQTT协议 消息服务器 代码 NFS redhat dba tidb GLIBC 3d 数学建模 visual studio code 网络结构图 群晖 文件分享 iis openstack Xen VSCode 云服务 odoo 服务器动作 Server action 密码学 目标跟踪 OpenVINO 推理应用 FTP 服务器 游戏程序 崖山数据库 YashanDB cmos 硬件 输入法 开机自启动 繁忙 解决办法 替代网站 汇总推荐 AI推理 av1 电视盒子 机顶盒ROM 魔百盒刷机 rag ragflow ragflow 源码启动 mamba Vmamba keepalived 服务器部署ai模型 sonoma 自动更新 sqlite3 Anolis nginx安装 环境安装 linux插件下载 重启 排查 系统重启 日志 原因 xshell termius iterm2 毕设 neo4j 数据仓库 数据库开发 数据库架构 database shell 银河麒麟操作系统 国产化 GIS 遥感 WebGIS gcc OpenManus dify 宝塔 三级等保 服务器审计日志备份 v10 软件 chrome devtools selenium chromedriver lio-sam SLAM glibc 无桌面 命令行 elasticsearch matlab Cline ci/cd 软考 流式接口 css 系统开发 binder 车载系统 framework 源码环境 联想开天P90Z装win10 openvpn server openvpn配置教程 centos安装openvpn yolov8 CLion Cursor 实时互动 Node-Red 编程工具 流编程 Kylin-Server 国产操作系统 多个客户端访问 IO多路复用 回显服务器 TCP相关API 宕机切换 服务器宕机 LInux 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? Google pay Apple pay 压力测试 android studio 交互 curl wget 网工 大模型应用 压测 ECS Linux PID 搜索引擎 ssrf 失效的访问控制 黑苹果 数据管理 数据治理 数据编织 数据虚拟化 SSH 密钥生成 SSH 公钥 私钥 生成 sdkman idm linux 命令 sed 命令 windows日志 图形渲染 设置代理 实用教程 dash 正则表达式 职场和发展 自动化测试 性能测试 功能测试 SSH 服务 SSH Server OpenSSH Server 环境迁移 python3.11 alias unalias 别名 bug 自动化任务管理 IIS .net core Hosting Bundle .NET Framework vs2022 XFS xfs文件系统损坏 I_O error es jvm 线程 混合开发 JDK 相差8小时 UTC 时间 Java fd 文件描述符 netty ruoyi 蓝桥杯 远程过程调用 Windows环境 mysql离线安装 ubuntu22.04 mysql8.0 源码 毕业设计 hive Hive环境搭建 hive3环境 Hive远程模式 risc-v file server http server web server DNS GPU vr 状态管理的 UDP 服务器 Arduino RTOS openEuler 基础入门 编程 硬件架构 计算机 gitea Redis Desktop Wi-Fi minio web 指令 DevEco Studio mq rocketmq x64 SIGSEGV SSE xmm0 ip命令 新增网卡 新增IP 启动网卡 flash-attention Invalid Host allowedHosts 云电竞 云电脑 todesk Linux的权限 大语言模型 SysBench 基准测试 ecm bpm 链表 Erlang OTP gen_server 热代码交换 事务语义 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 MNN Qwen ui 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 cnn 集成学习 集成测试 邮件APP 免费软件 音乐服务器 Navidrome 音流 MCP server C/S EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 Minecraft DOIT 四博智联 excel 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 WebUI DeepSeek V3 Dell HPE 联想 浪潮 iDRAC R720xd 运维监控 freebsd 系统安全 npm pyautogui gaussdb playbook 企业微信 Linux24.04 deepin qemu libvirt AI写作 prompt 测试用例 磁盘监控 next.js 部署next.js 聊天室 deepseek r1 CrewAI log4j make命令 makefile文件 剧本 muduo 个人博客 X11 Xming uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 iftop 网络流量监控 王者荣耀 安卓 xcode DocFlow 图像处理 mariadb 计算虚拟化 弹性裸金属 网络工程师 华为认证 英语 设备 PCI-Express 自动化编程 centos 7 docker run 数据卷挂载 交互模式 阻塞队列 生产者消费者模型 服务器崩坏原因 网站搭建 serv00 jetty undertow elk 文件系统 路径解析 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 langchain k8s集群资源管理 云原生开发 SenseVoice 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 技能大赛 p2p ros2 moveit 机器人运动 ip Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 监控k8s 监控kubernetes SSH dity make 银河麒麟桌面操作系统 Kylin OS DeepSeek行业应用 Heroku 网站部署 显示过滤器 ICMP Wireshark安装 迁移指南 游戏机 linux环境变量 hugo Netty 即时通信 NIO SWAT 配置文件 服务管理 网络共享 c HTTP 服务器控制 ESP32 DeepSeek RAGFLOW RAG 检索增强生成 文档解析 大模型垂直应用 rime vasp安装 医疗APP开发 app开发 高级IO epoll AI作画 半虚拟化 硬件虚拟化 Hypervisor bcompare Beyond Compare minicom 串口调试工具 单元测试 思科模拟器 思科 Cisco nuxt3 算力 openssl Docker Compose docker compose docker-compose 模拟退火算法 无人机 监控k8s集群 集群内prometheus 社交电子 数据库系统 TRAE kali 共享文件夹 docker命令大全 5G 3GPP 卫星通信 wsl nac 802.1 portal 银河麒麟高级服务器 外接硬盘 Kylin EMUI 回退 降级 升级 W5500 OLED u8g2 TCP服务器 chfs ubuntu 16.04 同步 备份 建站 vscode 1.86 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 大模型教程 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 直流充电桩 充电桩 IPMI Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 灵办AI 网络穿透 ios 火绒安全 Nuxt.js Xterminal 虚拟局域网 ceph selete Claude eNSP 网络规划 VLAN 企业网络 大模型面经 大模型学习 显卡驱动 CPU 主板 电源 网卡 图形化界面 飞书 深度求索 私域 知识库 gpt-3 文心一言 uniapp 远程服务 匿名管道 echarts GCC crosstool-ng LLMs 边缘计算 frp 北亚数据恢复 oracle数据恢复 oneapi 实战案例 wsl2 tensorflow trae ruby XCC Lenovo 田俊楠 多层架构 解耦 移动云 MS Materials 业界资讯 拓扑图 鲲鹏 code-server pgpool docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos nfs 信息可视化 网页设计 分析解读 SSL 域名 华为机试 skynet springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 openwrt USB网络共享 Playwright P2P HDLC 自定义客户端 SAS embedding JAVA linux上传下载 昇腾 npu 统信 虚拟机安装 云桌面 微软 AD域控 证书服务器 大大通 第三代半导体 碳化硅 UDP的API使用 vmware 卡死 LORA NLP remote-ssh uv ukui 麒麟kylinos openeuler wps EasyConnect 小艺 Pura X RustDesk自建服务器 rustdesk服务器 docker rustdesk 黑客技术 URL ftp rustdesk VPS pyqt MacMini 迷你主机 mini Apple webstorm 宠物 免费学习 宠物领养 宠物平台 ux 多线程 vscode1.86 1.86版本 ssh远程连接 强制清理 强制删除 mac废纸篓 open Euler dde RTMP 应用层 big data opensearch helm MI300x 自动驾驶 WebRTC web3 linux安装配置 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 VR手套 数据手套 动捕手套 动捕数据手套 seatunnel 单一职责原则 DBeaver kerberos IPMITOOL BMC 硬件管理 open webui SRS 流媒体 直播 etcd 数据安全 RBAC xml 产测工具框架 IMX6ULL 管理框架 Ubuntu共享文件夹 共享目录 Linux共享文件夹 k8s二次开发 集群管理 asp.net大文件上传下载 Linux的基础指令 seleium 虚拟显示器 7z IMX317 MIPI H265 VCU composer 视频编解码 spark HistoryServer Spark YARN jobhistory zookeeper ros saltstack 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 Logstash 日志采集 僵尸世界大战 游戏服务器搭建 开发 IM即时通讯 剪切板对通 HTML FORMAT 阿里云ECS 服务网格 istio swoole 程序 性能分析 ldap RAGFlow 内网环境 ubuntu24.04.1 网络建设与运维 序列化反序列化 游戏引擎 NLP模型 自学笔记 小米 澎湃OS Android 软负载 策略模式 单例模式 架构与原理 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 HiCar CarLife+ CarPlay QT RK3588 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 读写锁 HarmonyOS OpenHarmony IDEA AI Agent 字节智能运维 网卡的名称修改 eth0 ens33 triton 模型分析 less 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors bat 端口 查看 ss 语法 本地部署AI大模型 Unity Dedicated Server Host Client 无头主机 aarch64 编译安装 HPC IPv4 子网掩码 公网IP 私有IP Deepseek-R1 私有化部署 推理模型 捆绑 链接 谷歌浏览器 youtube google gmail vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 easyui prometheus数据采集 prometheus数据模型 prometheus特点 tcp 权限 ShenTong 常用命令 文本命令 目录命令 树莓派 VNC regedit 开机启动 信创 信创终端 中科方德 midjourney 飞牛nas fnos sentinel 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 webgl FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 考研 FTP服务器 DeepSeek r1 Open WebUI 免费域名 域名解析 私有化 干货分享 黑客工具 密码爆破 eclipse Spring Security 技术共享 我的世界 我的世界联机 数码 玩机技巧 软件分享 软件图标 我的世界服务器搭建 加解密 Yakit yaklang AI-native Docker Desktop rclone AList webdav fnOS 执法记录仪 智能安全帽 smarteye 办公自动化 自动化生成 pdf教程 tailscale derp derper 中转 线性代数 电商平台 服务器时间 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 ISO镜像作为本地源 李心怡 MySql arcgis lua 移动魔百盒 USB转串口 CH340 harmonyOS面试题 cursor g++ g++13 影刀 #影刀RPA# docker部署Python 软件构建 dns是什么 如何设置电脑dns dns应该如何设置 音乐库 飞牛 H3C 历史版本 下载 idea pppoe radius etl 相机 域名服务 DHCP 符号链接 配置 figma WebVM 流水线 脚本式流水线 推荐算法 前后端分离 DenseNet 代理 AI agent iventoy VmWare OpenEuler edge浏览器 onlyoffice c/c++ 串口 cd 目录切换 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR Xinference iphone GoogLeNet apt 国内源 用户缓冲区 virtualbox 模拟实现 镜像 支付 微信支付 开放平台 信号处理 ubuntu24 vivado24 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 显示管理器 lightdm gdm grub 版本升级 扩容 cocoapods ROS 游戏开发 版本 WLAN rancher deep learning 大模型推理 Kali 渗透 banner 本地知识库部署 DeepSeek R1 模型 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 xss DIFY llama.cpp minecraft 串口驱动 CH341 uart 485 实习 Ubuntu22.04 开发人员主页 trea 查询数据库服务IP地址 SQL Server 分布式训练 语音识别 AutoDL 反向代理 模拟器 教程 searxng PPI String Cytoscape CytoHubba firewall Radius 金仓数据库 2025 征文 数据库平替用金仓 qt项目 qt项目实战 qt教程 抗锯齿 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP nlp 根服务器 clickhouse 区块链 UOS1070e EMQX 通信协议 VS Code 键盘 Typore 代码托管服务 嵌入式Linux IPC 物联网开发 AD 域管理 代理服务器 中兴光猫 换光猫 网络桥接 自己换光猫 聚类 ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS laravel 小智AI服务端 xiaozhi TTS junit 需求分析 规格说明书 Linux环境 强化学习 内网服务器 内网代理 内网通信 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 备选 网站 调用 示例 autodl AD域 AnythingLLM AnythingLLM安装 互信 交叉编译 换源 Debian 毕昇JDK powerpoint 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 jina 人工智能生成内容 稳定性 看门狗 基础环境 大模型部署 主从复制 安防软件 端口测试 wpf cfssl WSL2 上安装 Ubuntu CDN vpn EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 deekseek can 线程池 Headless Linux flink ArkTs 虚拟现实 ssh远程登录 QT 5.12.12 QT开发环境 Ubuntu18.04 双系统 GRUB引导 Linux技巧 Jellyfin 存储维护 NetApp存储 EMC存储 进程优先级 调度队列 进程切换 TrueLicense Windows ai工具 做raid 装系统 armbian u-boot 信号 Mac内存不够用怎么办 浏览器开发 AI浏览器 ssh漏洞 ssh9.9p2 CVE-2025-23419 超融合 h.264 yaml Ultralytics 可视化 项目部署到linux服务器 项目部署过程 CVE-2024-7347 IO模型 rnn LLM Web APP Streamlit cpp-httplib OpenSSH sysctl.conf vm.nr_hugepages su sudo perf IMM 智能音箱 智能家居 程序员创富 国产数据库 瀚高数据库 数据迁移 下载安装 TCP协议 知识图谱 钉钉 端口聚合 windows11 milvus System V共享内存 进程通信 HarmonyOS NEXT 原生鸿蒙 安装MySQL React Next.js 开源框架 合成模型 扩散模型 图像生成 通信工程 毕业 fstab 云耀服务器 极限编程 docker desktop image 鸿蒙开发 移动开发 fast 防火墙 NAT转发 NAT Server react native docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 sequoiaDB 离线部署dify word iperf3 带宽测试 CentOS Stream CentOS rpa db 企业网络规划 华为eNSP Linux find grep nvm whistle css3 抓包工具 本地化部署 智能电视 在线office 热榜 UDP 带外管理 流量运营 perl vnc ubuntu20.04 开机黑屏 软件卸载 系统清理 欧标 OCPP 健康医疗 MDK 嵌入式开发工具 论文笔记 sublime text zip unzip 软链接 硬链接 AI员工 IO 网络爬虫 Unity插件 沙盒 电视剧收视率分析与可视化平台 粘包问题 计算生物学 生物信息 基因组 kotlin 虚幻引擎 Qwen2.5-VL vllm rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK PX4 问题解决 top Linux top top命令详解 top命令重点 top常用参数 Sealos nosql 论文阅读 ros1 Noetic 20.04 apt 安装 navicat xpath定位元素 Attention 烟花代码 烟花 元旦 嵌入式系统开发 kernel 网络搭建 神州数码 神州数码云平台 云平台 win服务器架设 windows server ip协议 状态模式 nftables SVN Server tortoise svn HAProxy ABAP gnu SEO ubuntu 18.04 hexo MVS 海康威视相机 dock 加速 Python基础 Python教程 Python技巧 proxy模式 性能调优 安全代理 磁盘清理 visual studio 元服务 应用上架 ranger MySQL8.0 环境配置 Linux权限 权限命令 特殊权限 MAC SecureCRT 容器技术 查看显卡进程 fuser ArtTS mcp服务器 client close UEFI Legacy MBR GPT U盘安装操作系统 多路转接 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 wsgiref Web 服务器网关接口 MacOS 对比 工具 meld DiffMerge 互联网医院 java-rocketmq ardunio BLE 浏览器自动化 项目部署 deployment daemonset statefulset cronjob hosts MAVROS 四旋翼无人机 vu大文件秒传跨域报错cors 达梦 DM8 机柜 1U 2U js Reactor反应堆 接口优化 Web服务器 多线程下载工具 PYTHON 本地环回 bind 数字证书 签署证书 搭建个人相关服务器 话题通信 服务通信 解决方案 macOS WebServer yum换源 服务器正确解析请求体 Linux 维护模式 视频平台 录像 视频转发 视频流 java-rabbitmq 搜狗输入法 中文输入法 copilot MobaXterm yolov5 powerbi conda配置 conda镜像源 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 风扇控制软件 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 西门子PLC 通讯