Reddit MCP Server
Provides AI assistants with access to Reddit data for searching, browsing subreddits, and retrieving post details or user activity without requiring API keys. It enables tools to fetch content, nested comment trees, and public user feeds directly through the Model Context Protocol.
README
Reddit MCP Server
A Model Context Protocol (MCP) server that provides AI assistants with access to Reddit data. Built on top of redd ā no API keys required.
https://github.com/user-attachments/assets/af8ae52c-f9f3-4d04-80d5-4be0dfa61b0f
Table of Contents
1. Features
- š Search ā Search all of Reddit or within a specific subreddit
- š° Subreddit Posts ā Browse hot, top, new, or rising posts from any subreddit
- š Post Details ā Get full post content with nested comment trees
- š¤ User Activity ā View a user's recent posts and comments
- š User Posts ā Get a user's submitted posts
No API keys, no authentication, no browser required. Just install and run.
2. Quick Start
2.1. Using uvx (recommended)
The fastest way to run the server ā no clone needed:
# stdio transport (default, for Claude Desktop / Cursor / etc.)
uvx reddit-no-auth-mcp-server
# HTTP transport
uvx reddit-no-auth-mcp-server \
--transport streamable-http \
--port 8000
2.2. From source
git clone https://github.com/eliasbiondo/reddit-mcp-server.git
cd reddit-mcp-server
uv sync
Run the server:
# stdio transport (default)
uv run reddit-no-auth-mcp-server
# HTTP transport
uv run reddit-no-auth-mcp-server \
--transport streamable-http \
--port 8000
2.3. MCP Client Configuration
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"reddit": {
"command": "uvx",
"args": ["reddit-no-auth-mcp-server"]
}
}
}
Cursor
Add to your .cursor/mcp.json:
{
"mcpServers": {
"reddit": {
"command": "uvx",
"args": ["reddit-no-auth-mcp-server"]
}
}
}
From source (any MCP client)
{
"mcpServers": {
"reddit": {
"command": "uv",
"args": [
"--directory", "/path/to/reddit-mcp-server",
"run", "reddit-no-auth-mcp-server"
]
}
}
}
3. Available Tools
| Tool | Description | Key Arguments |
|---|---|---|
search |
Search Reddit for posts | query, limit, sort |
search_subreddit |
Search within a subreddit | subreddit, query, limit, sort |
get_post |
Get post details + comment tree | permalink |
get_subreddit_posts |
Get subreddit listing | subreddit, limit, category, time_filter |
get_user |
Get user's activity feed | username, limit |
get_user_posts |
Get user's submitted posts | username, limit, category, time_filter |
Tool Details
search
Search all of Reddit for posts matching a query.
query: "python async programming"
limit: 10
sort: "relevance" # relevance, hot, top, new, comments
search_subreddit
Search within a specific subreddit.
subreddit: "Python"
query: "web scraping"
limit: 10
sort: "top"
get_post
Get full details of a Reddit post including its comment tree.
permalink: "/r/Python/comments/abc123/my_post/"
get_subreddit_posts
Get posts from a subreddit listing.
subreddit: "MachineLearning"
limit: 25
category: "hot" # hot, top, new, rising
time_filter: "week" # hour, day, week, month, year, all
get_user
Get a user's recent public activity (posts and comments).
username: "spez"
limit: 10
get_user_posts
Get a user's submitted posts.
username: "spez"
limit: 10
category: "top" # hot, top, new
time_filter: "all" # hour, day, week, month, year, all
4. Configuration
All settings can be configured via environment variables:
| Variable | Default | Description |
|---|---|---|
REDDIT_TRANSPORT |
stdio |
MCP transport (stdio, streamable-http) |
REDDIT_HOST |
127.0.0.1 |
Host for HTTP transport |
REDDIT_PORT |
8000 |
Port for HTTP transport |
REDDIT_PATH |
/mcp |
Path for HTTP transport |
REDDIT_LOG_LEVEL |
WARNING |
Log level (DEBUG, INFO, WARNING, ERROR) |
REDDIT_PROXY |
ā | HTTP/HTTPS proxy URL |
REDDIT_TIMEOUT |
10.0 |
Request timeout in seconds |
REDDIT_THROTTLE_MIN |
1.0 |
Min delay between paginated requests (seconds) |
REDDIT_THROTTLE_MAX |
2.0 |
Max delay between paginated requests (seconds) |
CLI arguments take precedence over environment variables:
uv run reddit-no-auth-mcp-server \
--transport streamable-http \
--port 9000 \
--log-level DEBUG
5. Architecture
This project follows hexagonal architecture (ports & adapters):
src/reddit_mcp_server/
āāā domain/ # Pure business logic, no framework imports
ā āāā exceptions.py # Domain exception hierarchy
ā āāā value_objects.py # Immutable config objects
āāā ports/ # Abstract interfaces (contracts)
ā āāā config.py # ConfigPort
ā āāā reddit.py # RedditPort
āāā application/ # Use cases (orchestration)
ā āāā search.py
ā āāā search_subreddit.py
ā āāā get_post.py
ā āāā get_user.py
ā āāā get_subreddit_posts.py
ā āāā get_user_posts.py
āāā adapters/
ā āāā inbound/ # Presentation layer
ā ā āāā cli.py # CLI entry point
ā ā āāā mcp_server.py
ā ā āāā error_mapping.py
ā ā āāā serialization.py
ā ā āāā mcp_tools/ # MCP tool definitions
ā āāā outbound/ # Infrastructure layer
ā āāā env_config.py # ConfigPort implementation
ā āāā redd_client.py # RedditPort implementation (wraps redd)
āāā container.py # DI composition root
6. Contributing
Contributions are welcome. Please read CONTRIBUTING.md for guidelines on setting up the project, running tests, and submitting changes.
7. License
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.