macsymwang/hello-mcp-server
If you are the rightful owner of hello-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The Hello World MCP Server is a simple demonstration of Model Context Protocol (MCP) functionality using FastMCP.
Hello World MCP Server
A simple "Hello World" MCP (Model Context Protocol) server built with FastMCP. This server demonstrates basic MCP functionality with several example tools.
Quick Start
Using uvx with GitHub (Recommended)
You can run this MCP server directly from GitHub using uvx
:
uvx --from git+https://github.com/macsymwang/hello-mcp-server.git hello-mcp-server
MCP Client Configuration
Add this to your MCP client configuration:
{
"mcpServers": {
"hello-world": {
"command": "uvx",
"args": ["--from", "git+https://github.com/macsymwang/hello-mcp-server.git", "hello-mcp-server"]
}
}
}
Features
- say_hello: Greet someone with a personalized message
- get_server_info: Get information about the MCP server
- echo_message: Echo back any message you send
- count_words: Analyze text and count words/characters
Installation
Using uvx with GitHub (Recommended)
You can run this MCP server directly from GitHub using uvx
:
uvx --from git+https://github.com/macsymwang/hello-mcp-server.git hello-mcp-server
Using uvx from PyPI (if published)
uvx hello-mcp-server
Local Installation
- Clone or download this repository
- Install the package:
pip install .
- Run the server:
hello-mcp-server
Development Installation
For development, install in editable mode:
pip install -e .
Usage
Registering as Stdio Protocol
This MCP server is designed to work with the stdio transport protocol, which is the standard way MCP servers communicate with clients. The server reads JSON-RPC messages from stdin and writes responses to stdout.
MCP Client Configuration
Claude Desktop
Add this configuration to your Claude Desktop config file (usually located at ~/.config/claude/claude_desktop_config.json
on Linux/Mac or %APPDATA%\Claude\claude_desktop_config.json
on Windows):
{
"mcpServers": {
"hello-world": {
"command": "uvx",
"args": ["--from", "git+https://github.com/macsymwang/hello-mcp-server.git", "hello-mcp-server"]
}
}
}
Cursor IDE
Add this to your Cursor MCP configuration:
{
"mcpServers": {
"hello-world": {
"command": "uvx",
"args": ["--from", "git+https://github.com/macsymwang/hello-mcp-server.git", "hello-mcp-server"],
"transport": {
"type": "stdio"
}
}
}
}
Generic MCP Client
For other MCP clients, use this configuration:
{
"mcpServers": {
"hello-world": {
"command": "uvx",
"args": ["--from", "git+https://github.com/macsymwang/hello-mcp-server.git", "hello-mcp-server"],
"env": {},
"transport": {
"type": "stdio"
}
}
}
}
Running the Server Manually
The server can also be started manually for testing:
-
Using uvx (recommended):
uvx hello-mcp-server
-
Using the installed command:
hello-mcp-server
-
Using Python module:
python -m hello_mcp_server.server
-
Direct execution:
python hello_mcp_server/server.py
When run manually, the server will wait for JSON-RPC messages on stdin. You can test it by sending MCP protocol messages, but it's typically used through MCP clients.
Available Tools
say_hello
Greets someone with a personalized message.
Parameters:
name
(optional): Name of the person to greet (default: "World")
Example:
{
"name": "Alice"
}
get_server_info
Returns information about the MCP server.
Parameters: None
echo_message
Echoes back the provided message.
Parameters:
message
(required): The message to echo back
count_words
Analyzes text and provides word/character statistics.
Parameters:
text
(required): The text to analyze
Configuration
Stdio Protocol
This MCP server uses the stdio transport protocol, which means:
- Input: The server reads JSON-RPC messages from standard input (stdin)
- Output: The server writes JSON-RPC responses to standard output (stdout)
- Logging: Error messages and logs are written to standard error (stderr)
This is the standard protocol for MCP servers and ensures compatibility with all MCP clients.
Transport Configuration
The server automatically configures itself for stdio transport when started. No additional configuration is needed for the transport layer.
For advanced FastMCP configuration options, refer to the FastMCP documentation.
Requirements
- Python 3.8+
- fastmcp>=0.1.0
Project Structure
hello-mcp-server/
āāā hello_mcp_server/
ā āāā __init__.py
ā āāā server.py
āāā pyproject.toml
āāā README.md
Development
To contribute to this project:
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
License
This project is open source. Please check the license file for details.
Support
For issues and questions, please open an issue on the project repository.