분류 전체보기421 loki logback appender 란? loki logback appender란?opentelemetry logback appender는 https://opentelemetry.io/docs/zero-code/java/spring-boot-starter/out-of-the-box-instrumentation/ Open Source 재단에서 만들고 제공하는 라이브러리로 중앙 집중형태의 collector 만들때 사용한다고 언급하였다. 오늘 알아볼 loki logback appender 는 여기서 확인 할 수 있다.https://loki4j.github.io/loki-logback-appender/ Loki4j Logback · Pure Java Logback appender for Grafana LokiPure Java Logback append.. 2025. 9. 10. opentelemetry logback appender opentelemetry logback appender우리는 로그를 확인하기위해 System.out.print 명령어를 이용하여 로그를 확인하였다. 하지만 시간이 흐름에 따라 콘솔기록 뿐만 아니라 파일로 기록을 남기기 위해 common-log 부터 log4j 까지 그리고 지금은 logback, slf4j 을 사용한다.모놀리틱 환경에서 분산서비스(MSA) 환경에 접어 들면서 로그를 한곳에서 모아보거나 흩어져있는 로그들을 취합하고 추적하기 위한 기술들이 사용되게 되는데 그중에 한가지를 소개한다.opentelemetry-logback-appender 라는 모듈이다. 아직 정식버전은 아니고 -alpha 버전만 존재한다.“다운로드 링크” →https://mvnrepository.com/artifact/io.ope.. 2025. 9. 3. matric / trace micrometer, OTLP 라이브러리 설명 서버에서 트레이싱과 메트릭 수집을 하기 위해서는 micromiter를 사용하여 cpu, 메모리 http 요청(count) 에대한 매트리글 수집하고, otpl 라이브러리를 사용하여 grabal MDC tracd id , span id 등을 생성하고 관리 할 수. 있다.matric 수집micrometer-registry-otlp메트릭 전송도구로 OTLP 프로토콜을 사용한다.cpu, 메모리, http요청수 응답시간 등의 수치데이터를Prometheus 대신 otlp로 메트릭을 보내고 싶을때 사용한다.micrometer-registry-prometheus메트릭 전송도구로 Prometheus 포멧이다.위와 동일한 메트릭 수치데이터를 Prometheus 엔드포인트 (/actuator/prometheus)로 노출한다... 2025. 9. 3. zipkin , jaeger, grafana tempo 특징 모두 분산추적(트레킹)시스템이다. 각각이 모두 장단점을 가지고 있으며, 이에 대해 알아 보자. 1. Jaeger예거는 분산 추적 시스템으로 유명하며, 중대형시스템에서 자주 사용된다. 학습곡선이 높지만 설정할수 있는 기능들이 많고 데이터 보관 및 확장성에 용의 하다.OpenTracing 의 네이티브 구현으로 표준을 지원하는 프레임웍들과 쉽게 통합 할 수있다. (ex grafana 연동 등)저장소 고급기능Cassandra적응형 샘플링Elasticsearch추적집계 종속성 그래프 시각화중대형 시스템에 적합한 트레이싱 도구로 저장 및 처리시 많은 컴퓨팅 자원이 소모될 수 있으며, 복잡한 설정으로 학습곡선이 높다.2. Zipkin경량화된 트레킹시스템으로 보통 중소형 시스템에서 자주 채택하는 아키텍처로 사용된다... 2025. 7. 30. Observability & Open Telemetry 전파전략 전파 전략Open Tracing 의 전파 전략에 대해 알아보겠습니다. 오픈트레이싱에서 선택할수 있는 방법은 두가지가 있습니다. 이전 Brave모드와, W3C Trace Context 스팩입니다. W3C Trace Contexttraceparent: {version}-{trace-id}-{parent-id}-{trace-flags}traceparent (필수)트레이스 구조 표현versiontrace IDspan IDtrace flagesversion 2자리 현재 버전정보trace-id32자리전체 트레이스를 식별하는 IDparent-id16자리현재 요청의 상위 span Idtrace-flasgs2자리샘플링 정보 (01: 샘플링 OK, 00: 샘플링 NO )traceparent: 00-4bf92f3577b.. 2025. 7. 30. Observability & Opentelemetry 옵저버빌리티(관찰가능성)란 ?옵저버빌리티를 사용하면 다음과 같은 질문을 통해 외부에서 시스템을 이해 할 수있다.내부 동작 방식을 모른채 그시스템에 대한 질문 또한 새로운 문제 즉 “알수없는” 문제를 쉽게 해결하고 처리 할 수 있다. 또한 알수 없는 문제들에 있어 “왜 이런 일이 발생하는가?” 에대한 질문에 답을 하는데 도움이 된다. MoniteroringObservability접근 방식미리 정의된 지표 주심의 상태 이상 감시내부 상태 추론, 원인 파악 및 분석활용 데이터Metrics, 알림Metrics, Logs, Traces목표무엇이 문제인가? 에 대한 문제 감지 /알림왜 문제가 발생 하였는가? 에 대한 근본적인 원인 분석활용 범위/관점일부 시스템, 사후 대흥시스템 사전.사후 통합 분석 옵저버빌리티.. 2025. 7. 30. Next.js 환경별 빌드 dotenv Next.js 혹은 Node.js 에서 환경별로 빌드하는 방법은 두가지가 존재한다.Node 에서 build 시에 env 값의 우선순위는 env.production > env.development > env.local 형태로 바라보기 때문에 다음과 같이 build 시 해당 파일을 .env.local 로 변경하여 npm start 로 실행시 development, production 에 속한 ENV 값을 local로 하여 해당 파일을 읽어 실행 하도록 한다. "scripts": { "start": "react-scripts start", "build": "react-scripts build", "build:dev": "cp .env.development .env.local && react-.. 2025. 1. 22. Multi datasource, router datasource 멀티-테넌시란?멀티-테넌시는 소프트웨어 어플리케이션의 단일 이느턴스가 여러 고객에게 서비스를 제공하는 아키텍처 이다.아래 그림에서 보듯이 싱클 테넌시와 멀티테넌시는 확실하게 구분된다. 싱글테넌시의 경우 사용자 별로 어플리케이션과 Database 가 존재한다.멀티테넌시의 경우엔 하나의 어플리케이션에서 여러 테넌트(tenant,사용자)가 사용할 수 있도록 해준다.멀티테넌시를 구축하는 이유는 고객마다 새로운 시스템을 만들 필요가 없기 때문에 소프으웨어 개발과 유지보수 비용을 절약 할 수 있기때문에 경제 적이다.멀티테넌시를 구축하는 방법은 여러 방법이 있다. 인프라 적인 부분, 소스코드에서 분기 혹은 database 에서 분리등 여러 방법을 이용하여 테넌트 분리가 가능 하며 대표적으로 다음과 같이 구분 해볼 수.. 2025. 1. 9. tenant id 에 따른 datasource 분리 , 인터셉터 Client 에서 Header 값을 통해 Datasource 를 선택하기 위함. Flow (흐름도)Headertanent-id : poc----Headertanent-id : kakao-games Client 에서 정의된 Header 정보를 담아 보낸다.Interceptor 에서 정의된 ID 값 을 기준으로 Router 를 선택한다.LocalThread에 저장된 정보를 읽어와 DB 정보를 FIX 한다.Controller, Service, 를거쳐 Repository 에 도달 했을때 앞서 선택된 router 정보에 의해 datasource를 결정하고 사용한다. 2025. 1. 9. 이전 1 2 3 4 ··· 47 다음