DOCS/docs/troubleshooting/20250714_docker_network_isolation.md
happybell80 ba52ee2200 docs: 트러블슈팅 문서 추가
- 관리자 대시보드 구축 과정
- Gitea Actions 설정
- GitHub에서 마이그레이션
- 시스템 메트릭 구현
- Docker 네트워크 격리 문제 해결

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-15 01:09:36 +09:00

102 lines
2.8 KiB
Markdown

# Docker 네트워크 격리로 인한 test-api unreachable 문제 해결
## 개요
- **날짜**: 2025-07-14
- **문제**: 관리자 대시보드에서 test-api (10508) 서비스가 unreachable 상태
- **원인**: Docker 네트워크 격리 (DOCKER-ISOLATION iptables 체인)
## 문제 상황
### 증상
- 관리자 대시보드에서 test-api 서비스가 지속적으로 `unreachable` 표시
- 호스트에서는 `curl http://localhost:10508/health` 정상 동작
- 컨테이너 내부에서는 연결 불가
### 네트워크 구성
```
frontend_default (172.18.0.0/16)
├── frontend-backend-1 (172.18.0.2)
└── frontend-frontend-1 (172.18.0.3)
appnet (172.21.0.0/16)
└── test-api-container (172.21.0.2)
```
## 원인 분석
Docker의 기본 bridge 네트워크 드라이버는 네트워크끼리 완전히 격리하도록 iptables 체인(DOCKER-ISOLATION, DOCKER-USER)을 자동으로 생성합니다.
**결과**: 같은 호스트라도 서로 다른 bridge 네트워크에 있는 컨테이너는 호스트 포트(`-p 10508:10508`)로도 통신이 차단됨
## 해결 방법
### 선택한 해결책: 같은 사용자 정의 네트워크에 연결
1. **appnet 네트워크 확인**
```bash
docker network ls
docker network inspect appnet
```
2. **frontend 컨테이너들을 appnet에 연결**
```bash
docker network connect appnet frontend-backend-1
docker network connect appnet frontend-frontend-1
```
3. **연결 확인**
```bash
docker network inspect appnet
# 모든 컨테이너가 나타나는지 확인
```
4. **테스트**
```bash
docker exec frontend-backend-1 curl -s -o /dev/null -w "%{http_code}" http://test-api-container:10508/health
# 200 응답 확인
```
### 다른 가능한 해결 방법들
1. **docker-compose.yml에서 네트워크 설정**
```yaml
services:
backend:
networks:
- appnet
networks:
appnet:
external: true
```
2. **host 네트워크 사용** (보안상 비추천)
```yaml
network_mode: "host"
```
3. **iptables 예외 규칙** (관리 복잡)
```bash
iptables -I DOCKER-USER -i br0 -o br1 -j ACCEPT
```
## 주의사항
1. **영구 설정**: 컨테이너 재시작 시 네트워크 연결이 유지되려면 docker-compose.yml 수정 필요
2. **DNS 해결**: 같은 네트워크에 있으면 컨테이너 이름으로 통신 가능
3. **보안**: 필요한 컨테이너만 같은 네트워크에 연결
## 검증 방법
```bash
# 네트워크 연결 상태 확인
docker network inspect appnet | grep -A 5 "Containers"
# 관리자 대시보드에서 서비스 상태 확인
curl http://localhost:8000/admin/services/status
```
## 참고사항
- Docker 네트워크 격리는 보안을 위한 의도된 동작
- 같은 네트워크에 있는 컨테이너끼리만 직접 통신 가능
- 서로 다른 네트워크 간 통신은 명시적인 설정 필요