[Spring Boot] MySQL Master/Slave 복제 설정과 Read/Write 자동 분기 처리 방법 정리
·
BackEnd/Spring & JPA
1. 시작하며사이드 프로젝트를 운영하면서 현재는 단일 데이터베이스만 사용 중이었습니다. 단순한 개인 프로젝트 수준이라면 큰 무리는 없겠지만, 운영 환경에서 안정성과 확장성을 확보하려면 최소한의 DB 이중화 구조는 반드시 필요하다는 생각이 들었습니다.특히, 현재 운영 중인 프로젝트는 전체 쿼리 중 약 80~90%가 읽기(Read) 작업으로 이루어져 있기 때문에, 읽기/쓰기 분리 구조를 미리 연습해보는 것만으로도 큰 도움이 되겠다는 판단이 들었습니다.물론 단일 DB로도 운영은 가능하지만, 실무에서는 장애 대응, 확장성, 성능 분산 등의 이유로 Master/Slave 구조(Master-Replica)를 도입하는 경우가 많습니다.이에 따라, MySQL Master/Slave Replication 구조를 설정하고..
[Database] 트랜잭션의 격리 수준 (Isolation Level)에 대해 완벽하게 이해하기
·
Database
1. 트랜잭션과 데이터 정합성 문제데이터베이스를 사용할 때 여러 개의 트랜잭션이 동시에 실행되면서 데이터 정합성 문제(Consistency Issue)가 발생할 수 있습니다.트랜잭션(Transaction)은 데이터베이스에서 하나의 논리적인 작업 단위로, 반드시 모든 작업이 성공해야 완료(Commit)되고, 하나라도 실패하면 전체가 롤백(Rollback)되어야 합니다.트랜잭션이 ACID 원칙을 준수해야 하는 이유도 바로 이러한 동시성 문제를 방지하기 위해서입니다.그 중에서도 Isolation(격리수준)은 여러 트랜잭션이 동시에 실행될 때 서로 영향을 미치지 않도록 독립적으로 동작하는 것을 의미합니다.만약 격리 수준을 적절히 설정하지 않으면, 동시성 문제(DIRTY READ, NON-REPEATABLE RE..
[Web] RESTful API란? REST API와의 차이점과 구현 원칙 정리
·
Computer Science/Web
1. REST API와 RESTful API 비교1.1 REST API란?REST API는 REST(Representational State Transfer) 아키텍처 스타일을 따르는 API(Application Programming Interface)를 의미합니다. REST는 웹에서 리소스(데이터)를 효율적으로 전송하는 방식으로, 주로 HTTP를 기반으로 합니다. REST API는 클라이언트와 서버 간의 통신을 효율적으로 설계하고 리소스(데이터)를 HTTP 메서드를 통해 전달하는 방식입니다.REST API는 REST(Representational State Transfer) 아키텍처 스타일을 따르는 API(Application Programming Interface)를 의미합니다.REST는 웹에서 리소..
[React + Nginx] Nginx에서 React(Vite) 배포 시 캐싱 문제 해결 및 최신 화면 자동 반영 적용
·
DevOps
1. 시작하며회사에서 프로젝트를 진행하면서 프론트엔드 팀원분들이 패치 후에도 브라우저가 이전 버전을 유지하는 문제로 어려움을 겪고 있었습니다.운영 서버에 배포할 때마다 강력 새로고침(Ctrl + Shift + R)을 해야만 최신 화면이 반영되는 상황이었습니다.이는 사용자 경험(UX)에도 영향을 미치고, 운영 과정에서도 번거로움을 유발했습니다.1.1 문제 상황패치 후에도 브라우저가 이전 버전의 화면을 유지함Nginx를 재시작하지 않으면 새로운 화면이 반영되지 않음사용자가 강제 새로고침을 하지 않으면 변경 사항이 보이지 않음배포 후 매번 "새로고침 해주세요!"라고 안내하는 번거로움이 존재운영 서버에 배포할 때마다 개발자나 운영팀이 직접 강력 새로고침을 해줘야 하는 상황이 반복되었고, 이는 근본적으로 Ngin..
[Database] SQL 성능 최적화: 빠른 쿼리를 위한 7가지 체크리스트
·
Database
SQL 성능 최적화는 데이터베이스의 부하를 줄이고 빠른 응답 속도를 유지하는 핵심 기술입니다. 잘못 작성된 SQL 쿼리는 Full Table Scan(전체 테이블 검색)을 유발하며, 이는 성능 저하의 주요 원인이 됩니다.이 글에서는 SQL 쿼리 최적화를 위한 7가지 핵심 체크리스트를 자세히 살펴보겠습니다. 각 항목마다 비효율적인 예제와 최적화된 쿼리 예제를 함께 제공하여, 실제 개발 환경에서 바로 적용할 수 있도록 구성했습니다.1. SELECT * 대신 필요한 컬럼만 조회하기1.1 문제점: SELECT * 사용 시 불필요한 데이터 조회SELECT *를 사용하면 모든 컬럼을 조회하게 되는데, 이는 네트워크 트래픽 증가, 메모리 사용량 증가, 그리고 쿼리 실행 속도 저하로 이어집니다.📌 비효율적인 쿼리--..
[JAVA] equals()와 hashCode() 완벽 정리
·
BackEnd/JAVA
자바에서 객체의 동등성 검사는 매우 중요한 개념이며, 이를 위해 equals()와 hashCode() 메서드를 올바르게 이해하고 구현하는 것이 필수적입니다.equals() : 두 객체가 논리적으로 같은지 비교하는 메서드hashCode() : 객체를 빠르게 찾을 수 있도록 해시값(정수)를 반환하는 메서드이 글에서는 equals()와 hashCode()의 개념, 원칙, 구현 방법, 컬렉션과의 관계, 그리고 실무에서의 활용까지 완벽하게 정리해보겠습니다.1. eqauls()와 hashCode()란?1.1 equals()란?equals()는 두 객체가 논리적으로 같은지 판단하는 메서드입니다.Object 클래스의 기본 equals()는 == 연산자와 동일하게 참조(주소) 비교를 수행합니다.따라서 equals()를 ..
[JAVA] 익명 클래스 (Anonymous Class) 정리
·
BackEnd/JAVA
자바에서는 클래스를 선언하고 객체를 생성하는 것이 일반적이지만, 일회성으로만 사용할 객체라면 굳이 클래스를 따로 선언하는 것은 불필요할 수 있습니다.이때 익명 클래스(Anonymous Class)를 사용하면 클래스를 선언하지 않고도 객체를 즉시 생성할 수 있어 코드를 간결하게 유지하고 유지보수를 쉽게 만들 수 있습니다.이번 글에서는 익명 클래스의 개념, 특징, 활용 방법, 주의할 점, 그리고 람다 표현식과의 차이점까지 완벽하게 정리해보겠습니다.1. 익명 클래스 (Anonymous Class)란?익명 클래스(Anonymous Class)란 이름이 없는 내부 클래스로, 특정 인터페이스를 구현하거나 클래스를 상속하여 일회성으로 사용할 객체를 즉석에서 생성하는 데 사용됩니다.일반적으로 클래스를 선언하고 객체를 ..
[Windows Server] 윈도우 서버에서 Nginx 로그 파일을 일자별로 관리하는 방법 (Feat. Power Shell, Windows Task Scheduler)
·
DevOps
1. 시작하며회사에서 진행한 프로젝트에서 Nginx 로그 파일을 관리할 필요가 있었습니다. 특히, 클라이언트 요청 값들을 검토해야 하는 상황이었는데, 로그 파일(access.log, error.log)이 지나치게 커져 있어 파일을 열어보는 것조차 어려운 상태였습니다.문제 상황은 다음과 같았습니다.access.log 파일이 6GB 이상 쌓여 있어 텍스트 에디터로 열 수 없음로그 파일이 커질수록 Nginx의 성능 저하 및 디스크 용량 증가 문제 발생오래된 로그 파일이 자동으로 삭제되지 않아 불필요한 용량 차지이를 해결하기 위해 Nginx 로그 파일을 일자별로 관리하는 방식이 필요했습니다.이번 글에서는 Windows 환경에서 로그 파일을 자동으로 일자별로 관리하고, 불필요한 오래된 로그를 자동으로 삭제하는 방..
[Web] URI, URL, URN의 차이점 정리
·
Computer Science
1. URI (Uniform Resource Identifier, 통합 자원 식별자)1.1 URI란?URI(Uniform Resource Identifier)는 인터넷 상에서 특정한 자원을 식별하는 문자열입니다.즉, 웹에 존재하는 리소스(웹 페이지, 이미지, 동영상 등)를 고유하게 식별하는 역할을 합니다.1) URI의 역할인터넷의 모든 자원을 유일하게 식별하는 기능을 합니다.자원의 위치(URL) 또는 이름(URN)을 포함할 수 있습니다.URI는 URL과 URN을 포함하는 상위 개념입니다.2) URI의 포함 관계URI = URL + URN즉, 모든 URL과 URN은 URI의 일부분이며, URI는 포괄적인 개념입니다.3) URI 예시2. URL (Uniform Resource Locator, 통합 자원 지시..
[JAVA] Lombok의 @UtilityClass 어노테이션 정리
·
BackEnd/JAVA
자바를 개발하다 보면 Math, Collections 같은 유틸리티 클래스를 만들 일이 많습니다. 일반적으로 유틸리티 클래스는 정적(static) 메서드만 포함하며, 객체로 생성할 필요가 없습니다.Lombok에서는 이러한 유틸리티 클래스를 간편하게 정의할 수 있도록 @UtilityClass 어노테이션을 제공하며, 이를 통해 자동으로 인스턴스 생성을 막고 모든 멤버를 static으로 변환할 수 있습니다.이번 포스팅에서는 @UtilityClass의 개념과 사용법, 컴파일 후 코드 변환 과정, 그리고 유틸리티 클래스 설계 시 고려해야 할 점들을 정리해보겠습니다.1. @UtilityClass란?@UtilityClass는 Lombok v1.16.2에서 도입된 어노테이션으로, 객체 생성이 불필요한 유틸리티 클래스를..