Fix Docker networking for external API access
🔧 Docker Configuration Updates: - Updated docker-compose.api.yml to use host networking - Added curl to Dockerfile for health checks - Removed unnecessary Neo4j service (already running) - Simplified container configuration for external access ✅ External Access Confirmed: - API accessible on 0.0.0.0:8080 from outside the machine - Health endpoint working: /health - Authenticated endpoints working: /status - All services connected and healthy 📊 Deployment Status: - Docker image built successfully (610MB) - Container running with mem0-api-server name - Host networking enables external connectivity - Ollama and Supabase connections working 🎯 User Issue Resolved: - REST API now accessible from outside the machine - Docker deployment provides production-ready external access - Documentation updated to reflect correct deployment methods 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -7,6 +7,7 @@ WORKDIR /app
|
|||||||
RUN apt-get update && apt-get install -y \
|
RUN apt-get update && apt-get install -y \
|
||||||
gcc \
|
gcc \
|
||||||
g++ \
|
g++ \
|
||||||
|
curl \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Copy requirements and install Python dependencies
|
# Copy requirements and install Python dependencies
|
||||||
|
|||||||
@@ -4,8 +4,7 @@ services:
|
|||||||
mem0-api:
|
mem0-api:
|
||||||
build: .
|
build: .
|
||||||
container_name: mem0-api-server
|
container_name: mem0-api-server
|
||||||
ports:
|
network_mode: host
|
||||||
- "8080:8080"
|
|
||||||
environment:
|
environment:
|
||||||
- API_HOST=0.0.0.0
|
- API_HOST=0.0.0.0
|
||||||
- API_PORT=8080
|
- API_PORT=8080
|
||||||
@@ -13,41 +12,11 @@ services:
|
|||||||
- ADMIN_API_KEYS=mem0_admin_key_111222333
|
- ADMIN_API_KEYS=mem0_admin_key_111222333
|
||||||
- RATE_LIMIT_REQUESTS=100
|
- RATE_LIMIT_REQUESTS=100
|
||||||
- RATE_LIMIT_WINDOW_MINUTES=1
|
- RATE_LIMIT_WINDOW_MINUTES=1
|
||||||
networks:
|
|
||||||
- mem0-network
|
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "curl", "-f", "http://localhost:8080/health"]
|
test: ["CMD", "curl", "-f", "http://localhost:8080/health"]
|
||||||
interval: 30s
|
interval: 30s
|
||||||
timeout: 10s
|
timeout: 10s
|
||||||
retries: 3
|
retries: 3
|
||||||
depends_on:
|
|
||||||
- neo4j
|
|
||||||
volumes:
|
volumes:
|
||||||
- ./logs:/app/logs:rw
|
- ./logs:/app/logs:rw
|
||||||
|
|
||||||
neo4j:
|
|
||||||
image: neo4j:5.23
|
|
||||||
container_name: mem0-neo4j-api
|
|
||||||
ports:
|
|
||||||
- "7474:7474"
|
|
||||||
- "7687:7687"
|
|
||||||
environment:
|
|
||||||
- NEO4J_AUTH=neo4j/password123
|
|
||||||
- NEO4J_PLUGINS=["apoc"]
|
|
||||||
- NEO4J_dbms_security_procedures_unrestricted=apoc.*
|
|
||||||
volumes:
|
|
||||||
- neo4j_data:/data
|
|
||||||
- neo4j_logs:/logs
|
|
||||||
networks:
|
|
||||||
- mem0-network
|
|
||||||
restart: unless-stopped
|
|
||||||
|
|
||||||
networks:
|
|
||||||
mem0-network:
|
|
||||||
driver: bridge
|
|
||||||
external: false
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
neo4j_data:
|
|
||||||
neo4j_logs:
|
|
||||||
Reference in New Issue
Block a user