전체 글 (35) 썸네일형 리스트형 WebClient를 이용한 외부 호출 관련 Metric 수집 서비스를 운영하다보면 내 서비스가 호출하는 API 호출량을 모니터링 하고 싶은 경우가 있다. 내 서비스가 외부 서비스 API를 너무 과하게 호출하고 있지는 않은지 점검할 수 있다. WebClient를 통한 외부 호출 모니터링Spring에서 외부 API를 호출하기 위해 대표적으로 RestTemplate과 WebClient를 제공한다. 만약 Spring에서 생성해준 Builder를 주입받아 RestTemplate, WebClient 객체를 만들었다면, 기본적으로 Metric이 수집된다. 즉, Grafana를 통해 모니터링 할 수 있다. ref : https://docs.spring.io/spring-boot/docs/2.1.7.RELEASE/reference/html/production-ready-metri.. Application Context Refresh 전에 로깅 설정하기 개발 중 Application Context가 Refresh 되기전 비정상 종료하면 내가 설정한 로그 파일이 적용되지 않는 이슈를 발견했고, 이 이슈를 해결한 과정을 공유한다. 배경기존 프로젝트에 새로운 Profile을 추가하는 과정에 Java 프로그램이 제대로 실행되지 않는 이슈 발생했다.원인은 Zookeeper 설정 누락으로 새로운 Profile에 대한 Zookeeper endpoint를 제대로 지정하지 않아 실패했다. 원인은 간단하지만, 로그가 내가 설정한데로 동작하지 않아 로그를 찾는데 오랜 시간이 걸렸다...그럼 왜 로그 설정이 내가 원하는데로 되지 않았을까? 로그 설정이 적용되지 않은 이유두괄식으로 이유만 먼저 말하면 application.yaml의 logging.config에 설정한 값은 A.. SimpleDateForat 동시성 이슈 SimpleDateFormat 객체를 사용하다 동시성 이슈를 만났다.이슈를 해결한 과정을 기록해 두려고 한다. 문제Jackson Library Custom Deserializer에서 SimpleDateFormat을 이용해 역직렬화 작업 수행 간헐적으로 역직렬화 실패하는 이슈 발생java.lang.NumberFormatException: For input string: ".206E206E22" at java.base/jdk.internal.math.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2054) at java.base/jdk.internal.math.FloatingDecimal.parseDouble(FloatingDecimal.java:11.. Spring Event UnderTheHood Spring을 이용해 개발하다보면, 모듈간 결합도를 낮추기 위해 Spring Event를 활용하는 케이스가 있다. Spring Event를 편리하게 사용하고 있다 문득 내부 동작 원리가 궁금해 코드를 살펴봤다. 이번글은 Spring Event 동작 방식에 대해 설명하는 글이다. 크게 2가지 동작의 원리를 살펴보겠다.1. @EventListener 애노테이션을 통한 Handler 등록 과정2. ApplicationEventPublisher를 이용해 Event를 발행할 때 Event가 Listener로 전송되는 과정 @EventListener 애노테이션을 통한 Handler 등록 과정FlowApplicationContext Refresh 과정에 EventListenerMethodProcessor 부터 @Ev.. [인프런 X VMware Tanzu] Spring Boot 밋업 with Josh Long 후기 좋은 기회로 Josh Long님이 Java21과 SpringBoot 3.x에 대해 소개해주는 밋업에 참여했다.깊이 있는 내용을 다루기엔 시간이 짧았지만, Java21과 SpringBoot 3.x에서 제공해주는 새로운 기능들과 이 기능들의 활용 방법에 대한 아이디어를 얻을 수 있었다. Java21의 DATA ORIENTED PROGRAMMIG 지원 요즘 인프라의 트랜드는 서비스를 작은 서버에 여러대에 올려 필요에 따라 scale out/in해 사용한다.작은 서버에 애플리케이션을 실행시키기 때문에 하나의 서비스가 하는 역할이 작아졌고, 다른 서비스들과 메시지를 주고 받을 일이 많아졌다. 그리고 이러한 상황에 DATA ORIENTED PROGRAMMING 방식을 사용하면 목적에 맞는 코드를 작성할 수 있다. .. Python 입문기 최근에 AI 모델을 직접 만지는 프로젝트에 참여할 기회가 있었다. 프로젝트는 Python을 이용는데, Java에 익숙한 나에겐 신선한 경험이었다. 위 프로젝트를 진행하면서 알게된 Python의 기본 지식을 나중을 위해 정리해 두려고 한다. 다른 언어들은 사용해 봤지만, Python은 처음 사용하신다면 한 번쯤 읽어보길 추천한다. 글에서는 Python 관련 2가지 개념을 설명한다.첫 번째는 Python 코드가 실제 동작하기까지의 과정이다. (개인적으로 실제 코드가 동작하는 과정을 알아야 개발하다 이슈를 만나도 쉽게 해결할 수 있는 것 같다.)두 번째는 Virtual Environment에 대해 설명하겠다. Python Code 실행 과정 Code Editior에 Python 코드를 작성하면 Python 코.. K8S CPU Requests와 Limits 의미 쿠버네티스를 이용해 서버를 배포하면, Pod 설정 파일에 cpu request와 limit 설정 값이 존재한다. 이 값들이 실제로 어떤 의미인지 궁금해 여러 글들을 찾아보다, 좋은 글을 발견해 공유차 남겨둔다. 자세한 내용은 첨부한 글을 참고하길 바란다. 글에 있는 핵심 내용만 간략하게 정리하겠다. K8S에서 Pod의 Container는 Worker 노드 관점에서 Cgroup로 관리되고, CFS를 이용해 Cgroup이 얼만큼의 리소스를 사용할지 결정된다. cpu request는 CFS가 Cgroup에게 CPU 리소스를 할당할 때, 얼만큼 할당할지의 기준으로 사용한다. 따라서 request 값이 클 수록 worker node에서 더 오랫동안 cpu를 점유할 수 있다. cpu limit은 CPU 사용량 제한.. Java 시간관련 객체 정리 들어가면서 이번 글에서는 Java에서 제공하는 시간과 관련된 Class를 정리한다. 자바 시간 객체 종류 Date public class Date implements java.io.Serializable, Cloneable, Comparable { ... private transient long fastTime; ... } The class {@code Date} represents a specific instant* in time, with millisecond precision. java.util 패키지에 있는 클래스다. 좀 더 쉽게 풀어쓰면 1970년 1월 1일 00:00:00 GMT를 기준으로 지금 몇 milisecond이 지났는지를 저장한다. (이런 개념을 epoch-seconds 라고 부른다... 이전 1 2 3 4 5 다음