반응형

전체 글 86

[데이터 중심 애플리케이션 설계] 3장

핵심 내용 로그 구조화 관점에서 파일에 추가와 오래된 파일의 삭제만 허용하고 한 번 쓰여진 파일은 절대 갱신하지 않는다. 비트캐스크, SS테이블, LSM 트리, 레벨 DB, 카산드라, HBase, 루씬 등이 이 그룹에 속한다. 임의 접근 쓰기를 체계적으로 디스크에 순차 쓰기로 바꾼다 하드드라이브와 SSD의 성능 특성에 맞춰 쓰기 처리량을 높이는 것이 가능하다 제자리 갱신 관점에서 덮어쓰기 할 수 있는 고정 크기 페이지의 셋으로 디스크를 다룬다. 이 관점에서 가장 큰 예가 B 트리다. B 트리는 모든 주요 관계형 데이터베이스와 많은 비정형 데이터베이스에서도 사용한다. 배운 내용 1. 정렬되어 있으면 적어도 두가지 값 사이에 있다는 것만으로도 이진 탐색이 가능해진다. 인덱스가 범위를 나타내는 페이지로 구성되..

독서 2023.11.13

[Spring Batch] Update documentation about serializable keys in the execution context

Issue Update documentation about serializable keys in the execution context · Issue #4457 · spring-projects/spring-batch The documentation section about the execution context should mention that non transient keys should be Serializable (otherwise a custom serializer should be used). Related-to: spring-projects/sprin... github.com PR Update documentation about serializable keys in the execution ..

오픈소스 2023.11.03

[Spring Data Commons] Add overload to ReactiveSortingRepository accepting a Limit parameter

Issue Add overload to ReactiveSortingRepository accepting a `Limit` parameter. · Issue #2923 · spring-projects/spring-data-commons Flux findAll(Sort sort, Limit limit); github.com PR Add overload to ReactiveSortingRepository accepting a Limit parameter. by hwan33 · Pull Request #2959 · spring-projects/spring Related issue: #2923 Motivation Flux findAll(Sort sort, Limit limit); It's good to add f..

오픈소스 2023.11.03

단위 테스트에서 Mockito 잘 활용하기

서론 단위 테스트는 두 가지 견해 고전파와 런던파로 구분할 수 있다. 고전파는 켄트 백의 테스트 주도 개발(TDD)으로 원론적으로 접근하는 방식 때문에 '고전'이라 한다. 런던파는 런던 프로그래밍 커뮤니티에서 시작되어, 목 추종자라고도 불린다. 아래 글에서는 위의 학파와는 상관없이 단순히 단위 테스트에서 mockito를 잘 활용하는 방법에 대해서만 설명할 예정이다. 단위 테스트의 관심사 controller 👇 (interface) service 👇 service implementation (복잡한 비지니스 규칙) 👇 (interface) repository 👇 repository implementation (외부 의존성) 위의 흐름에서 단위 테스트 자체는 인터페이스의 실제 구현에 전혀 관심이 없다. 왜 ..

개발 2023.09.22

Spring Boot 3.x 기반 actuator 설정 및 custom metrics 추가

Spring Boot Actuator http://localhost:8080/actuator/ 위 링크 접속시 아래처럼 각 항목별 상세 링크 정보를 알려준다 이러한 방식을 HATEOAS 방식이라고 한다 각각의 url은 endpoint라고 부른다 self -> http://127.0.0.1:8080/actuator health -> http://127.0.0.1:8080/actuator/health health-path -> http://127.0.0.1:8080/actuator/health/{*path} 의존성 추가 implementation 'org.springframework.boot:spring-boot-starter-actuator' 핵심 라이브러리인 micrometer-core를 ..

개발 2023.07.11

Feign Client 커스텀 하기

Spring boot 2.6.x 기준 포스팅입니다 Spring boot 3.0.x부터는 HttpClientFeignConfiguration 클래스가 사라진 것으로 보입니다. 따라서 아무 설정 하지 않은 경우와ApacheHttpClient로 변경에 대한 내용은 추후 살펴보겠습니다. 아무 설정 하지 않은 경우 특별한 설정을 하지 않는 이상 FeignAutoConfiguration에 의해 httpClient와 feignClient를 ApacheHttpClient로 등록한다. HttpClientFeignConfiguration 클래스의 connectionManager() -> httpClient() -> createClient() 순서로 CloseableHttpClient 가 디폴트로 생성된다. 이 과정에서 매..

개발 2023.07.05

[스터디 메모] 2 ~ 5장

enrichPerformance 메서드에서 shallow copy한 Performance 객체에 동적으로 play라는 필드를 추가해버리는데 자바에서는 어떻게 구현하셨는지 궁금합니다 (p.56) PerformanceVo 별도로 정의 Performance 클래스에 추가 데이터베이스 리팩토링 or 마이그레이션 시 얼마나 작은 단계로 나눠서 릴리스 하시는지 궁금합니다 (p.99) flyway 사용 DBA 검수 이후 주로 오전에 배포합니다. 락이 걸리거나 큰 작업의 경우에는 새벽에 배포합니다. DBA에게 요청합니다. 2주에 한번씩 주기적으로 한번에 배포합니다. 모든 상황에서 기능 추가와 리팩토링을 독립적으로 분리하여 커밋하기에는 너무 피곤해질 것 같은데.. 그럼 기능 추가를 진행하며 마음에 들지않는 코드여도 일단..

[스터디 메모] 1장

부정관사 사용하는 이유가 뭘까? (p.34) 자바 스크립트는 동적 타입 언어이기 때문에 타입을 변수명으로 쉽게 확인할 수 있게 된다 실제로 헝가리안 표기법을 사용하는 팀이 있다고 한다 playFor 함수는 단순히 인덱스를 통해 배열의 값을 가져오는 것 같은데, 함수 추출하는 의미가 무엇일까? (p.35) 1. 함수로 추출하는 이유는 변경점을 최소화하기 위해서 2. 추상화 레벨을 맞추기 위해서 (인덱스에 접근하는 것은 낮은 레벨이다) for 루프 한번이면 될 일을 for 루프 두번으로 돌리는 것이 성능에는 크게 상관이 없다 (p.39) 상관 있더라도 리팩토링과 성능 개선은 분리해서 접근하는 것이 맞다 실제 테스트 결과 O(n), O(4n)이 1.5~2배 정도 차이난다 컴파일러 성능이 많이 좋아졌기에 클린 ..

Mockito를 사용한 테스트에서의 OOM

상황 내가 만든 로직의 성능을 테스트하고자 연속적으로 호출하는 테스트 코드를 작성해봤다. 해당 로직에서는 레디스에 접근하는 경우가 있었기 때문에, Mock 객체를 활용해 실제 레디스에 접근하는 시간은 제외한 자바 코드의 성능만을 테스트 하고자 했다. 예시 코드는 아래와 같다. @MarsSpringBootTest @Slf4j class ServiceTest { private static final int CALL_STANDARD = 10_000_000; @Autowired private TestService testService; @Mock private Repository repository; @Test void run() { when(repository.find(xxx)).thenReturn(Optio..

트러블 슈팅 2023.01.03
반응형