YouTube Subtitle MCP Server
Fetches YouTube video subtitles and transcripts with support for multiple languages and output formats (SRT, VTT, TXT, JSON).
README
🎬 YouTube Subtitle MCP Server
A Model Context Protocol (MCP) server for fetching YouTube video subtitles/transcripts with support for multiple output formats (SRT, VTT, TXT, JSON).
✨ Features
- 🎥 Fetch subtitles from any public YouTube video
- 📝 Multiple output formats: SRT, VTT, TXT, JSON
- 🌍 Multi-language subtitle support
- ⚡ Two deployment modes: stdio (local) and HTTP (server)
- 🔧 Zero-configuration setup with npx
- 📊 Complete timestamp information
- 🚀 Production-ready with TypeScript
- 🔥 Built with youtubei.js for reliable and stable subtitle extraction
🚀 Quick Start
⭐ Method 1: stdio Mode (Recommended for Local Use)
Zero configuration required! Simply use npx:
npx -y youtube-subtitle-mcp
Or install globally:
npm install -g youtube-subtitle-mcp
youtube-subtitle-mcp
🌐 Method 2: HTTP Mode (For Server Deployment)
# Clone repository
git clone https://github.com/guangxiangdebizi/youtube-subtitle-mcp.git
cd youtube-subtitle-mcp
# Install dependencies
npm install
# Build
npm run build
# Start HTTP server
npm run start:http
Server will start at http://localhost:3000
📦 Installation
For Development
# Clone repository
git clone https://github.com/guangxiangdebizi/youtube-subtitle-mcp.git
cd youtube-subtitle-mcp
# Install dependencies
npm install
# Build
npm run build
For Production
npm install -g youtube-subtitle-mcp
🔧 Configuration
⭐ stdio Mode Configuration (Recommended)
Add to your MCP client configuration file:
Claude Desktop / Cursor Configuration:
- Windows:
%APPDATA%\Claude\claude_desktop_config.json - macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"youtube-subtitle": {
"command": "npx",
"args": ["-y", "youtube-subtitle-mcp"]
}
}
}
For local development:
{
"mcpServers": {
"youtube-subtitle": {
"command": "node",
"args": ["C:/path/to/youtube-subtitle-mcp/build/index.js"]
}
}
}
🌐 HTTP Mode Configuration
{
"mcpServers": {
"youtube-subtitle": {
"type": "streamableHttp",
"url": "http://localhost:3000/mcp",
"timeout": 600
}
}
}
🛠️ Tool: fetch_youtube_subtitles
Parameters
| Parameter | Type | Required | Description | Example |
|---|---|---|---|---|
url |
string | ✅ Yes | YouTube video URL or video ID | https://www.youtube.com/watch?v=dQw4w9WgXcQ |
format |
string | ❌ No | Output format (default: JSON) | SRT, VTT, TXT, JSON |
lang |
string | ❌ No | Language code (default: auto) | zh-Hans, en, ja |
Supported URL Formats
- Standard:
https://www.youtube.com/watch?v=VIDEO_ID - Short:
https://youtu.be/VIDEO_ID - Embed:
https://www.youtube.com/embed/VIDEO_ID - Direct ID:
VIDEO_ID
Language Codes
zh-Hans- Simplified Chinesezh-Hant- Traditional Chineseen- Englishja- Japaneseko- Koreanes- Spanishfr- Frenchde- German
📝 Usage Examples
Example 1: Fetch JSON Format Subtitles (Default)
Please fetch subtitles from this video:
https://www.youtube.com/watch?v=dQw4w9WgXcQ
Example 2: Fetch SRT Format Subtitles
Please fetch subtitles in SRT format from:
https://www.youtube.com/watch?v=dQw4w9WgXcQ
Example 3: Fetch Specific Language Subtitles
Please fetch Simplified Chinese subtitles in VTT format from:
https://www.youtube.com/watch?v=dQw4w9WgXcQ
Language code: zh-Hans
Example 4: Fetch Plain Text Content
Please fetch plain text subtitles from:
https://youtu.be/dQw4w9WgXcQ
Format: TXT
📊 Output Format Examples
JSON Format
[
{
"text": "Hello world",
"start": 0,
"end": 2000,
"duration": 2000
},
{
"text": "Welcome to YouTube",
"start": 2000,
"end": 5000,
"duration": 3000
}
]
SRT Format
1
00:00:00,000 --> 00:00:02,000
Hello world
2
00:00:02,000 --> 00:00:05,000
Welcome to YouTube
VTT Format
WEBVTT
00:00:00.000 --> 00:00:02.000
Hello world
00:00:02.000 --> 00:00:05.000
Welcome to YouTube
TXT Format
Hello world
Welcome to YouTube
This is a subtitle example
🏗️ Project Structure
youtube-subtitle-mcp/
├── src/
│ ├── index.ts # stdio mode entry (recommended for local use)
│ ├── httpServer.ts # HTTP mode entry (for server deployment)
│ └── tools/
│ ├── fetchYoutubeSubtitles.ts # Main tool implementation
│ ├── formatters.ts # Format converters (SRT/VTT/TXT/JSON)
│ └── utils.ts # Utility functions
├── build/ # Compiled JavaScript (generated)
├── package.json
├── tsconfig.json
└── README.md
📚 Development
Build
npm run build
Watch Mode
npm run watch
Start stdio Mode
npm run start:stdio
Start HTTP Mode
npm run start:http
Custom Port (HTTP Mode)
PORT=8080 npm run start:http
🐳 Docker Deployment
Using Docker
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production
COPY . .
RUN npm run build
EXPOSE 3000
CMD ["npm", "run", "start:http"]
# Build image
docker build -t youtube-subtitle-mcp .
# Run container
docker run -d -p 3000:3000 --name youtube-mcp youtube-subtitle-mcp
Using Docker Compose
version: '3.8'
services:
youtube-subtitle-mcp:
build: .
ports:
- "3000:3000"
environment:
- PORT=3000
restart: unless-stopped
docker-compose up -d
🚀 Deployment
PM2 (Process Manager)
# Install PM2
npm install -g pm2
# Start service
pm2 start build/httpServer.js --name youtube-subtitle-mcp
# View status
pm2 status
# View logs
pm2 logs youtube-subtitle-mcp
# Restart
pm2 restart youtube-subtitle-mcp
# Stop
pm2 stop youtube-subtitle-mcp
🔍 API Reference
Health Check (HTTP Mode)
Endpoint: GET /health
Response:
{
"status": "healthy",
"transport": "streamable-http",
"activeSessions": 0,
"name": "youtube-subtitle-mcp",
"version": "1.0.0",
"timestamp": "2024-01-01T12:00:00.000Z"
}
MCP Endpoint (HTTP Mode)
Endpoint: POST /mcp
Headers:
Content-Type: application/jsonMcp-Session-Id: <session-id>(after initialization)
Request Body: JSON-RPC 2.0 format
⚠️ Notes
- Public videos only: Cannot fetch subtitles from private or restricted videos
- Subtitles required: Video must have available subtitles (auto-generated or uploaded)
- Language codes: If specified language doesn't exist, an error will be returned
- Network required: Requires stable network connection to access YouTube
- Terms of Service: Please comply with YouTube's Terms of Service, use for research/analysis purposes only
❓ FAQ
Q: Server started but client can't connect?
A: Check the following:
- Verify server is running: visit
http://localhost:3000/health - Check URL in configuration file:
http://localhost:3000/mcp - Ensure firewall isn't blocking port 3000
- Restart Cursor/Claude Desktop
Q: Why can't I fetch subtitles?
A: Possible reasons:
- Video has no subtitles
- Video is private or region-restricted
- Specified language code doesn't exist
- Network connection issue
- Server network can't access YouTube
Q: Do you support auto-generated subtitles?
A: Yes, supports YouTube auto-generated subtitles.
Q: Can I batch process multiple videos?
A: Current version processes one video at a time. For batch processing, loop the tool call on the client side.
Q: What's the timestamp unit?
A: Timestamps in JSON format are in milliseconds (ms).
Q: Can I deploy on a remote server?
A: Yes! Just:
- Install Node.js on remote server
- Clone project and run
npm install - Start server with
npm run start:http - Use remote URL in client configuration:
http://your-server:3000/mcp - Recommend using HTTPS and reverse proxy (e.g., Nginx) for security
Q: How to change port?
A: Two methods:
- Environment variable:
PORT=8080 npm run start:http - Create
.envfile: addPORT=8080
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
📄 License
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.
👤 Author
Xingyu Chen
- LinkedIn: https://www.linkedin.com/in/xingyu-chen-b5b3b0313/
- Email: guangxiangdebizi@gmail.com
- GitHub: https://github.com/guangxiangdebizi/
- NPM: https://www.npmjs.com/~xingyuchen
🙏 Acknowledgments
- Model Context Protocol - MCP SDK
- youtubei.js - Powerful YouTube API wrapper for reliable subtitle extraction
📮 Support
If you have any questions or suggestions, please create an Issue.
Made with ❤️ by Xingyu Chen
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。