HTTP 200 OK

Memento mori & Carpe diem

분류 전체보기 51

글또 9기를 지원하며 - 삶의지도 작성

삶의 지도 글또를 지원하면서 그동안의 삶을 되돌아보며 삶의 지도를 작성해 볼 수 있는 좋은 기회를 얻은 것 같습니다. 혼자서는 생각하지 못했을 일입니다. 글또를 운영하시는 분들과 글또를 알게 해 주신 이름 모를 블로거분에게 감사합니다. 꿈이 없던 지난 날 어렸을 적에는 꿈 없이 흘러가는 대로 살아왔습니다. 관심이 가는 일은 많아서 이것저것 여러 가지를 경험해 봤지만 무엇이든 금방 질리고 뒷심이 부족했습니다. 별 다른 꿈이 없었기에 부모님이 추천하신 과에 진학했고 돈이 부족하면 아르바이트를 했으며 공부도 하고 놀기도 하면서 정처 없이 시간을 보냈습니다. 하지만 마음 한편으로는 '내가 하고 싶은 일이 무엇일까' 하며 꿈에 대한 갈망을 가슴속에 품고 살았습니다. 무기력하게 살고 싶지 않았기에 꿈을 찾고자 다방..

활동 2023.11.08

Connection Pool 테스트와 고찰(2)

1. jdbc yml 설정 1) connectionTimeout (default : 30000 (30 seconds)) 클라이언트가 Pool에 Connection을 요청하는데 기다리는 최대시간을 설정 즉 db 서버에 연결할 때까지의 연결 대기 시간, 최대시간이 지나면 ConnectionTimeoutException이 throw 됩니다. 이 경우 connection-timeout 값을 늘려주거나, maximum-pool-size를 늘려줘야 합니다. 2) maximunPoolSize (default : 10) Pool에 보관가능한 최대 Connection 개수 설정 3) minimumIdle (default : maximumPoolSize와 동일) Pool에서 보관가능한 최소 Connection 개수 설정 ..

CS 2023.11.07

Connection Pool 테스트와 고찰(1)

개요 jdbc와 r2dbc Connection Pool에 대한 고찰과 어떠한 경우에 무엇을 선택해야 할지에 대한 고민을 담은 글입니다. 예전 글에서도 Connection Pool을 정리한 적(Connection Pool이란?)이 있었기 때문에 개념과 사용이유만 짚고 가겠습니다. 직접 구현해본 경험은 없었으므로 간단한 CRUD 예제 프로젝트로 학습했던 내용을 정리했습니다. connection pool 개념 웹 컨테이너(WAS)가 실행되면서 DB와 미리 연결을 해놓은 객체들을 Pool에 저장해 둔다. 이후 클라이언트 요청이 오면 Connection을 빌려주고, 처리가 끝나면 다시 Connection을 반납받아 Pool에 저장하는 방식 사용이유 db에 직접 연결해서 처리하는 경우 드라이버를 불러오고 Conne..

CS 2023.11.07

Cold Stream vs Hot Stream 이란?

Coroutine Cold Stream vs Hot Stream 코루틴에서 Scope와 몇 가지 연산자 등의 학습을 거쳐 flow와 channel이라는 것을 학습하게 되었는데 이 2개의 정확한 차이점은 무엇일까? stream은 정확히 무엇인가?.. 둘 다 무언가 값을 방출하는 것까지는 알겠는데 말이다. 여러 포스팅을 살펴보면 flow는 cold 스트림이고 channel 은 hot 스트림이라고 말한다. 그렇다면 여기서 말하는 스트림이라는 것은 대체 뭘까? flow 와 channel에 대해서 잘 이해하기 위해서는 이 “stream”이라는 것부터 알아야 될 듯해 작성하게 되었습니다. 1. Stream 우리는 hot, cold stream을 정의하는데 많은 혼란을 겪는다. 우리는 Flow는 Cold Stream..

CS 2023.10.31

[Kotlin] Result란?

