일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- git
- mybatis
- OOP
- Redis
- Interceptor
- request
- 관점지향프로그래밍
- Filter
- network
- java
- Spring
- 자바
- Spring Security
- 스프링 시큐리티
- http
- 인터셉터
- aop
- spring boot
- 객체지향프로그래밍
- response
- RestControllerAdvice
- SQL
- MYSQL
- proxy pattern
- aspect
- 트랜잭션
- 디자인패턴
- 스프링
- exception
- 스프링부트
- Today
- Total
목록Spring Framework (33)
장쫄깃 기술블로그
분산락(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..
Scheduling (스케줄링) 스케줄링은 어떤 작업 (job)에 대해서 지정된 기간 혹은 시간에 동작하도록 하는 것이다. Spring에서 스케줄 작업을 처리하기 위해서는 Quartz Scheduler와 같은 외부 라이브러리를 이용하거나 Spring Boot에서 제공하는 @Scheduled 어노테이션을 이용하여 간단하게 동작시킬 수 있다. Quartz Scheduler 라이브러리는 보다 정교하게 job 스케줄링을 다룰 수 있다. 하지만 설정과 사용에 번거로운 단점이 있다. 반대로 @Scheduled는 사용하기 매우 쉽다. 때문에, 만약 단순히 특정 시간 혹은 특정 간격으로 job을 수행해야 하는 정도이면 @Scheduled를 사용해도 좋을 것 같다. @Scheduled 사용법 1. @EnableSched..
들어가며 프록시 패턴 (Proxy Pattern)은 객체 지향 디자인 패턴 중 하나로, 객체 간의 간접적인 접근을 가능하게 하는 구조를 제공하는 패턴이다. 이번 게시글에선 프록시 패턴을 이용하여 전혀 다른 2가지 이상의 요구사항을 구현한 경험에 대해 정리해보려고 한다. 프록시 패턴에 대한 설명은 해당 글을 참고하면 된다. 링크 : https://jangjjolkit.tistory.com/59 [Design Pattern] 프록시 패턴 (Proxy Pattern) 프록시 패턴 (Proxy Pattern) 이란? 프록시 패턴 (Proxy Pattern)은 객체 지향 디자인 패턴 중 하나로, 객체 간의 간접적인 접근을 가능하게 하는 구조를 제공하는 패턴이다. 여기서 프록시 (Proxy)란 대리 jangjjol..
들어가며 회사에서 진행하는 신규 프로젝트의 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에 대한 ..