Featured image of post [MCP] @playwright/mcp로 MCP 설정 완벽 가이드 (Windows 포함)

[MCP] @playwright/mcp로 MCP 설정 완벽 가이드 (Windows 포함)

Cursor에서 MCP로 웹 자동화를 설정하는 방법을 정리했다. Node.js 18+ 설치, @playwright/mcp 연결, mcp.json 전역/프로젝트 구성, 헤드리스/격리/포트 옵션, 원격 서버와 확장 API, 보안·승인, 대안 배포판 비교까지 실무 위주로 안내한다.

Cursor에서 웹 자동화가 필요할 때마다 브라우저를 직접 조작하거나 복잡한 스크립트를 작성해야 했다면, 이제 Playwright MCP로 모든 것이 달라진다. Microsoft가 공식 배포하는 @playwright/mcp는 **Model Context Protocol(MCP)**을 통해 AI 어시스턴트가 브라우저를 직접 제어할 수 있게 해주는 혁신적인 도구다.

기존의 웹 스크래핑이나 UI 테스팅 도구들과 달리, Playwright MCP는 접근성 트리 기반의 구조화된 DOM 스냅샷을 사용해 스크린샷이나 비전 모델 없이도 빠르고 정확한 웹 상호작용을 제공한다. 더 나아가 Cursor의 MCP 통합을 통해 승인 흐름과 안전한 격리 환경까지 제공받을 수 있다.

이 가이드에서는 Windows 11 환경에서 Node.js 설치부터 시작해, .cursor/mcp.json 구성 파일 작성, 다양한 브라우저 옵션 설정, 그리고 실제 웹 자동화 시나리오까지 단계별로 완벽하게 설정하는 방법을 다룬다. 특히 개발자들이 자주 마주치는 포트 충돌, 권한 문제, 프록시 설정 등의 트러블슈팅도 함께 정리했다.

웹 개발, API 테스팅, 데이터 수집, UI 자동화 등 어떤 목적이든 5분 안에 Playwright MCP를 Cursor에 완벽히 통합할 수 있을 것이다.

왜 MCP 그리고 왜 @playwright/mcp인가

**MCP(Model Context Protocol)**은 에디터/에이전트가 외부 도구와 데이터를 안전하게 연결하는 표준 프로토콜이다. Cursor는 MCP를 통해 도구를 켜고 끄며, 승인 흐름을 제공한다. 공식 문서의 구성 위치와 사용 예시는 다음을 참고하자: Cursor – MCP 문서.

@playwright/mcp는 Microsoft가 배포하는 공식 Playwright MCP 서버로, 스크린샷·비전 모델 없이 접근성 트리 기반의 구조화된 DOM 스냅샷으로 빠르고 결정적으로 상호작용한다. 요구 사항과 기본 구성, 실행 옵션은 공식 저장소의 README가 가장 정확하다: GitHub: microsoft/playwright-mcp.

사전 준비: Node.js 설치 (Windows 기준)

  • 요구 버전: 공식 문서 기준 Node.js 18+
  • Windows PowerShell에서 LTS 설치 예시:
1
2
3
winget install OpenJS.NodeJS.LTS -s winget
node -v
npm -v

macOS는 brew install node, Linux는 배포판 패키지 매니저 또는 NodeSource를 사용하면 된다. 설치 후 node -v가 18 이상인지 확인하자.

전역/프로젝트 구성 파일 위치

  • 전역: ~/.cursor/mcp.json (Windows 예: C:\Users\<사용자>\.cursor\mcp.json)
  • 프로젝트: <프로젝트 루트>/.cursor/mcp.json

Cursor 문서의 권장 위치와 예시는 여기에서 확인할 수 있다: Using mcp.json.

최소 작동 구성 (권장)

아래 설정은 대부분의 MCP 호환 클라이언트에서 동작하는 표준 구성이다. Cursor에서도 그대로 사용할 수 있다.

1
2
3
4
5
6
7
8
{
  "mcpServers": {
    "playwright": {
      "command": "npx",
      "args": ["@playwright/mcp@latest"]
    }
  }
}

출처: microsoft/playwright-mcp – Standard config

실전 옵션: 브라우저/헤드리스/격리/포트

