mirror of
https://github.com/ktds-dg0501/kt-event-marketing.git
synced 2025-12-06 20:46:24 +00:00
7.1 KiB
7.1 KiB
네이버 블로그 포스팅 설정 가이드
개요
Distribution Service는 Playwright를 사용하여 네이버 블로그에 자동으로 포스팅합니다.
사전 준비
1. Playwright 설치
처음 실행 시 Playwright 브라우저가 자동으로 다운로드됩니다. 수동으로 설치하려면:
# Windows (PowerShell)
mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="install chromium"
# Linux/Mac
mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="install chromium"
2. 네이버 계정 준비
- 네이버 계정 (아이디/비밀번호)
- 네이버 블로그 개설 (blog.naver.com에서 블로그 만들기)
- 블로그 ID 확인 (예: blog.naver.com/YOUR_BLOG_ID)
환경 변수 설정
IntelliJ 실행 프로파일 설정
.run/DistributionServiceApplication.run.xml 파일에서 다음 환경 변수를 설정:
<env name="NAVER_BLOG_USERNAME" value="your_naver_id" />
<env name="NAVER_BLOG_PASSWORD" value="your_password" />
<env name="NAVER_BLOG_BLOG_ID" value="your_blog_id" />
<env name="NAVER_BLOG_HEADLESS" value="false" /> <!-- 브라우저 표시 여부 -->
<env name="NAVER_BLOG_SESSION_PATH" value="playwright-sessions" />
환경 변수 설명
| 환경 변수 | 설명 | 기본값 | 필수 |
|---|---|---|---|
NAVER_BLOG_USERNAME |
네이버 아이디 | - | ✅ |
NAVER_BLOG_PASSWORD |
네이버 비밀번호 | - | ✅ |
NAVER_BLOG_BLOG_ID |
네이버 블로그 ID | - | ✅ |
NAVER_BLOG_HEADLESS |
Headless 모드 (true/false) | true | ❌ |
NAVER_BLOG_SESSION_PATH |
세션 저장 경로 | playwright-sessions | ❌ |
Headless 모드
- false: 브라우저 창이 표시되어 디버깅에 유용 (개발 환경 권장)
- true: 백그라운드 실행, 서버 환경에 적합 (운영 환경 권장)
사용 방법
API 호출 예시
# 배포 요청
curl -X POST http://localhost:8085/distribution/api/v1/distributions \
-H "Content-Type: application/json" \
-d '{
"eventId": "EVT001",
"title": "신규 이벤트 안내",
"content": "이벤트 상세 내용입니다.",
"imageUrl": "https://example.com/event.jpg",
"channels": ["NAVER"]
}'
응답 예시
{
"eventId": "EVT001",
"status": "SUCCESS",
"totalChannels": 1,
"successCount": 1,
"failureCount": 0,
"channels": [
{
"channel": "NAVER",
"success": true,
"distributionId": "NAVER-abc123",
"distributionUrl": "https://blog.naver.com/your_blog_id/222999999999",
"estimatedReach": 2000,
"executionTimeMs": 5234
}
],
"distributedAt": "2025-10-29T10:30:00"
}
세션 관리
자동 로그인
- 최초 실행 시 네이버에 로그인하고 세션이 저장됩니다
- 이후 요청은 저장된 세션을 사용하여 로그인 없이 진행됩니다
- 세션 파일 위치:
playwright-sessions/naver-blog-session.json
세션 만료 시
세션이 만료되면 자동으로 재로그인을 시도합니다.
수동 세션 초기화
# 세션 파일 삭제
rm -rf playwright-sessions/naver-blog-session.json
문제 해결
1. 로그인 실패
증상: "Login failed" 에러 발생
해결 방법:
- 네이버 아이디/비밀번호 확인
- 네이버 로그인 보안 설정 확인 (캡차, 2단계 인증 등)
- Headless 모드를 false로 설정하여 브라우저 동작 확인
- 세션 파일 삭제 후 재시도
2. 브라우저 실행 실패
증상: "Failed to initialize Playwright" 에러
해결 방법:
# Playwright 브라우저 재설치
mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="install chromium"
3. 포스팅 실패
증상: 포스팅 URL이 반환되지 않음
해결 방법:
- Headless 모드를 false로 설정하여 UI 확인
- 네이버 블로그 에디터 구조 변경 여부 확인
- 로그 확인:
logs/distribution-service.log
4. 성능 이슈
브라우저 자동화는 리소스를 많이 사용하므로:
- Resilience4j Bulkhead 설정으로 동시 실행 제한 (현재 10개)
- Circuit Breaker로 반복 실패 방지
- 실패 시 자동 재시도 (최대 3회)
보안 고려사항
1. 비밀번호 관리
- 절대로 소스 코드에 비밀번호를 하드코딩하지 마세요
- 환경 변수 또는 시크릿 관리 서비스 사용
- Git에
.run/*.xml파일을 커밋하지 마세요 (.gitignore추가)
2. 세션 파일 보안
playwright-sessions/디렉토리를.gitignore에 추가- 서버 환경에서 파일 권한 설정 (chmod 600)
3. 네트워크 보안
- HTTPS만 사용
- 프록시 사용 시 안전한 프록시 설정
운영 환경 배포
Docker 환경
# Dockerfile에 Playwright 설치 추가
RUN apt-get update && apt-get install -y \
libnss3 \
libatk-bridge2.0-0 \
libdrm2 \
libxkbcommon0 \
libgbm1 \
libasound2
# Playwright 브라우저 설치
RUN mvn exec:java -e -D exec.mainClass=com.microsoft.playwright.CLI -D exec.args="install chromium"
Kubernetes 환경
apiVersion: v1
kind: Secret
metadata:
name: naver-blog-credentials
type: Opaque
stringData:
username: your_naver_id
password: your_password
blog-id: your_blog_id
---
apiVersion: apps/v1
kind: Deployment
spec:
template:
spec:
containers:
- name: distribution-service
env:
- name: NAVER_BLOG_USERNAME
valueFrom:
secretKeyRef:
name: naver-blog-credentials
key: username
- name: NAVER_BLOG_PASSWORD
valueFrom:
secretKeyRef:
name: naver-blog-credentials
key: password
- name: NAVER_BLOG_BLOG_ID
valueFrom:
secretKeyRef:
name: naver-blog-credentials
key: blog-id
- name: NAVER_BLOG_HEADLESS
value: "true"
제약사항
- 동시 실행 제한: Bulkhead 설정으로 최대 10개 동시 실행
- 실행 시간: 브라우저 자동화는 API 호출보다 느림 (평균 5-10초)
- 네이버 정책: 네이버 블로그 정책 변경 시 업데이트 필요
- UI 변경: 네이버 블로그 UI 변경 시 코드 수정 필요
모니터링
로그 확인
# 실시간 로그
tail -f logs/distribution-service.log
# 에러만 필터
grep ERROR logs/distribution-service.log
주요 로그 메시지
Initializing Playwright for Naver Blog: Playwright 초기화Starting Naver login process: 로그인 시작Naver login successful: 로그인 성공Post published successfully: 포스팅 성공Failed to post to Naver blog: 포스팅 실패
참고 자료
지원
문제 발생 시:
- 로그 파일 확인:
logs/distribution-service.log - Headless 모드를 false로 설정하여 브라우저 동작 확인
- GitHub Issue 등록 (로그 첨부)