kookmin-stock

kookmin-stock

MCP server that provides Korean stock market data including indices, top gainers, stock quotes, news, fundamentals, and buy recommendations. Enables LLMs to access real-time and historical Korean stock information.

Category
访问服务器

README

Kookmin MCP Stock Agent

국민대 과제 · "Hermes + MCP 자작 서버로 임팩트 끌어올리기"

지난 과제에서 만든 국내 주식 추천 Hermes 에이전트에 자작 MCP 서버를 붙여 작업 퀄리티가 어떻게 변하는지 3가지 실험으로 증명한다.

🎯 무엇이 들어 있나

산출물 경로 설명
MCP 서버 (정상) src/mcp_stock/server.py FastMCP stdio, 도구 6종
MCP 서버 (망가뜨린 버전) src/mcp_stock/server_broken.py 잘못된 description / 타임아웃 / 빈 응답
30초 동작 데모 src/experiments/exp1_demo.py 녹화용 시퀀스 출력
실험 ② 결과 비교 src/experiments/exp2_quality.py NO MCP / GOOD / BROKEN 비교
실험 ③ 패턴 비교 src/experiments/exp3_orchestration.py Single / Planner+Executor / Parallel
발표 자료(spec) slides/slides.md 다른 AI에 그대로 붙여 PPT 생성
결과 산출물 results/exp2_*, results/exp3_* 자동 생성 표·CSV·로그

⚙️ 설치

Python 3.10+ (테스트 환경 3.13).

python -m venv .venv
source .venv/bin/activate
pip install -e .

▶️ 실행

# 1) MCP 서버 검증 (서버는 stdio라 호스트가 붙어야 의미 있음 — Ctrl+C로 종료)
python -m mcp_stock.server

# 2) 30초 동작 데모 (실제로 돌려서 녹화)
python -m experiments.exp1_demo
#  또는 ./demo/record_demo.sh

# 3) 실험 ② 성공/실패 비교 → results/exp2_* 자동 생성
python -m experiments.exp2_quality

# 4) 실험 ③ Orchestration 토큰 비교 → results/exp3_* 자동 생성
python -m experiments.exp3_orchestration

🎥 30초 데모 녹화

demo/demo_script.md에 타임코드별 행동이 정리돼 있다. 가장 단순한 경로:

./demo/record_demo.sh         # QuickTime/Cmd+Shift+5 로 화면 녹화하면서 실행
./demo/record_demo.sh --asciinema   # 텍스트 캡처 (asciinema 필요)

🧪 실험 ① — MCP 서버 (도구 6종)

도구 입력 출력
get_market_overview(date) 'today' / YYYY-MM-DD {kospi:{close, changePct, tradingValueKrw}, kosdaq:{...}}
get_top_gainers(market, top_n) KOSPI/KOSDAQ, 1..50 상위 N 종목
get_stock_quote(ticker) 코드 또는 한글명 close / changePct / volume / per / pbr
get_recent_news(query, top_n) 키워드 또는 종목명 헤드라인 + positivityScore
get_fundamentals(ticker) 코드 또는 한글명 per / pbr / eps / bps / roe
recommend_buys(market, top_n, criteria) KOSPI/KOSDAQ scoreBreakdown + rationale

데이터: Naver Finance 크롤링 단일 소스 (src/mcp_stock/sources/naver.py). 무료·키 불필요.

  • 지수: polling.finance.naver.com/api/realtime/domestic/index/{KOSPI|KOSDAQ} JSON
  • 등락률 상위: finance.naver.com/sise/sise_rise.naver?sosok={0|1} HTML
  • 종목 상세 / PER·EPS·PBR·배당: finance.naver.com/item/main.naver?code=... (안정적인 id="_per" 등 emphasis 태그)
  • 종목별 뉴스: finance.naver.com/item/news_news.naver?code=...
  • 휴장일 / 네이버 페이지 변경 시 자동 fallback 스냅샷으로 안전 동작.

🧪 실험 ② — Tool 성공/실패 결과 퀄리티 비교

exp2_quality.py가 동일한 사용자 질문을 세 환경으로 돌리고 표·실패 로그를 자동 생성한다.

  • (a) NO MCP — 도구 0개. LLM이 학습 데이터로만 답변 → 환각·근거 부재.
  • (b) GOOD MCP — 정상 자작 서버. 도구 12회 호출, 4개 호재 키워드 인용.
  • (c) BROKEN MCPserver_broken.py 정의대로:
    • get_top_gainers description을 "하락률 상위"로 잘못 적음 → 모델 오선택
    • get_recent_newstime.sleep(5)TimeoutError 발생
    • get_fundamentals가 빈 dict 반환