공식 README의 --help에는 다양한 옵션이 있다. 자주 쓰는 것만 정리한다.

  • 브라우저 채널 선택: --browser chrome|msedge|firefox|webkit
  • 헤드리스 실행: --headless (기본은 headed)
  • 접근성 외 좌표 클릭 기능: --caps=vision
  • PDF 생성 도구 포함: --caps=pdf
  • 격리 세션: --isolated (+ 초기 로그인 상태 주입 --storage-state=path/to/storage.json)
  • 서비스워커 차단: --block-service-workers
  • 허용/차단 목록: --allowed-origins, --blocked-origins (세미콜론 구분)
  • 원격(SSE/HTTP) 서버 노출: --port 8931 후 클라이언트에서는 "url": "http://localhost:8931/mcp"

예시 1) 격리 세션 + 초기 스토리지 상태

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
{
  "mcpServers": {
    "playwright": {
      "command": "npx",
      "args": [
        "@playwright/mcp@latest",
        "--isolated",
        "--storage-state=state.json"
      ]
    }
  }
}

예시 2) 원격 서버로 실행(IDE 외부에서 기동) 후 Cursor가 URL로 연결

1
npx @playwright/mcp@latest --port 8931
1
2
3
4
5
{
  "mcpServers": {
    "playwright": { "url": "http://localhost:8931/mcp" }
  }
}

공식 사용법 상세: README – Configuration/Standalone · Standalone MCP server

Cursor에서 켜기: UI와 파일, 두 가지 방식

  1. UI: Settings → Tools → MCP → Add new global MCP server → 이름/명령/인자 입력

  2. 파일: ~/.cursor/mcp.json 또는 프로젝트의 .cursor/mcp.json을 직접 작성

Cursor 문서에는 확장 API로 프로그램적으로 서버를 등록하는 방식도 소개되어 있다. 엔터프라이즈/자동화 환경에 유용하다: MCP Extension API.

다른 배포판과의 비교

기준@playwright/mcp (공식)executeautomation/mcp-playwright (커뮤니티)기타 커스텀/래퍼형
배포Microsoft 공식 npm (@playwright/mcp)GitHub 커뮤니티 리포지토리다양한 개인/기업 리포지토리
설치npx @playwright/mcp@latest리포지토리별 상이리포지토리별 상이
기능접근성 트리 기반, caps=vision/pdf, 원격/격리, 풍부한 CLI 옵션대체로 유사하나 최신 기능 추적은 리포마다 편차목적 특화(테스트/크롤링 등) 래퍼 추가 가능
문서/업데이트활발한 릴리스/문서화유지보수 빈도 가변가변
권장도기본 선택지로 권장특정 워크플로우에서 대안특정 특수 기능 필요 시 선택

핵심은 “가능하면 공식 배포판을 먼저 적용”하는 것이다. 최신 Playwright/브라우저 채널 연동, 문서/옵션의 일관성에서 이점이 크다.

보안/승인 및 도구 토글

Cursor는 MCP 도구를 사용할 때 기본적으로 사용자 승인을 요구하고, 토글을 통해 도구 활성/비활성을 관리한다. 이미지/파일 응답을 베이스64로 전달하는 형태도 지원한다. 자세한 정책과 권장 보안 체크리스트는 문서를 참고: Tool approval · Security.

문제 해결(Windows 포함)

  • 전역 vs 프로젝트 설정이 로드되지 않는 경우: 커뮤니티 포럼의 유사 증상을 확인하자. 특히 Windows 11에서 프로젝트 단위 /.cursor/mcp.json 인식 이슈 사례가 있었다: Cursor Forum 사례
  • Node 버전 오류: node -v로 18+ 확인. 낮으면 LTS 재설치
  • 브라우저 실행 실패: --executable-path로 명시하거나 --headless로 전환 테스트
  • 네트워크 차단: --allowed-origins/--blocked-origins 점검, 프록시 환경은 --proxy-server/--proxy-bypass 사용

빠른 체크리스트

  1. Node.js 18 이상 설치 및 확인
  2. ~/.cursor/mcp.json 또는 프로젝트 /.cursor/mcp.json에 표준 구성 추가
  3. 필요 시 --isolated, --headless, --caps=vision/pdf 등 옵션 확장
  4. 보안/승인 정책 확인 후 실제 브라우저 작업 시도

참고 자료