Result란? Result는 동작이 성공하든 실패하든 동작의 결과를 캡슐화하여 나중에 처리할 수 있도록 하는 것이 목적입니다. Result 클래스는 runCatching 함수의 반환형이며 코루틴에서 에러 처리를 할 때 권장하는 방식이기도 합니다. runCatching 블록 안에서 성공/실패 여부가 캡슐화된 Result 형태로 리턴합니다.(Js의 Promise와 유사) - Result 클래스 멤버 isSuccess & isFailure 블록의 실행이 성공하면 (블록내에서 예외처리가 발생하지 않았을때) isSuccess 변수를 확인하여 알 수 있습니다. 역으로 블록의 실행이 실패했다면 isFailure 변수를 통해 확인 할 수 있습니다. if (colorName.isSuccess) { //성공시 호출 } ..

Kotlin 2023.09.12

[Kotlin] Error Handling

kotlin Error Handle을 하기 전에 어떠한 상황에서 에러 상황을 처리할지 정해야 한다. Type-safe Error Handling → Either Type Either Type은 Left && Right에 특정 value가 들어갔을때 미리 정의한 type과 일치하지 않는다면 .left() && .right() 를 사용해 success/fail을 커스텀할 수 있다. sealed class Either data class Left(val value: L): Either() / error data class Right(val value: R): Either() // success Sealed class는 하나의 type value를 사용하는 제한적인 상황일때 다양한 기능을 해당 value로 구현..

Kotlin 2023.08.26

API 헬스체크

헬스체크란? 서비스의 고가용성(HA, High Availability), 고성능을 위한 부하 분산 등의 이유로 우리는 서버의 이중화(혹은 그 이상)를 하고, 앞에서 어떤 서버로 요청을 보낼지 라우팅 역할을 하는 로드 밸런서를 둔다. 로드 밸런서는 부하를 적절히 분산하여 구축된 여러 서버중 한대에게 클라이언트의 요청을 보낸다. 하지만 요청을 한 서버가 서비스 불가상태라거나 소스코드를 로딩하고 있을 경우에는 서버로 요청을 보내면 안된다. → (장애 유발과 더불어 부하를 더 증가시키기 때문이다) 때문에 로드 밸런서에서는 각 서버의 헬스 체크 API를 호출해서 해당 서버가 현재 서비스 가능한 상태인지 아닌지 주기적으로 체크한다. 즉 헬스 체크는 정상적으로 서비스가 가능한 서버에만 트래픽을 보내서 서비스의 고가용..

CS 2023.08.17

Redis 정의 및 사용법 && Docker 배포시 이슈

Redis란? Key, Value 구조의 비정형 데이터를 저장하고 관리하기 위한 오픈 소스 기반의 비관계형 데이터 베이스 관리 시스템 (DBMS)입니다. 데이터베이스, 캐시, 메세지 브로커로 사용되며 인메모리 데이터 구조를 가진 저장소입니다. db-engines.com 에서 key, value 저장소 중 가장 순위가 높습니다. Redis는 Memcached와 비슷한 캐시 시스템으로서 동일한 기능을 제공하면서 영속성, 다양한 데이터 구조와 같은 부가적인 기능을 지원합니다. Redis는 Inmemory DataBase(빠르다)로서 모든 데이터를 메모리에 저장하고 조회합니다. DBMS를 이용한다면 DB에 데이터를 저장하고 저장된 데이터를 정렬하여 다시 읽어오는 과정은 디스크에 직접 접근을 해야하기 때문에 시간..

Redis 2023.07.21

Run Catching

Run Catching란? runCatching 은 try-catch 를 대체할 수 있는 코틀린의 문법이다. try-catch 문은 실패시의 핸들링을 처리할 수 있었다면, runCatching 은 성공시, 실패시 둘 다 처리할 수 있다. 기본 문법 runCatching { } : 중괄호 안에 try 하고자 하는 구문을 작성 onSuccess { } : 위 runCatch 구문이 성공시 매핑할 구문을 작성. it 은 위 구문의 결과. onFailure { } : 위 runCatch 구문이 실패시 매핑할 구문을 작성. it 은 위 구문에서 던진 Throwable 객체. also { } : 기존 try-catch-finally 에서 finally 에서 작성하던 구문을 작성할 수 있음. 복잡한 상황 map { ..

Kotlin 2023.03.01

Redis를 k8s에 업로드할때 경험한 이슈들

개요 1. Redis를 findByUserId와 같은 형식으로 검색을 하고 싶어 @Indexed 어노테이션을 활용해 Entity class에 선언해두었다. @RedisHash("test", timeToLive = 86400) class TemporaryGiftEntity( @Indexed val id: String = UUID.randomUUID().toString(), @Indexed val purchaseId: String, val orderName: String, ... ) 위와 같이 설정을 해놓는다면 Redis에 저장될때 id와 purchaseId가 각각 key값으로 저장되기 때문에 기존의 RDBMS 검색조건들과 같이 findByIdAndPurchaseId 와 형식으로 검색조건을 지정할 수 있다...

Redis 2023.01.30