CHypeTools/VPS-MCP-SERVER
If you are the rightful owner of VPS-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 VPS MCP Server is an automation system designed for configuring servers with support for the Model Context Protocol (MCP), enabling AI assistants to manage infrastructure using natural language commands.
VPS MCP SERVER - Automação para Servidores MCP
Sistema de automação para configuração de servidores com suporte ao Model Context Protocol (MCP) que permite que assistentes AI (como Cursor AI) gerenciem sua infraestrutura através de comandos em linguagem natural.
🌟 Visão Geral
Este projeto oferece scripts para configurar rapidamente servidores MCP com as seguintes opções:
- Configuração de Servidor Único: Tudo em um só servidor (MCP Server, aplicações, bancos de dados e armazenamento de objetos)
- Configuração de Dois Servidores:
- Servidor de Aplicações: MCP Server e aplicações
- Servidor de Banco de Dados: MCP Server, bancos de dados (PostgreSQL/MySQL) e armazenamento de objetos
🚀 Instalação Rápida
Servidor Único (Tudo em uma VPS)
curl -fsSL https://raw.githubusercontent.com/LuizBranco-ClickHype/VPS-MCP-SERVER/main/install.sh | bash
Configuração de Dois Servidores (Duas VPS)
Na primeira VPS (Servidor de Aplicações):
curl -fsSL https://raw.githubusercontent.com/LuizBranco-ClickHype/VPS-MCP-SERVER/main/install.sh | bash -s -- --mode app
Na segunda VPS (Servidor de Banco de Dados):
curl -fsSL https://raw.githubusercontent.com/LuizBranco-ClickHype/VPS-MCP-SERVER/main/install.sh | bash -s -- --mode db
💻 Requisitos do Sistema
- Ubuntu 20.04+ ou Debian 11+
- Acesso root ou usuário com privilégios sudo
- Conexão à internet
- Mínimo 2GB RAM (recomendado 4GB)
- 20GB de espaço em disco
🛠 Recursos
Serviços MCP Disponíveis
- VPS MCP Server: Gerenciamento central de infraestrutura
- PostgreSQL MCP: Acesso a banco de dados com suporte a vetores para IA
- Storage MCP: Operações de armazenamento compatível com S3
- Context7 MCP: Acesso a documentação e conhecimento externo
Componentes Integrados
- Docker / Docker Compose: Para containerização dos serviços
- PostgreSQL: Banco de dados com suporte a pgvector para embeddings de IA
- MinIO: Armazenamento de objetos compatível com S3
- Context7: Integração para acesso a documentação e conhecimento externo
Segurança
- Firewall configurado (ufw)
- Tokens de autenticação gerados aleatoriamente
- Comunicação segura entre servidores
- Certificados SSL automáticos (Let's Encrypt) quando configurado com domínio
⚙️ Opções de Configuração
O script de instalação aceita os seguintes parâmetros:
| Parâmetro | Descrição | Padrão |
|---|---|---|
--mode | Modo de instalação (single, app, db) | single |
--domain | Domínio para configurar SSL | - |
--email | Email para certificados Let's Encrypt | - |
--db-type | Tipo de banco de dados (postgres, mysql) | postgres |
--db-host | Endereço IP do servidor de banco de dados (para modo app) | - |
--app-host | Endereço IP do servidor de aplicações (para modo db) | - |
--port | Porta para o MCP Server | 3000 |
--help | Exibe ajuda | - |
🌐 Model Context Protocol (MCP)
O Model Context Protocol (MCP) é um protocolo aberto que padroniza como aplicativos fornecem contexto e ferramentas para LLMs. Este projeto implementa servidores MCP que podem ser consumidos pelo Cursor AI e outros clientes compatíveis.
Arquitetura MCP
A implementação neste projeto fornece:
- Transporte stdio: Executa em máquina local e é gerenciado pelo Cursor
- Transporte SSE: Permite execução local ou remota via HTTP
Configurando o Cursor AI
Para conectar o Cursor AI aos servidores MCP:
- Crie uma pasta
.cursorna raiz do seu projeto - Crie um arquivo
mcp.jsoncom o seguinte conteúdo (ajuste os IPs conforme necessário):
{
"mcpServers": {
"vps_mcp_server": {
"description": "Servidor MCP unificado para gerenciamento de infraestrutura",
"command": "bash",
"args": [
"./mcp-service.sh",
"--endpoint",
"/api/mcp"
]
},
"postgresql": {
"description": "Acesso a banco de dados PostgreSQL com suporte a vetores",
"command": "bash",
"args": [
"./mcp-service.sh",
"--endpoint",
"/api/postgres"
]
},
"storage": {
"description": "Gerenciamento de armazenamento de objetos S3 compatível",
"command": "bash",
"args": [
"./mcp-service.sh",
"--endpoint",
"/api/storage"
]
},
"context7": {
"description": "Acesso a documentação e conhecimento via Context7",
"command": "npx",
"args": ["-y", "@upstash/context7-mcp@latest"]
}
}
}
📝 Funções Disponíveis
O sistema oferece diversas funções para gerenciamento do servidor:
Gerenciamento MCP
# Listar serviços MCP disponíveis
./mcp-service.sh list
# Verificar status dos serviços MCP
./mcp-service.sh status
# Testar conexão com serviço específico
./mcp-service.sh test-mcp postgresql
# Ver logs de comunicação MCP
./mcp-service.sh logs 20
# Iniciar como servidor MCP
./mcp-service.sh --endpoint /api/mcp
Banco de Dados
# Configurar PostgreSQL com pgvector
./postgres-mcp-setup.sh
# Backup de banco de dados
source common.sh
backup_database
🔍 Diagnóstico e Resolução de Problemas
Se você encontrar problemas:
-
Verifique o status dos serviços MCP:
./mcp-service.sh status -
Verifique os logs específicos:
./mcp-service.sh logs 50 -
Teste a conexão com serviços específicos:
./mcp-service.sh test-mcp postgresql ./mcp-service.sh test-mcp storage ./mcp-service.sh test-mcp context7
🔧 Implantação em Produção
1. Configuração Inicial do Servidor
-
Atualize o sistema e instale dependências:
apt update && apt upgrade -y apt install -y curl git jq -
Clone o repositório:
git clone https://github.com/LuizBranco-ClickHype/VPS-MCP-SERVER.git cd VPS-MCP-SERVER -
Torne o script executável:
chmod +x mcp-service.sh -
Crie o diretório de logs:
mkdir -p /var/log/vps-mcp touch /var/log/vps-mcp/mcp-communication.log
2. Configuração do Servidor MCP
-
Edite o arquivo
mcp-model.jsonpara substituirIP_DO_SERVIDORpelo seu IP público ou domínio:# Exemplo com sed sed -i 's/IP_DO_SERVIDOR/seu.ip.ou.dominio/g' mcp-model.json -
Instale dependências NPM:
npm install -
Configure o firewall para permitir acesso às portas MCP:
# Se estiver usando ufw ufw allow 3000/tcp # Porta MCP principal
3. Configuração para Execução Contínua
-
Crie um serviço systemd para manter o MCP em execução:
cat > /etc/systemd/system/vps-mcp.service << EOF [Unit] Description=VPS MCP Server After=network.target [Service] Type=simple User=root WorkingDirectory=/caminho/para/VPS-MCP-SERVER ExecStart=/bin/bash mcp-service.sh --endpoint /api/mcp Restart=on-failure RestartSec=5 [Install] WantedBy=multi-user.target EOF -
Habilite e inicie o serviço:
systemctl enable vps-mcp systemctl start vps-mcp -
Verifique o status:
systemctl status vps-mcp
🤝 Contribuições
Contribuições são bem-vindas! Para contribuir:
- Faça um fork do repositório
- Crie uma branch para sua feature (
git checkout -b feature/nova-feature) - Faça commit das suas mudanças (
git commit -m 'Adiciona nova feature') - Envie para o GitHub (
git push origin feature/nova-feature) - Abra um Pull Request
📄 Licença
Este projeto está licenciado sob a