192.168.219.45 → 192.168.0.100 일괄 변경 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
9.7 KiB
9.7 KiB
Robeing Monitor 모니터링 아키텍처
1. 목적
- 역할 한 줄 요약:
robeing-monitor는 로빙/스킬/컨테이너에서 발생하는 상태·이벤트·리소스 데이터를 관찰(수집)·기록(저장)·표시(조회/대시보드 제공) 하는 중앙 모니터링 백엔드이다. - 이 문서는 현재 인프라 구조에서 robeing-monitor가 담당할 모니터링 책임 범위와,
각 서비스가 어떤 형식으로 데이터를 제공해야 하는지(계약) 를 정의한다.
2. 인프라 구조 요약 (현재 기준)
2.1 서버 배치
| 서버 | IP | 주요 서비스 | 포트 | 역할 |
|---|---|---|---|---|
| 51123 | 192.168.0.100 | nginx, Gitea, auth-server, robeing-gateway | 80, 443, 3000, 8100 | 외부 진입, 인증, 프록시 |
| 51124 | 192.168.219.52 | rb8001, rb10508_micro, robeing-monitor, skill-* | 8001, 10508, 9024, 85xx | 로빙/스킬/모니터링 실행 |
상세 구조:
310_전체_시스템_구조_컨테이너와_마이크로서비스.md,
Slack 경유 플로우:320_Slack_기반_인터페이스_설계.md참조.
2.2 모니터링 관련 데이터 흐름 (요약)
flowchart TD
subgraph UserSide[사용자 측]
U[사용자\nSlack / Web UI]
end
subgraph Frontend[51123]
G[robeing-gateway (8100)]
end
subgraph Backend[51124]
RB8001[rb8001 (8001)\n프로덕션 로빙]
RB10508[rb10508_micro (10508)\nSlack 이벤트 처리]
Skills[skill-* (85xx)\n뉴스/이메일 등]
Monitor[robeing-monitor (9024)\n이 문서의 주인공]
end
subgraph Storage[데이터 저장소]
PG[(PostgreSQL\nrobeing_stats 등)]
Chroma[(ChromaDB\n벡터 메모리)]
OS[(OpenSearch\nDataprepper-static)]
end
U -->|요청/이벤트| G -->|프록시| RB8001
G --> RB10508
RB8001 -->|상태/이벤트 전송| Monitor
RB10508 -->|상태/이벤트 전송| Monitor
Skills -->|상태/이벤트 전송| Monitor
Monitor -->|스탯/로그 기록| PG
Monitor -->|메모리 기록| Chroma
Monitor -->|표준 로그/메트릭| OS
U -->|대시보드 조회| G --> Monitor
3. Robeing Monitor의 책임 범위
3.1 책임 한 눈에 보기
- 수집(Observe): rb8001, rb10508_micro, skill-* 등에서 발생하는 상태 변화, 요청/응답 이벤트, 리소스 사용량을 표준 형태로 수집한다.
- 기록(Record): 수집한 데이터를 PostgreSQL/ChromaDB/OpenSearch에 일관된 스키마로 저장한다.
- 표시(Show):
/api/stats/*,/api/memory/*,/api/monitor/*API를 통해 현재 상태 + 히스토리 + 집계를 제공한다. - 알림(Notify, 선택): 향후에는 에러율/응답시간/특정 에러 패턴을 기준으로 알람 트리거를 보내는 역할까지 확장 가능하다.
3.2 “하지 않는 일”
- 비즈니스 로직(예: 이메일 실제 발송, 뉴스 수집, Slack 응답 생성)을 대신 수행하지 않는다.
- LLM 추론/대화 생성/의도 분류를 대신 수행하지 않는다.
- 오케스트레이션(워크플로우 실행)을 중앙에서 모두 담당하지 않는다.
(단, 모니터링용으로 “어떤 워크플로우가 언제 어떻게 실패했는지”를 기록하는 것은 책임 범위 안이다.)
요약: robeing-monitor는 “관찰자 + 기록자 + 리포터” 역할에 집중한다.
4. 데이터 모델 및 계약(Contract)
4.1 공통 식별자 규칙
- robeing_id:
rb8001,rb10508_micro등 로빙/컨테이너 단위 ID. - user_uuid: Slack ID → UUID 변환 규칙에 따른 사용자 UUID.
- 변환 규칙:
250817_robeing_monitor_integration.md의 namespace UUID 사용.
- 변환 규칙:
- request_id: 게이트웨이/서비스별로 생성하는 요청 단위 추적 ID (예: UUID4 문자열).
모든 서비스(rb8001, rb10508_micro, skill-*)는 로깅/모니터링 대상 이벤트에 대해
다음 필드를 가능한 한 포함하는 것을 원칙으로 한다.
{
"timestamp": "2025-11-16T15:28:15.199Z",
"robeing_id": "rb8001",
"user_uuid": "…",
"request_id": "…",
"channel": "Slack 채널 ID 또는 Web UI 세션 ID",
"event_type": "llm_call | skill_call | scheduler_job | health_check | error",
"status": "success | error | timeout",
"latency_ms": 1234,
"meta": {
"intent": "email_send",
"skill_name": "skill-email",
"http_status": 200
}
}
4.2 Robeing Monitor 내부 저장소 역할
- PostgreSQL
robeing_stats: 로빙 스탯(레벨, memory/compute/empathy/leadership 등) 기록.robeing_stats_history(제안): 일정 주기/이벤트 기반 스냅샷 저장.gmail_token,gmail_audit_logs등 기존 토큰/감사 로그 테이블.
- ChromaDB
- 각 유저별/로빙별 벡터 메모리 저장 (
rb8001_{user_uuid},rb8001_{user_uuid}_memory등). - 장기적으로 “모니터링용 메타데이터(예: 요약된 세션 상태)”도 저장 가능.
- 각 유저별/로빙별 벡터 메모리 저장 (
- OpenSearch (
dataprepper-static)- Fluent Bit → Data Prepper를 통해 들어오는 표준화된 JSON 로그/메트릭 저장.
- 운영 대시보드/알람의 주요 데이터 소스.
5. 각 서비스와의 연동 규칙
5.1 rb8001 (프로덕션 로빙, 포트 8001)
- 해야 할 일
- LLM 호출, 스킬 호출, 주요 사용자 액션에 대해 위 4.1의 공통 필드 기반 로그를 남긴다.
- 정기적으로(또는 이벤트 기반으로) robeing-monitor의 다음 API를 호출해 스탯/상태 동기화:
PUT /api/stats/{robeing_id}– 레벨/스탯 업데이트POST /api/logs/{robeing_id}– 대화/이벤트 로그 저장POST /api/memory/{robeing_id}/store– 중요 메모리 저장
- robeing-monitor가 제공해야 할 것
GET /api/stats/{robeing_id}– 현재 스탯(프론트/Slack에서 사용).GET /api/stats/{robeing_id}/history– 성장 히스토리(그래프용).GET /api/logs/{robeing_id}/stats– 대화 통계(요청 수, 실패율 등).
5.2 rb10508_micro (Slack 이벤트 처리)
- Slack 기반 아키텍처:
320_Slack_기반_인터페이스_설계.md참조. - 해야 할 일
- Slack 이벤트 처리 시, 사용자/채널/의도/처리 결과를 robeing-monitor로 기록:
POST /api/logs/{robeing_id}– conversation_log 스타일로 기록.- 에러/타임아웃 발생 시
status="error"와 함께 원인 코드를 남긴다.
- Slack 이벤트 처리 시, 사용자/채널/의도/처리 결과를 robeing-monitor로 기록:
- robeing-monitor가 제공해야 할 것
- Slack 운영 대시보드에서 사용할 “사용자별/채널별 사용량, 스킬 사용 통계” 쿼리 API.
5.3 skill-* (이메일, 뉴스, Slack, RAG 등)
- 해야 할 일
- 각 스킬이 수행하는 주요 작업(예: 이메일 발송/뉴스 수집/RAG 검색)에 대해
요청 수, 성공/실패, 지연 시간, 외부 API 에러를 robeing-monitor 또는 OpenSearch에 기록. - 스킬 자체 헬스 상태를 robeing-monitor가 주기적으로 조회할 수 있도록
/health를 제공.
- 각 스킬이 수행하는 주요 작업(예: 이메일 발송/뉴스 수집/RAG 검색)에 대해
- robeing-monitor가 제공해야 할 것
GET /api/monitor/skills– 스킬별 헬스/에러율/응답시간 요약.- 향후:
GET /api/monitor/resources– 스킬 컨테이너별 CPU/메모리/디스크 사용량.
6. “보여주기(대시보드)”를 위한 설계
6.1 운영자용(엔지니어) 뷰
- 도구: OpenSearch Dashboards
- 데이터 소스:
dataprepper-static인덱스 - 주요 화면
- 서비스별 로그 검색(robeing_id / container_name 필터).
- 에러 패턴(“Event loop is closed”, “never awaited” 등) 트렌드 그래프.
- 응답시간/에러율 타임시리즈.
6.2 제품/운영용 뷰
- 도구:
robeing-monitor전용 Web UI 또는 기존 프론트 내 “운영 대시보드” 페이지. - 데이터 소스:
robeing-monitorAPI (/api/stats/*,/api/monitor/*등) - 주요 화면
- 로빙별 성장 그래프(레벨/스탯 히스토리).
- 사용자/워크스페이스별 사용량/성공률/스킬 사용 분포.
- 스킬/서비스별 현재 헬스 상태와 최근 에러 요약.
6.3 역할 분리 원칙
- OpenSearch 대시보드: “원시 로그/에러 중심” 디버깅/장기 분석.
- robeing-monitor UI/API: “도메인 친화적인 지표(레벨, 사용량, 성공률)” 중심 뷰.
7. 향후 개선 방향
-
로그 스키마 완전 표준화
- 모든 서비스에서 동일 필드명/타입 사용 (
robeing_id,user_uuid,request_id,event_type,status,latency_ms등). - Fluent Bit → Data Prepper 파이프라인에서 JSON 스키마 검증/정규화.
- 모든 서비스에서 동일 필드명/타입 사용 (
-
히스토리/집계 API 확장
/api/stats/{robeing_id}/history?from=...&to=...&interval=.../api/monitor/overview에 기간 필터/집계 옵션 추가.
-
알람 시스템 연동
- OpenSearch 쿼리 기반 알람 룰(에러율, 특정 메시지 패턴 등).
- robeing-monitor 내부 스케줄러(APScheduler)를 활용한 주기적 점검 및 Slack 알림.
-
문서/코드 정합성 유지
- 새로 정의된 로깅 스키마/엔드포인트 변경 시,
이 문서와 각 서비스 README를 동시에 갱신하는 것을 원칙으로 한다.
- 새로 정의된 로깅 스키마/엔드포인트 변경 시,
8. 요약 (운영 관점 3줄)
robeing-monitor는 모든 로빙/스킬의 상태·이벤트·리소스 데이터를 중앙에서 모니터링하고 기록·표시하는 전담 백엔드이다.- 각 서비스는 공통 식별자(robeing_id/user_uuid/request_id)와 표준 로그 스키마를 따라 robeing-monitor/OpenSearch에 데이터를 보내야 한다.
- 운영자는 OpenSearch Dashboards(엔지니어용)와 robeing-monitor API/대시보드(제품/운영용)를 통해 현재 상태와 히스토리를 한눈에 볼 수 있게 된다.