-
Notifications
You must be signed in to change notification settings - Fork 8
프론트엔드 모니터링 및 디버깅 환경 구축
MYONG JAEWI edited this page Aug 9, 2024
·
3 revisions
- 더 안정적인 서비스를 운영하기 위해서
- 어떤 에러가 발생하고 있는지 수집, 추적하여 해결하기 위해서
- 다양한 사용자에게 발생하는 에러를 수집, 데이터화 하기 위해서
- 배포 환경에서 QA할 때 디버깅을 용이하게 하기 위해서
-
Sentry
- Sentry 선정 이유
- 실제 사용자의 행동을 기록하고 재현할 수 있기 때문
- 대시보드와 리포트를 통해 오류 추이와 영향도를 실시간으로 확인할 수 있기 때문
- 소스맵 설정을 통해 에러가 어디에서 발생했는지 추적 가능하기 때문
- 라벨링, Priority 설정할 수 있고, 슬랙 알람을 연동할 수 있기 때문
- Sentry 적용
- env 라벨링으로 development, production 설정
- 단, dev-server에서는 Sentry로 전송 안되도록 설정
- 소스맵 적용하여 에러난 위치의 소스 코드 확인 가능하도록 설정
- Sentry의 ErrorBoundary 적용
- Slack 연동(issue별, event 10회)
- 이외에 Tag, context 적용 아직 안함
- 실제 사용자들이 우리 서비스를 어떻게 얼마나 이용하고있는지 파악하기 위해서
- 새로운 기능을 개발하거나 개발한 기능에 대해 정량적인 데이터를 쌓기 위해서
- 팀 내부 의사결정을 위한 정량적인 근거 자료로 사용하기 위해서
-
GA(Google Analytics)
- GA 선정 이유
- 사용자 행동 패턴, 유입 경로, 전환율 등을 심도 있게 분석할 수 있기 때문
- 실시간 보고서, 맞춤 대시보드, 세그먼트 분석 등 다양한 분석 기능을 제공하기 때문
- 설정이 간단하고, 무료버전에서도 충분하고 다양한 기능을 제공하기 때문
- GA(Google Analytics) 적용
- 시간 경과에 따른 페이지 경로 및 화면 클래스별 조회수 확인
- 스크롤 이벤트는 추적 X
- 추후 유의미한 데이터 수집을 위해 커스터마이징 할 예정
- 추적할 데이터
- 코드 템플릿 업로드 수
- 템플릿 상세페이지 조회 수
- 스니펫 복사 버튼 클릭 수
- 재방문 수
- 추적할 데이터
- 백엔드 코드 컨벤션
- 백엔드 기술 스택 및 선정 이유
- 각종 인스턴스 설정 파일 및 구성 위치 가이드
- ERD
- 백엔드 CI CD 동작 프로세스
- 로컬 DB 환경 설정
- 백엔드 로깅 전략
- 백엔드 로그 모니터링 구성도
- 스프링 메트릭 모니터링 구성도
- Flyway 로 스키마 관리
- 코드잽 서버 구성도
- Git Submodule 사용 메뉴얼
- 프론트엔드 코드 컨벤션
- 프론트엔드 기술 스택 및 선정 이유
- 프론트엔드 서비스 타겟 환경 및 브라우저 지원 범위 선정
- 프론트엔드 모니터링 및 디버깅 환경 구축
- 프론트엔드 테스트 목록
- 프론트엔드 라이브러리 기술 검토
- 프론트엔드 개발서버, 운영서버 빌드 및 배포 환경 구분
- 목표했던 타겟 환경과 디바이스에서 서비스 핵심 기능 동작 확인
- 프론트엔드 접근성 개선 보고서
- EC2 로그 확인 방법
- VSCode를 통한 EC2 인스턴스 SSH 연결 방법
- 터미널을 통한 EC2 인스턴스 SSH 연결 방법
- NGINX 설정 파일 접근 및 적용 방법
- DB 접속 및 백업 방법
- [QA] 배포 전 체크리스트
- CI 파이프라인 구축
- CD 파이프라인 구축
- 백엔드 CI CD 트러블슈팅
- Lombok Annotation Processor 의존성을 추가한 이유
- 2차 스프린트 기준 ERD
- DTO 검증하기
- ProblemDetail
- Fork된 레포지토리 PR에서 CI Secrets 접근 문제 해결
- AWS CloudWatch 모니터링
- 스프링 메트릭 모니터링 구축 방법
- 로깅과 Logback에 대해 알아보아요.
- Logback MDC로 쉽게 요청 추적하기 (+ Grafana로 추적 더더 쉽게!)
- 백엔드 CD 파이프라인 Ver.2
- 요청, 응답 로그에 correlationId 를 추가하자!
- 3차 스프린트 기준 ERD
- 더미데이터 생성하고 실행하기
- 쿼리 성능 개선 결과
- 테이블별 인덱스 설정 목록
- 사용자 증가 시 발생할 수 있는 문제 상황과 개선 방안
- k6를 사용한 서버 부하 테스트
- 6차 스프린트 기준 ERD
- TestExecutionListenr 간의 충돌 문제에 대해 알아보아요
- Query Performance Improvement Results
- 테스트 전략 및 CI 설정
- CI CD 구조
- 배포 전, 로컬에서 로그인 기능 포함 테스트해보는 법
- stylelint 적용기
- 내 작업 브랜치 중간에 Merge된 동료의 작업물을 넣고 싶다면 pull vs rebase
- [TS] Webpack config
- [TS] Webpack 환경에서 MSW v2 이슈
- [TS] webpack에서 react‐router‐dom 적용 안됨