TIL, WIL 95

03. 26 TIL : 도커의 편리함 깨닫기

쉘 스크립트를 사용해 배포하는 과정에서 온갖 시행착오를 겪었다. 너무 불편하고 신경쓸게 한 두개가 아니더라. 1) 리눅스에서 매번 권한설정하기 : sudo 지옥 2) VPC마다 다른 환경과 경로에 맞춰 설정해야 한다(그나마 단일 VPC 환경에서 작업해서 이 정도지, 여러 개로 늘리는 순간 개 헬일듯) 3) 실행 명령어에 환경 변수 설정이 빠졌는지를 매번 확인해야함-> 도커는 도커파일 또는 compose.yaml에 적어두면 신경쓸 필요가 없다 4) 모든 실행 환경에 필요한 언어 등을 직접 설치해야함 : 말해 뭐해, 최악 도커의 단점은..이미지의 용량이 크다는 것?러닝 커브가 좀 있다는 것 정도인 것 같다. 정말 빡센 경험이다.그래도 이런 경험을 해야하는 이유가 있다. 왜 좋다고 하는지를 몸소 깨달을 수 ..

TIL, WIL/TIL📘 2026.03.27

10.21 TIL : SQL 필터를 통한 데이터 정제

DB에서 varchar로 저장된 json String에 대해 한글인 경우의 데이터를 추출해야 했다. 다만, 한글이어도 상관없는 키와 한글 데이터가 같이 섞여있기 때문에, 이를 제외하는 것이 중요했다 완성된 쿼리 :WITH W1 AS ( -- 1. 본 테이블에서 한글이 포함된 모든 데이터 조회 SELECT sequence, content FROM board b WHERE b.content RLIKE '[가-힣]'),W2 AS ( SELECT sequence, REGEXP_SUBSTR( b.content -- 패턴: "key":" 뒤에 오며, 한글을 포함하고, 닫는 따옴표 직전까지의 내용을..

TIL, WIL/TIL📘 2025.10.22

09. 25 TIL : Gson 라이브러리의 JsonObject 객체 활용 시 주의할 점

0. 문제 상황-> JsonObject에서 String인 값을 toString() 메서드를 활용해 값을 참조했지만, 왜인지 \"A\" 의 형태로 문자열 안에 따옴표까지 추가된 형태로 데이터를 반환하고 있었다 1. 공부한 내용JsonObject.get(memberName).toString() 메서드를 활용할 때 주의할 사항 가장 기본인 Object의 toString() 메서드는public String toString() { return getClass().getName() + "@" + Integer.toHexString(hashCode());}로직을 가지고 있다 이 로직을 통해 호출할 경우, 해당 객체의 "주소"를 문자열로 반환받을 수 있다 이와 다르게 JsonObject의 경우, 상위 객체인 Js..

TIL, WIL/TIL📘 2025.09.25

07. 03 TIL : @Configuration 클래스

@Contiguration 의 역할에 대해 조금 착각한 부분을 적어본다 해당 클래스는 스프링 빈 컨테이너에 다른 컴포넌트들과 마찬가지로 @Bean으로 등록된 클래스로, 스프링에 의해 의존성 관리 및 라이프 사이클 관리가 이루어지는 클래스 컴포넌트의 한 종류에 속한다 나는 유틸리티 클래스(흔히 ~Util.java로 네이밍하는 클래스)와 혼동해 설정 클래스에 의존성 주입이나 다른 라이프 사이클 등을 적용하면 안될 것으로 혼동했다 하지만 그럴 필요 없이, 유틸리티 클래스는정적 메서드의 집합으로, 어디서나 재사용이 가능하고 스프링의 관리를 받지 않는 클래스를 의미한다 이미 @Configuration을 붙임으로, 스프링의 관리를 받는 설정 클래스는 유틸리티 클래스가 아닌 것이다 그렇기 때문에설정 클래스에 의존성 ..

TIL, WIL/TIL📘 2025.07.03

04. 29 TIL : SQL 쿼리에서 CASE 문의 중복 사용

쿼리문을 작성하다가, 공통 조건 A가 있고, 분기점이 2개 이상인 CASE 문을 작성할 떄 가독성 및 속도 향상을 위해 공통 조건을 하나로 사용하려고 한다 -> 기존SELECT CASE WHEN 공통조건 A AND 분기점 B THEN C, WHEN 공통조건 A AND 분기점 D THEN E END...-> 개선안 : CASE 문의 중복 사용SELECT CASE WHEN 공통조건 A THEN CASE WHEN 분기점 B THEN C, WHEN 분기점 D THEN E END END...이 방식으로 개선이 가능하다

TIL, WIL/TIL📘 2025.04.29

04. 06 TIL : 인터넷/ 전송 계층(IP, TCP, UDP)

IP 프로토콜- 지정한 IP 주소에 데이터를 패킷 단위로 전달한다 IP 프로토콜의 단점- 패킷을 받을 대상이 없거나 서비스 불능 상태여도 패킷을 전송할 수 있다- 패킷이 중간에 사라져도 송신 클라이언트에서 그 손실 여부를 확인할 방법이 없다- 패킷을 보낸 순서를 보장하지 않는다(데이터의 순서가 보장되지 않는다)- 같은 IP를 사용하는 서버 내 애플리케이션에 대한 구분이 어렵다 IP 프로토콜의 단점을 보완한 프로토콜 : TCP/UDP*cf) TCP/IP 프로토콜 (OSI 7계층과 비교 가능)데이터를 주고받기 위한 규칙과 절차를 정의하며, TCP/IP 프로토콜을 중심으로 설계되었다.1) 응용 계층사용자와 직접 상호작용하는 계층으로 데이터 형식 변환, 암호화 사용자 인터페이스 등 제공 : HTTP, FTP, ..