결과:

  • results/exp2_quality_table.md — 비교 표
  • results/exp2_failure_logs.md — 실패 호출 트레이스 + 답변 본문
  • results/exp2_summary.json — 원본 통계

🧪 실험 ③ — Orchestration 3패턴

패턴 설명 토큰 특성 응답시간 특성
Single 한 루프 내 도구 결과 누적 입력 토큰 ↑↑ 가장 느림
Planner + Executor planner가 호출 시퀀스만 짜고 executor는 결과 요약만 입력 토큰 ↓ 중간
Parallel sub-agents KOSPI / KOSDAQ / NEWS sub-agent 동시 실행 입력 토큰 ↓↓ 가장 빠름

결과:

  • results/exp3_benchmark.csv — 막대그래프 작성용 wide CSV
  • results/exp3_pattern_table.md — 표 + 회고
  • results/exp3_summary.json — 패턴별 풀 트레이스

🤖 LLM 연동 — Hermes / 다른 호스트

이 저장소는 LLM API 키 없이도 결정적 시뮬레이션으로 토큰·트레이스가 나오도록 만들었다. 실제 Hermes / Claude Desktop / Cursor에 붙이려면:

1) Hermes 호스트로 사용 (실험 ②③를 진짜 LLM으로 돌리기)

src/experiments/runner/hermes_runner.py_callHermes()만 채우면 된다.

# TODO(user): replace this body with the real Hermes call.
import httpx
response = httpx.post(self.endpoint, headers=..., json=...)
return response.json()

환경변수 HERMES_ENDPOINT, HERMES_API_KEY 설정 후 AgentRunner 인스턴스를 HermesRunner()로 교체.

2) Claude Desktop / Cursor에서 도구만 사용

Claude Desktop의 claude_desktop_config.json 또는 Cursor MCP 설정에 추가:

{
  "mcpServers": {
    "kookmin-stock": {
      "command": "python",
      "args": ["-m", "mcp_stock.server"],
      "cwd": "/path/to/Kookmin-University-MCP",
      "env": { "PYTHONPATH": "/path/to/Kookmin-University-MCP/src" }
    }
  }
}

📑 PPT 만들기

slides/slides.md를 다른 AI에게 그대로 붙여넣으면 된다. 예시 프롬프트:

다음 markdown은 5분 발표용 12장 슬라이드 spec이야. # Slide N 헤더 단위로 PowerPoint 슬라이드를 만들어줘. ### Visual 블록은 가급적 mermaid 다이어그램이나 표 그대로 표현하고, ### Speaker Notes는 슬라이드 노트 영역에 넣어줘.

📤 제출 흐름

  1. python -m experiments.exp2_quality && python -m experiments.exp3_orchestration 으로 결과 갱신
  2. ./demo/record_demo.sh 로 30초 데모 녹화 → demo/demo.mov
  3. GitHub push (저장소 URL을 README와 slide 6에 기록)
  4. 이메일 kts123@kookmin.ac.kr 로 GitHub URL + slides + demo 영상 전송 (마감 5/14 23:59:59)

📁 디렉토리 트리

.
├── README.md
├── pyproject.toml / requirements.txt
├── demo/
│   ├── demo_script.md
│   └── record_demo.sh
├── results/                 # 자동 생성
├── slides/slides.md
└── src/
    ├── mcp_stock/
    │   ├── server.py
    │   ├── server_broken.py
    │   ├── data/ticker_map.py
    │   ├── sources/naver.py        # 네이버 금융 크롤러 (단일 데이터 소스)
    │   └── tools/{market, quote, news, fundamentals, recommend}.py
    ├── experiments/
    │   ├── exp1_demo.py
    │   ├── exp2_quality.py
    │   ├── exp3_orchestration.py
    │   └── runner/{agent_base, mock_runner, hermes_runner}.py
    └── utils/{logger, token_counter}.py

🛟 트러블슈팅

증상 원인 대응
naver detail fetch failed for XXXXXX 네이버 페이지에 해당 종목이 없거나 구조 변경 자동 fallback 스냅샷 사용 — 정상 동작
httpx.ConnectError 네트워크 오프라인 모든 도구가 fallback 스냅샷으로 안전 동작
한글 깨짐 터미널 폰트 D2 Coding / Pretendard / SF Mono 권장
휴장일/주말 호출 영업일 아님 폴링 API는 마지막 종가를 그대로 반환

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选