域名工具MCP服务器是一个用于综合域名分析的Model Context Protocol(MCP)服务器,可进行WHOIS查询、DNS记录查询和DNS健康检查,帮助用户深入分析和监控域名配置。
git clone https://github.com/deshabhishek007/domain-tools-mcp-server.git
cd domain-tools-mcp-server
python3 -m venv domain-tools-env
source domain-tools-env/bin/activate
pip install -r requirements.txt
python -c "import mcp, dns.resolver, whois; print('All dependencies installed successfully!')"
python domain_tools_server.py
或者使其可执行:
chmod +x domain_tools_server.py
./domain_tools_server.py
/etc/systemd/system/domain-tools-mcp.service
:[Unit]
Description=Domain Tools MCP Server
After=network.target
[Service]
Type=simple
User=your-username
WorkingDirectory=/path/to/your/project
Environment=PATH=/path/to/your/project/domain-tools-env/bin
ExecStart=/path/to/your/project/domain-tools-env/bin/python domain_tools_server.py
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.target
sudo systemctl daemon-reload
sudo systemctl enable domain-tools-mcp.service
sudo systemctl start domain-tools-mcp.service
Dockerfile
:FROM python:3.13-slim
WORKDIR /app
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
COPY domain_tools_server.py .
EXPOSE 8080
CMD ["python", "domain_tools_server.py"]
docker build -t domain-tools-mcp .
docker run -p 8080:8080 domain-tools-mcp
.
├── domain_tools_server.py # 主服务器实现
├── requirements.txt
├── .gitignore
├── README.md
└── ...
服务器实现了Model Context Protocol,可以与任何兼容MCP的客户端集成。 示例MCP客户端配置:
{
"servers": {
"domain-tools": {
"command": "python",
"args": ["/path/to/domain_tools_server.py"],
"env": {}
}
}
}
domain
(字符串,必填):要查询的域名。{
"tool": "whois_lookup",
"arguments": {
"domain": "example.com"
}
}
{
"domain": "example.com",
"registrar": "Example Registrar Inc.",
"creation_date": "2023-01-15T00:00:00Z",
"expiration_date": "2025-01-15T00:00:00Z",
"updated_date": "2024-01-15T00:00:00Z",
"status": ["clientTransferProhibited"],
"name_servers": ["ns1.example.com", "ns2.example.com"],
"days_until_expiry": 215
}
domain
(字符串,必填):要查询的域名。record_types
(数组,可选):要查询的DNS记录类型(默认:["A", "AAAA", "MX", "NS", "TXT", "CNAME", "SOA"]
)。{
"tool": "dns_records",
"arguments": {
"domain": "example.com",
"record_types": ["A", "MX", "NS"]
}
}
domain
(字符串,必填):要分析的域名。{
"tool": "dns_health_check",
"arguments": {
"domain": "example.com"
}
}
domain
(字符串,必填):要分析的域名。{
"tool": "domain_analysis",
"arguments": {
"domain": "example.com"
}
}
每个工具都遵循JSON输入架构。完整细节请查看代码。
所有工具返回的响应格式如下:
[
{
"type": "text",
"text": "Tool-specific formatted output"
}
]
可以在服务器代码中自定义DNS解析器:
self.dns_resolver.nameservers = ['8.8.8.8', '8.8.4.4']
self.dns_resolver.timeout = 10
self.dns_resolver.lifetime = 30
可以使用环境变量配置服务器:
export DNS_TIMEOUT=10
export DNS_LIFETIME=30
export WHOIS_TIMEOUT=30
export SERVER_NAME="domain-tools"
export SERVER_VERSION="1.0.0"
pip install --upgrade mcp dnspython python-whois pydantic
。在服务器中添加以下代码启用调试日志:
import logging
logging.basicConfig(level=logging.DEBUG)
本项目采用MIT许可证。详情请参阅 LICENSE 文件。