TIL, WIL/TIL📘 2025.04.06

03. 07 TIL : 카프카 세팅 및 실행, 테스트

스프링 카프카 실행하기 1. 아파치 제공 카프카 다운로드 및 압축풀기 2. 압축 푼 폴더로 이동해 2-1) Zookeeper 실행 ~ 기본포트 : 2181bin>zookeeper-server-start.sh config/zookeeper.properties  2-2) Kafka 서버 실행 ~ 기본포트 : 9092bin>zookeeper-server-start.sh config/server.properties (config/server.properties에서 설정 변경 가능 (예: listeners=PLAINTEXT://localhost:9092) 3. 토픽(데이터 관리 단위) 생성 ex) 채팅시스템용 토픽 : bin/kafka-topics.sh --create --topic chat-messages --..

TIL, WIL/TIL📘 2025.03.07

02. 28 TIL : Statc 상태 값 선언(직접 참조) vs RDB 데이터 쿼리를 통한 조회

요즘 실무 중 해당 트레이드 오프에 대한 고민을 많이 하게 된다 Staic으로 설정하는 경우와 이를 DB에서 관리하는 경우의 트레이드 오프에 대한 간단한 정리 1) Static (또는 Enum을 통한 코드 직접 참조 방식) : 개발 편의성 측면에서 선택장점- DB 호출을 줄일 수 있다- DB 접근 실패할 경우에도 로직에 문제가 생기지 않는다- IDE에서 바로 추적 가능 가장 핵심이 직접 참조가 불가능하다는 점인 듯 하다.해당 참조 방식을 통해 상태 값에 대해 컴파일 시점에서 값의 타입을 점검할 수 있고,해당 데이터를 DB에서 관리하는 경우, 리팩토링 시 값 조회를 위해 IDE가 아닌 DB 프로그램(별도로 나눠서 실행하고 있는 경우)을 실행해서 조회해야 한다 2) DB 관리 : 유지보수 측면에서 선택장점..

TIL, WIL/TIL📘 2025.02.28

02. 26 TIL : Collectors.groupingBy() 외 ~ List<Object> list를 특정 요소로 mapping

list list 안의 요소를 분류할 때 일반적으로 stearm().fileter() 방법을 많이 사용한다 하지만 이 방법으론 필터에 해당하는 요소가 있는 리스트를 발라내는 것밖에 할 수 없다. 특정 요소의 값을 기준으로 전체 리스트를 분류하고 싶은 경우,strream().collect(Collectors.groupingBy(Object:getField)); 를 사용 가능하다 이 방식을 통해 하나의 Field로 분류된 Map> 타입인 map이 생성된다. 이제 리스트 별로 분류된 인스턴스에 서로 다른 작업이 가능해진다 일반적으로 이 방법을 많이 사용하며, GPT가 추천해주는 다른 방법으로는, 1) 리스트가 아닌 다른 자료구조에 분류 Map> groupedSetMap = stream() .collect..

TIL, WIL/TIL📘 2025.02.26