slf4j을 활용한 로깅시 놓치기 쉬운 실수 한가지 그리고 Logback 내부 동작 과정 해당 포스트에선 java 8, logback 1.3, slf4j 2.0를 바탕으로 코드 제공 및 설명한다. 요약: slf4j의 로깅 메서드 호출 시 formatted string이 필요하다면 무조건 {} 쓰자. 개발을 하다 보면 디버깅 및 에러감지를 위해 필수적으로 코드 사이사이에 로그를 쌓게 된다. 자바에서는 로깅 기능을 위해 활용되는 프레임워크가 크게 logback, log4j, log4j2 정도가 있다. 보통 애플리케이션 단에서는 이 프레임워크들을 직접 사용하진 않고(굳이 사용하고 싶다면 뭐..), 이들을 추상화시켜 뒷단에 두며 구현체를 선택할 수 있는 퍼사드를 제공하는 프레임워크를 사용한다. 퍼사드의 종류엔 ..
스프링 프록시 기반 AOP (2) - CGLIB Proxy 이번엔 cglib를 이용한 프록시 객체 생성/동작 과정에 대해서 알아보고자 한다. 스프링 AOP 적용을 위한 프록시 방식 2가지 중, cglib가 사실상 메인으로 쓰이는데, cglib가 뭔지, 프록시 객체 생성을 위해서 cglib에서 어떤 모듈이 쓰이는지에 대해 알아보자. 메인으로 쓰인다는 것에 대한 지표등은 확인 못했지만, aop를 적용하고자 하는 메소드가 인터페이스를 구현하지 않는 경우도 많으며, 부트에서도 auto-configuration에서 default로 cglib를 선택하고 있으므로 main라고 말해도 되지 않을까.? CGLIB (Code Generation LIBrary) 해당 글을 작성하며 cglib에 대해 좀 더 자세히 보기전까진..
스프링 Proxy 기반 AOP (1) 스프링을 통해 애플리케이션을 개발할 때, 우리는 애플리케이션의 도메인과 관련된 코어 로직 개발뿐만 아니라 이 코어 기능을 제대로 동작시키기 위해 트랜잭션 관리나 로깅, 캐싱등의 관심에도 신경써야한다. 하지만 이런 부가적인 관심사들을 도메인 코어 로직에 같이 녹여야한다면 해당 모듈은 변경의 이유가 도메인 로직의 변경 뿐만이 아니게 된다. 그리고 이런 부가적인 관심사들은 전 애플리케이션의 영역이 활용이 필요하다. 그래서 스프링에선 AOP를 통해서 이런 공통적인 기능들을 별도로 분리해 필요한 곳에서 재사용가능하게 했다. 스프링에서 AOP를 적용하기 위해선 스프링에서 자체적으로 구현하고 있는 AOP 프레임워크를 사용할 수도 있고 AspectJ라는 라이브러리를 활용할 수도 있..
NGINX와 Apache(NGINX and Apache) 잘못 정리된 내용이 있다면 댓글부탁드립니다. 관련해서 알아두면 이해하는데 도움되는 내용(추후에 딥하게 알아보자.) socket 네트웤 데이터 교환을 위한 IO 인터페이스 또한 일종의 file이다.(리눅스) blocking/non-blocking mode IO(especially, Network I/O) 외부와 데이터를 교환하기 위한 기능. 소켓은 네트워크를 통해 외부와 데이터를 교환할 수 있는 IO 인터페이스. system call user/kernal space 일단 프로세스(user space상의)는 시스템의 file을 직접 다룰 수 없다. 따라서 소켓에 대한 핸들링을 하기 위해선 커널에 요청해야함. IO multiplexing(select(s..
스프링을 사용하다보면 @Transactional과 함께 자주 사용하는 애노테이션중에 하나가 바로 @Async 일 것이다. 스프링은 애플리케이션에서 메소드의 비동기 수행이 필요한 경우, @Async 애노테이션을 통해 애플리케이션 코어 로직을 수정하지 않고도 AOP를 통해 메소드를 비동기 처리로 전환할 수 있다. 오늘은 이 스프링 비동기 실행 및 이를 위해 필요한 스레드풀 관련해서 포스팅하려 한다. 아래 Spring 코드는 5.x 기반 주의. 스프링 프레임워크 코드 및 이미지가 많아 스크롤 압박은 있을 수 있으나 내용은 실제로 그렇게 길지 않습니다. Spring Async 설정 및 메소드 비동기 수행 스프링은 일련의 작업을 수행하는 메소드를 간단하게 비동기로 처리할 수 있게끔 프레임워크단에서 AOP로 비동기..
자바(버전 8 기준) 오브젝트 생성 과정 톺아보기 (+ JVM Runtime Data Area 영역) Intro 이번에 java 및 JVM의 Runtime Data Area 영역에 대해 공부를 하였는데, 자바에서 오브젝트가 생성 시 어떤 과정을 거치며 jvm 메모리 영역에 올라가는지에 대해 조금 더 자세히 알게되어 정리하고자 합니다. (사실 지금부터 제가하는 말은 거짓말입니다.; 가려서 들어주시고, 틀린점은 바로잡아주시면 업데이트해놓도록 하겠습니다.) 아래와 같은 Product 모델 클래스가 있다고 가정을 하고, 이 클래스의 오브젝트를 생성해보도록 한다. public class Product { public static final int PAYMENT_WINDOW_TITLE_MAX_BYTE = 4000;..
TCP는 Transport layer(4 layer)의 프로토콜인데, 4 layer의 통신은 애플리케이션 프로세스들간의 논리적인 통신이라고 할 수 있다. 호스트의 TCP 소프트웨어간에 데이터를 교환하는 unit은 TCP segment라고 부름.TCP segment는 TCP header와 TCP data(optional)로 구성되어 있다. [TCP segment = TCP header + TCP data] TCP header의 format은 다음과 같다. port numberTCP나 UDP와 같은 transport layer에서 호스트에서 실행중인 애플리케이션 프로세스로 TCP 패킷을 demultiplexing해주기 위해서 각 애플리케이션 프로세스의 소켓은 고유한 identifier를 가지고 있는데, 이게..
API를 개발하다보면 API의 버전을 나눌 필요가 있다. 그런데 API가 바뀔 때가 아니더라도 UI나 아이콘과 같은 것들이 바뀔 때 클라이언트의 버전은 올라가야한다. 그래서 버전을 구분하는 것을 API Level과 Version으로 나누도록 한다. API Level: API가 추가되거나 값이 바뀔때 올라가도록 함Version: API가 변경되지 않더라도 다른 무언가가 바뀌었을 때 올라가도록 함따라서 일정 API Level에 따라 URI에 클라이언트의 버전을 path를 추가하는 방식을 사용한다. AP 서버를 운영하다보면 웹 서버 엔진을 사용하게 되는데, 나는 nginx를 사용하였기에 nginx를 통해서 API versioning을 해보았다. nginx에서 http request의 header를 변수로 가져..
service restart는 service를 재시작하는 것. 서비스를 완전히 shutdown한다음에 다시 시작한다. service reload는 해당 service에게 그것의 configuration 파일들을 reload하라고 명령한다. 이말은 configuration을 reload하는 것이 충분해야만 한다는 것이다. 하지만 아마 특정한 서비스들은 이와 같은 rule을 따르지 않을 수도 있고, config file들을 reload 하지 않을 수도 있다. 이런 것 때문에 아마 service를 restart하는 것이 더 안전할 수 있다.
/etc/init.d이 디렉토리는 System V init tool(SysVinit)에 의해서 사용되는 스크립트들을 포함한다.이것은 전통적인 리눅스에서 service management package인데, 서비스 시작 및 종료, 설정하는 인프라뿐만 아니라 init 프로그램(커널이 이니셜라이징을 끝냈을 때 실행되는 첫번쨰 프로세스)또한 포함한다. 특히. /etc/init.d에 위치한 파일들은 특정 서비스를 관리하기 위한 start, stop, restart, reload 커맨드에 repond하는 쉘 스크립트들이다. 이 스크립트들은 직접 실행될 수도 있고, (대부분은) 어떤 다른 트리거에 의해서 실행 될 수 있다. (보통은 /etc/rc?.d/에 있는 심볼릭 링크를 통해) /etc/init 이 디렉토리는 U..
- Total
- Today
- Yesterday
- async
- Apache
- good practice
- java
- log level
- webserver
- TaskExecutor
- Spring
- logging
- NGINX
- logging facade
- JVM
- log
- lood
- runtime data areas
- object
- slf4j
- linux
- logback
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |