remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Integrations
Provides access to Confluence API functionality including retrieving space lists, fetching pages within spaces, accessing specific page details by ID, creating new pages, and updating existing pages.
Confluence MCP Server
Confluence API에 접근하기 위한 Model Context Protocol 서버 시스템입니다. Personal Access Token을 사용하여 Confluence와 통신합니다. VPN 영역 내에서 Confluence API에 접근하기 위한 중개 서버 역할을 합니다.
시스템 구성
이 프로젝트는 두 가지 서버로 구성되어 있습니다:
- MCP 서버 (server.ts): Confluence API와 통신하여 데이터를 처리하는 주 서버입니다.
- 기본 포트: 3000
- RESTful API 제공
- MCP 프로토콜 처리
- 프록시 서버 (proxyServer.ts): MCP 클라이언트와 MCP 서버 사이의 프록시 역할을 합니다.
- 기본 포트: 3001
- MCP 클라이언트로부터 요청을 받아 주 서버로 전달
이 구조는 VPN 영역 문제를 해결하기 위해 설계되었습니다. MCP 서버는 VPN 내부에서 실행되어 Confluence API에 접근하고, 프록시 서버는 외부에서 접근 가능한 환경에서 실행됩니다.
기능
- 모든 Confluence 스페이스 목록 조회
- 특정 스페이스 내의 모든 페이지 조회
- 페이지 ID로 특정 페이지 정보 조회
- 새 페이지 생성
- 기존 페이지 업데이트
설치 및 설정
필수 조건
- Node.js 16.x 이상
- Bun 1.0.0 이상
설치
환경 변수 설정
.env
파일을 프로젝트 루트에 생성하고 다음 내용을 추가합니다:
실행
개발 환경
프로덕션 환경
엔드포인트
MCP 서버 엔드포인트 (기본 포트: 3000)
- POST /mcp - MCP 요청을 처리하는 메인 엔드포인트
- GET /mcp/tools - 사용 가능한 도구 목록 조회
- GET /api/spaces - 모든 스페이스 목록 조회
- GET /api/spaces/:spaceKey/pages - 특정 스페이스의 페이지 목록 조회
- GET /api/pages/:pageId - 특정 페이지 정보 조회
- POST /api/pages - 새 페이지 생성
- PUT /api/pages/:pageId - 페이지 업데이트
- GET /health - 서버 상태 확인
프록시 서버 엔드포인트 (기본 포트: 3001)
- POST /mcp - MCP 클라이언트 요청을 받아 MCP 서버로 전달
- GET /tools - 사용 가능한 도구 목록 조회
- GET /health - 프록시 서버 상태 확인
문제 해결
VPN 영역 문제 해결
이 프로젝트는 VPN 영역 문제를 해결하기 위해 두 서버로 분리되었습니다:
- MCP 서버는 VPN 내부에서 실행하여 Confluence API에 직접 접근합니다.
- 프록시 서버는 외부에서 접근 가능한 환경에서 실행하여 MCP 클라이언트의 요청을 받습니다.
이 구성은 MCP 클라이언트가 직접 Confluence API에 접근할 수 없는 상황에서 중개 역할을 합니다.
"Error fetching spaces: Unable to connect" 오류
이 오류는 다음과 같은 문제로 발생할 수 있습니다:
- HTTPS 인증서 문제: 개발 환경에서는 SSL 인증서 검증이 비활성화되어 있지만, 프로덕션 환경에서는 올바른 인증서 설정이 필요합니다.
- 네트워크 연결 문제: 방화벽이나 프록시 설정으로 인해 Confluence 서버에 접근할 수 없는 경우입니다.
- Personal Access Token 문제: 토큰이 만료되었거나 잘못된 형식일 수 있습니다.
해결 방법
.env
파일의CONFLUENCE_BASE_URL
이 올바른지 확인합니다.- Personal Access Token이 유효한지 확인합니다.
- 방화벽 설정을 확인하여 Confluence 서버에 접근할 수 있는지 확인합니다.
- 네트워크 관리자에게 문의하여 접근 권한을 확인합니다.
- MCP 서버와 프록시 서버 간의 연결이 올바르게 설정되었는지 확인합니다 (
MCP_SERVER_URL
설정).
테스트
배포 구성
권장 배포 구성
프로덕션 환경에서는 다음과 같은 배포 구성을 권장합니다:
- MCP 서버: VPN 내부 또는 Confluence 서버에 접근할 수 있는 네트워크에 배포
- 프록시 서버: MCP 클라이언트가 접근할 수 있는 네트워크에 배포
보안 고려사항
- 프록시 서버와 MCP 서버 간의 통신은 HTTPS를 사용하여 암호화하는 것을 권장합니다.
- Personal Access Token은 안전하게 관리하고, 필요에 따라 정기적으로 갱신하세요.
- 프로덕션 환경에서는 적절한 인증 메커니즘을 추가하여 프록시 서버에 대한 무단 접근을 방지하세요.
라이센스
MIT
This server cannot be installed
A Model Context Protocol server for accessing Confluence API using Personal Access Tokens, enabling users to retrieve space lists, view pages, create new pages, and update existing content.