6.0 KiB
6.0 KiB
IndexStreamTTS 使用指南
环境准备
1. 克隆项目
git clone https://github.com/Ksuriuri/index-tts-vllm.git
进入解压后的目录
cd index-tts-vllm
切换到指定版本 (使用VLLM-0.10.2的历史版本)
git checkout 224e8d5e5c8f66801845c66b30fa765328fd0be3
2. 创建并激活 conda 环境
conda create -n index-tts-vllm python=3.12
conda activate index-tts-vllm
3. 安装PyTorch 需要版本为2.8.0(最新版)
查看显卡最高支持的版本和实际安装的版本
nvidia-smi
nvcc --version
驱动支持的最高 CUDA 版本
CUDA Version: 12.8
实际安装的 CUDA 编译器版本
Cuda compilation tools, release 12.8, V12.8.89
那么对应的安装命令(pytorch默认给的是12.8的驱动版本)
pip install torch torchvision
需要 pytorch 版本 2.8.0(对应 vllm 0.10.2),具体安装指令请参考:pytorch 官网
4. 安装依赖
pip install -r requirements.txt
5. 下载模型权重
方案一:下载官方权重文件后转换
此为官方权重文件,下载到本地任意路径即可,支持 IndexTTS-1.5 的权重
| HuggingFace | ModelScope |
|---|---|
| IndexTTS | IndexTTS |
| IndexTTS-1.5 | IndexTTS-1.5 |
下面以ModelScope的安装方法为例
请注意:git需要安装并初始化启用lfs(如已安装可以跳过)
sudo apt-get install git-lfs
git lfs install
创建模型目录,并拉取模型
mkdir model_dir
cd model_dir
git clone https://www.modelscope.cn/IndexTeam/IndexTTS-1.5.git
模型权重转换
bash convert_hf_format.sh /path/to/your/model_dir
例如:你下载的IndexTTS-1.5模型存放在model_dir目录下,则执行以下命令
bash convert_hf_format.sh model_dir/IndexTTS-1.5
此操作会将官方的模型权重转换为 transformers 库兼容的版本,保存在模型权重路径下的 vllm 文件夹中,方便后续 vllm 库加载模型权重
6. 更改接口适配一下项目
接口返回数据与项目不适配需要调整一下,使其直接返回音频数据
vi api_server.py
@app.post("/tts", responses={
200: {"content": {"application/octet-stream": {}}},
500: {"content": {"application/json": {}}}
})
async def tts_api(request: Request):
try:
data = await request.json()
text = data["text"]
character = data["character"]
global tts
sr, wav = await tts.infer_with_ref_audio_embed(character, text)
return Response(content=wav.tobytes(), media_type="application/octet-stream")
except Exception as ex:
tb_str = ''.join(traceback.format_exception(type(ex), ex, ex.__traceback__))
print(tb_str)
return JSONResponse(
status_code=500,
content={
"status": "error",
"error": str(tb_str)
}
)
7.编写sh启动脚本(请注意要在相应的conda环境下运行)
vi start_api.sh
将下面内容粘贴进去并按:输入wq保存
脚本中的/home/system/index-tts-vllm/model_dir/IndexTTS-1.5 请自行修改为实际路径
# 激活conda环境
conda activate index-tts-vllm
echo "激活项目conda环境"
sleep 2
# 查找占用11996端口的进程号
PID_VLLM=$(sudo netstat -tulnp | grep 11996 | awk '{print $7}' | cut -d'/' -f1)
# 检查是否找到进程号
if [ -z "$PID_VLLM" ]; then
echo "没有找到占用11996端口的进程"
else
echo "找到占用11996端口的进程,进程号为: $PID_VLLM"
# 先尝试普通kill,等待2秒
kill $PID_VLLM
sleep 2
# 检查进程是否还在
if ps -p $PID_VLLM > /dev/null; then
echo "进程仍在运行,强制终止..."
kill -9 $PID_VLLM
fi
echo "已终止进程 $PID_VLLM"
fi
# 查找占用VLLM::EngineCore进程
GPU_PIDS=$(ps aux | grep -E "VLLM|EngineCore" | grep -v grep | awk '{print $2}')
# 检查是否找到进程号
if [ -z "$GPU_PIDS" ]; then
echo "没有找到VLLM相关进程"
else
echo "找到VLLM相关进程,进程号为: $GPU_PIDS"
# 先尝试普通kill,等待2秒
kill $GPU_PIDS
sleep 2
# 检查进程是否还在
if ps -p $GPU_PIDS > /dev/null; then
echo "进程仍在运行,强制终止..."
kill -9 $GPU_PIDS
fi
echo "已终止进程 $GPU_PIDS"
fi
# 创建tmp目录(如果不存在)
mkdir -p tmp
# 后台运行api_server.py,日志重定向到tmp/server.log
nohup python api_server.py --model_dir /home/system/index-tts-vllm/model_dir/IndexTTS-1.5 --port 11996 > tmp/server.log 2>&1 &
echo "api_server.py 已在后台运行,日志请查看 tmp/server.log"
给脚本执行权限并运行脚本
chmod +x start_api.sh
./start_api.sh
日志会在tmp/server.log中输出,可以通过以下命令查看日志情况
tail -f tmp/server.log
如果显卡内存足够,可在脚本中添加启动参数 ----gpu_memory_utilization 来调整显存占用比例,默认值为 0.25
音色配置
index-tts-vllm支持通过配置文件注册自定义音色,支持单音色和混合音色配置。
在项目根目录下的assets/speaker.json文件中配置自定义音色
配置格式说明
{
"说话人名称1": [
"音频文件路径1.wav",
"音频文件路径2.wav"
],
"说话人名称2": [
"音频文件路径3.wav"
]
}
注意 (配置角色后需重启服务进行音色注册)
添加后需在智控台中添加相应的说话人(单模块则更换相应的voice)