일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- exception
- request
- 관점지향프로그래밍
- 트랜잭션
- OOP
- 자바
- response
- aspect
- proxy pattern
- MYSQL
- RestControllerAdvice
- 스프링 시큐리티
- 스프링
- network
- 객체지향프로그래밍
- 인터셉터
- spring boot
- mybatis
- http
- Redis
- Filter
- SQL
- java
- 디자인패턴
- Spring Security
- Interceptor
- git
- Spring
- 스프링부트
- aop
- Today
- Total
목록Spring (32)
장쫄깃 기술블로그
분산락(Distributed Lock)의 필요성분산락(Distributed Lock)은 분산 시스템에서 여러 노드 또는 프로세스가 동시에 공유 자원에 접근하려 할 때, 충돌을 방지하고 자원의 일관성을 유지하기 위해 사용하는 기술이다. 이를 통해 여러 컴퓨터 또는 서버가 동시에 동일한 자원에 접근할 때 발생할 수 있는 문제를 해결할 수 있다. Redis는 기본적으로 싱글 스레드로 동작하므로, 단일 Redis 노드를 사용해도 동시성 문제는 발생하지 않는다. 따라서 리소스에 값을 설정하여, 값이 설정된 경우에는 다른 클라이언트의 접근을 차단할 수 있다. 필자는 분산 환경에서 선착순 신청 기능을 개발하면서, 처음에는 DB에 직접 락을 거는 비관적 락을 사용했다. 그러나 Deadlock이 자주 발생하자, 분산락으..
멱등성(Idempotent)이란?첫 번째 수행을 한 뒤 여러 차례 적용해도 결과를 변경시키지 않는 작업 또는 기능의 속성 멱등한 작업이란, 한 번 수행하든 여러 번 수행하든 결과가 동일한 작업을 의미한다. 멱등성이 보장되면 메소드가 여러 번 실행되어도 결과가 동일하기 때문에 안전하게 사용할 수 있다. 반면, 멱등성이 보장되지 않으면 동일한 요청을 중복해서 실행할 위험이 있다. 예를 들어, 동일한 등록 요청을 중복해서 실행한다면 중복되는 여러 개의 데이터가 생성될 수 있다. HTTP 메소드의 멱등성HTTP 메소드에도 멱등성이 있다. 메소드멱등성GETOPOSTXPUTOPATCHXDELEETEOHEADOOPTIONSOTRACEOCONNECTX GET, PUT은 리소스를 조회하거나 대체하는 메소드이기 때문에..
들어가며Spring Security 6.1부터 기존에 사용하던 and()와 non-Lambda DSL Method가 Deprecated 되고, 필수적으로 Lambda DSL을 사용하도록 변경되었다. 변경된 내용으로 스프링 시큐리티 JWT 로그인을 구현해보려 한다. 다만, 본 게시글은 스프링 시큐리티 위주의 내용만 작성하려고 한다. 로그인, 회원가입 등의 별도 비즈니스 로직 코드는 게시글 하단의 깃허브를 참고하길 바란다. 기술스택- Spring Boot 3.3.1- Spring Security 6.3.1- JPA- JWT(Access Token, Refresh Token) 구현- Spring Security 6.1 이후 lambda 문법을 이용한 코드 적용 JWT에 대한 설명이나 이전에 작성한 내용에 대해..
들어가며Spring Security 6.1부터 기존에 사용하던 and()와 non-Lambda DSL Method가 Deprecated 되고, 필수적으로 Lambda DSL을 사용하도록 변경되었다. 변경된 내용으로 스프링 시큐리티 세션 로그인을 구현해보려 한다. 다만, 본 게시글은 스프링 시큐리티 위주의 내용만 작성하려고 한다. 로그인, 회원가입 등의 별도 비즈니스 로직 코드는 게시글 하단의 깃허브를 참고하길 바란다. 기술스택- Spring Boot 3.3.1- Spring Security 6.3.1- JPA- Session, Form Login 구현- Spring Security 6.1 이후 lambda 문법을 이용한 코드 적용 스프링 시큐리티에 대한 설명은 해당 글을 참고하면 된다.링크 : https..
log4j2.xml {%5p}{FATAL=red blink, ERROR=red bold, WARN=yellow bold, INFO=green bold, DEBUG=blue bold, TRACE=blue} ... 결과 로그별 색상이 다르게 출력되는 것을 볼 수 있다.
CustomHighlightConverter 구현ForegroundCompositeConverterBase 상속 객체를 구현한다.import ch.qos.logback.classic.spi.ILoggingEvent;import ch.qos.logback.core.pattern.color.ANSIConstants;import ch.qos.logback.core.pattern.color.ForegroundCompositeConverterBase;/** * logback-spring 로그 레벨별 색상 지정 Custom Converter Class */public class CustomHighlightConverter extends ForegroundCompositeConverterBase { @Overr..
들어가며 회사에서 진행하는 신규 프로젝트의 AA 역할을 맡아 API 프로젝트를 아키텍처링했다. 기존 프로젝트에서 API 서버와 UI 서버를 분리하고, 레거시 코드를 리팩터링 하는 등 개편과 동시에 기능 개발을 진행하는 프로젝트였다. 필자가 맡았던 프로젝트는 기능이 꽤나 복잡하나 프로젝트였다. 예를 들어, 리뷰를 작성하면 포인트도 주고, 쿠폰도 주고, 등급 점수도 올라갔다. 그런데 이 리뷰 작성을 하는 방식이 총 4가지가 있었다. 혹은 A라는 기능은 메인 페이지, 마이 페이지, 특정 동작 완료 페이지에서 사용했다. 또, B라는 기능은 B-1, B-2, ..., B-10이라는 기능으로 고도화되었다. 왜 이렇게 비즈니스 로직이 복잡하게 기획되었는지는 나중에 생각하고, 당장 이 상황에 맞는 설계가 필요했다. 하..
들어가며 하나의 어플리케이션에서 다중 DB에 접근할 수 있는 설정에 대해 알아보려고 한다. 대략적인 순서로는 application.yml 설정파일에 db 연결정보 작성 Config 파일 생성 service, dao, mapper 파일 생성 테스트 위와 같으며, 패키지 구조도 함께 살펴보겠다. 0. 프로젝트 구조 프로젝트 구조는 다음과 같다. 중요하게 봐야할 부분은 Mapper 인터페이스 파일과 쿼리를 작성하는 xml 파일을 DB별로 나눠서 사용할 수 있게끔 나누었다. 1. application.yml 설정파일에 db 연결정보 작성 연결하려는 DB의 접속정보들을 작성한다. 2. Config 파일 생성 Mybatis를 사용하기 위해 HikariCP의 DataSource를 설정하였다. HikariCP에 대한 ..
들어가며 application.yml 이나 application.properties 파일에 DB 접속 정보 또는 키 값을 명시하는 경우 중요한 정보들이 외부로 유출되어 심각한 피해가 발생할 수 있다. 이를 해결하기 위해 해당 파일의 정보를 암호화하는 방법에 대해서 알아보려고 한다. 이번 게시글에서 사용할 라이브러리는 jasypt(Java Simplified Encryption) 이다. 참조 : http://www.jasypt.org/ Jasypt: Java simplified encryption - Jasypt: Java simplified encryption - Main Jasypt 1.9.3 RELEASED! (May 25th, 2019) [DOWNLOAD and ChangeLogs] [WHAT'S ..
들어가며 서비스를 제공하다 보면 운영환경과 개발환경이 서로 다른 경우들이 있다. 예를 들면, 운영 DB와 개발 DB 환경이 다르거나, 로그 레벨을 다르거나 하는 경우이다. 그럴 때마다 매번 application.yml 혹은 logback.xml 파일을 수정할 수 있지만, 매우 비효율적이다. 이번 게시글에서는 실행환경(profile)에 따라 다른 설정 파일을 사용하는 방법에 대해서 알아보려고 한다. 이번 게시글은 스프링 2.4 이상 버전을 기준으로 작성하였다. 2.4 버전을 기준으로 application.yml에서 active profile을 설정하는 방법이 바뀌었다. spring: profiles: active: dev spring: config: activate: on-profile: dev 1. re..