전체 글
Spring Boot에 Redis를 적용하여 인기 메뉴 순위 구현
0. 목표 일주일간 인기 메뉴 순위 조회 기존 방식 순위 조회할 때마다 DB에 접근해서 순위 연산 JPA의 네이티브 쿼리 이용 목표 Redis로 캐싱하여 DB 접근 최소화 성능 향상 Redis란 키-값(Key-Value) 구조의 비정형 데이터를 저장 및 관리하며 빠른 처리하는 비관계형 DBMS 다양한 데이터 구조 지원 데이터베이스, 캐시, 메세지 브로커 등의 용도로 사용 Redis의 Sorted Sets을 사용하여 랭크 보드 구현 구조 설계 Redis Sorted Sets 구조 Spring 구조 Order 1. 최초 주문 시 DB에 저장 2. DB 저장 후 Redis에 Score 추가 PopularMenu 1. 인기 메뉴 조회 시 Redis 조회 2. 조회 데이터 반환 (3. Redis에 데이터가 없을 ..
Custom Exception: 검사 예외, 런타임 예외 무엇을 써야할까
포인트 사용 시 포인트가 부족하면 IllegalArgumentException(extends RuntimeException) 예외 발생 @Entity public class Point { private Integer amount; ... public Integer usePoint(Integer amount) { checkEnoughPoint(amount); this.amount -= amount; return this.amount; } private void checkEnoughPoint(Integer amount) { if(this.amount - amount < 0) throw new IllegalArgumentException("사용할 포인트가 부족합니다."); } } 표준 예외로 간단하게 쓰기 위..
@ExceptionHandler는 어떻게 예외를 처리할 수 있을까?
결론부터 말하자면 DispatcherServlet 덕분에 가능하다. DispatcherServlet의 동작 방식을 확장하여 만들어진 여러 가지 전략 중 예외 처리 전략도 있다. HandlerMapping(URL과 요청정보를 기준으로 어떤 컨트롤러를 사용할 건지 결정) HandlerAdapter(HandlerMapping 전략에 따라 선택한 컨트롤러가 어떤 타입이든 DispatcherServlet가 사용할 수 있게 함) ViewResolver(컨트롤러가 리턴한 뷰 이름을 참고해서 적절한 뷰 오브젝트를 찾아줌) ... HandlerExceptionResolver(예외 처리) 예외가 발생했을 때 종류에 따라 클라이언트에게 알려주는 작업은 DispatcherServlet을 통해 처리되어야 하기 때문이다. @Co..
자바의 함수형 프로그래밍 전략, 메서드 참조
자바 8의 주요 컨셉은 함수형 프로그래밍 지향이다. 여기서 함수형 프로그래밍이란 함수를 일급 값으로 넘겨주도록 구현하는 것이다. 객체를 여기저기로 넘겨주며 활용하는 것처럼 메서드도 그렇게 하면 프로그램을 더 효율적으로 구현할 수 있다. 자바의 함수형 프로그래밍의 전략 중 하나로 메서드 참조가 있다. 메서드 참조는 말 그대로 객체를 참조하듯, 메서드를 참조하는 것이다. 메서드 참조의 문법은 " :: " 다. 이 메서드를 값으로 사용하라는 의미다. File[] hiddenFiles = new File(".").listFiles(File::isHidden); "그래서 메서드 호출이랑 참조가 뭐가 다른 건데?"라는 질문이 생길 수 있다. 아래의 간단한 코드 예제를 보면 두 개념의 차이 그리고 자바의 지향점을 알..
응답Response과 처리량Throughput
시스템 성능의 지표 시스템을 사용하는 사용자는 불만을 얘기한다. 시스템이 느려서 사용할 수 없어 클릭한 후 아무리 기다려도 화면이 뜨지 않아 일괄 처리가 아침이 되어도 끝나지 않아 인프라 관점에서 응답(Response)과 처리량(Throughput)은 시스템 성능의 중요한 지표다. 응답은 사용자 입장에서 요청을 보낸 후 응답받기까지를 의미한다. 처리량은 서비스 제공자 입장에서 시간당 처리하는 양이다. 응답 문제 응답 시간은 아래와 같이 세세히 나눌 수 있다. 사용자가 브라우저를 클릭하여 요청이 실행되기까지 + 웹 서버 통신 + 웹 서버 처리 + AP 서버 통신 + AP 서버 처리 + DB 서버 통신 + DB 처리 + ... + 브라우저 화면이 결과를 표시하는 시간 서버 처리 시간은 데이터 구조나 탐색 ..
Spring과 Spring Boot 차이 한 줄 요약
스프링과 스프링 부트. 스프링 부트가 더 편한 건 알겠는데 정확한 차이점을 알고 싶어서 검색해 보면 비슷한 내용의 긴 글들만 마주치게 된다. 그래서 둘의 차이점을 한 줄로 요약하면 뭔데? Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can "just run". 스프링 부트로 "그냥 실행"만 하면 독립적이고 상용화 수준인 스프링 애플리케이션을 만들 수 있다. 스프링 공식 사이트의 스프링 부트 페이지 첫 문장이다. 스프링을 처음 시작했을 때 환경 설정에 애를 먹었던 경험이 있을 것이다. 그에 비해 부트는 환경 설정이 비교적 간편하다. 스프링 부트는 바로 "just run"의..
[Java] 제네릭
들어가기 전 에러가 발생하는 시간을 기준으로 컴파일 에러와 런타임 에러로 나눌 수 있다. 둘 중에 어떤 게 더 치명적일까? 컴파일 에러는 IDE가 바로 알려주기 때문에 고치기 쉽다. 반면 런타임 에러는 그 코드가 실제 사용되기 전까지는 발견하기가 어렵다. 게다가 그 에러로 인해 실제 데이터에 영향을 준다면 더 치명적일 것이다. 런타임 에러가 발생할 여지가 있는 코드를 컴파일 단계에서 검사를 한다면 치명적인 에러를 줄일 수 있다. 제네릭이란 클래스, 인터페이스, 메서드를 정의할 때 타입(클래스 및 인터페이스)을 매개변수로 사용하는 기능 사용하는 이유? 1. 컴파일 시 타입 검사를 해 코드의 안정성을 높임 2. 형변환 번거로움이 줄어듦 여기까지만 보면 설명이 추상적이라 명확하게 이해가 되지 않을 수 있다. ..
트랜잭션 이해
트랜잭션에 대해 이미 알고 있는 것 예외 발생 시 롤백해줌 스프링에서 주로 서비스 계층 클래스에 @Transactional 애노테이션을 붙여서 사용 클래스에 @Transactional 붙이면 메서드마다 적용됨 트랜잭션 스크립트 vs 선언적 트랜잭션 A, B, C라는 메서드가 있을 때 A, B, C를 하나의 트랜잭션에 넣으려면? 트랜잭션 스크립트 Connection connection = dataSource.getConnection(); try { connection.setAutoCommit(false); doSomething(connection, id, ...); connection.commit(); } catch (Exception e) { connection.rollback(); throw new I..
3. JAVA로 아주 간단한 WAS와 Spring MVC Framework 만들기
WAS란 Socket과 HTTP 구현 Servlet Container & Spring Container 구현 Servlet 구현 MVC 구현 Servlet Container 구현 Servlet Container란 서블릿 컨테이너는 브라우저와 같은 클라이언트로부터 들어오는 요청을 받아서 서블릿을 동작시켜 주는 일을 맡는다. 서블릿은 웹 애플리케이션이 시작될 때 미리 만들어둔 웹 애플리케이션 컨텍스트에게 빈 오브젝트로 구성된 애플리케이션의 기동 역할을 해줄 빈을 요청해서 받아둔다. 그리고 미리 지정된 메소드를 호출함으로써 스프링 컨테이너가 DI 방식으로 구성해 둔 애플리케이션의 기능이 시작되는 것이다. RequestHandler 앞서 구현한 WebServer에서 RequestHandler 인스턴스를 생성하여..
2. JAVA로 아주 간단한 WAS와 Spring MVC Framework 만들기
WAS란 네트워크 연결 (with Socket) 구현 Servlet Container & Spring Container 구현 Servlet 구현 MVC 구현 구현 코드 GitHub - leelee31/was: WAS 구조와 Spring MVC 동작 학습용 프로젝트 WAS 구조와 Spring MVC 동작 학습용 프로젝트. Contribute to leelee31/was development by creating an account on GitHub. github.com 네트워크 연결 (with Socket) 구현 Web Application Server, 서버를 구현한다는 것은 무엇일까? '클라이언트/서버'는 컴퓨터 간의 관계를 역할로 구분하는 개념이다. 서버는 서비스를 제공하는 컴퓨터이고, 클라이언트는 ..
1. JAVA로 아주 간단한 WAS와 Spring MVC Framework 만들기
WAS란 네트워크 연결 (with Socket) 구현 Servlet Container & Spring Container 구현 Servlet 구현 MVC 구현 프로젝트 목적 WAS와 Spring MVC Framework는 자바를 배우고 나서부터 사용해 왔지만 대략적인 구조만 알고 있었다. 구조로 인한 에러를 여러 번 겪다 보니 언젠간 직접 구조를 만들면서 학습해 봐야겠다고 생각했다. 하지만 뭐부터 해야 할지 막막함이 커 시작하기까지 오랜 시간이 걸렸다. 이 학습 프로젝트가 누군가의 막막함을 해소하는 데 작게나마 도움이 되었으면 좋겠다. 구현 코드 GitHub - leelee31/was: WAS 구조와 Spring MVC 동작 학습용 프로젝트 WAS 구조와 Spring MVC 동작 학습용 프로젝트. Cont..
커피 주문 서비스를 객체 지향으로 설계해보기 with Java
프로젝트의 목적 지난 3년간 업무에서 접했던 코드들은 객체 지향과는 거리가 멀었다. Service단이나 DAO는 추상화가 되어있었지만 대부분의 데이터는 Map으로 관리해야 했다. 자바라는 언어에 관심을 갖게 된 계기가 '객체 지향'이었기 때문에 마음속엔 항상 아쉬움이 있었다. Map으로 데이터를 관리하는 건 어떨까? 예를 들어 customer에 name, address, phone number라는 속성이 있다고 하자. 컨트롤러는 화면으로부터 customer 정보가 담긴 Map 타입 파라미터를 받는다. 컨트롤러에서 customer가 가진 속성을 확인하려면 디버깅을 하거나 for문으로 Map 내부를 모두 print 해봐야 한다. 그뿐만이 아니다. 실수로 map.get("nmae")으로 오타를 내서 에러가 날..
JVM 명세 - Run-Time Data Areas
공식 JVM 명세 The Java Virtual Machine Specification, Java SE 11 Edition 문서이고 번역은 파파고로 했다. -> 표시 뒤 문장은 내가 단 주석이다. 명세 중 JVM에서 다루는 데이터 유형과 Run-time Data Areas에 대한 내용이다. JVM이란? JVM은 추상적인 컴퓨팅 머신이다. 실제 컴퓨팅 머신처럼, 그것은 명령어 세트를 가지고 있고 실행 시 다양한 메모리 영역을 조작한다. JVM은 자바 프로그래밍 언어에 대해 전혀 알지 못하며, 특정 바이너리 형식, 클래스 파일 형식만 알고 있다. 클래스 파일에는 Java Virtual Machine 명령(또는 바이트 코드)과 기호 테이블 및 기타 보조 정보가 포함되어 있습니다. 형식 및 데이터 유형 1. c..
테스트 코드와 의존성 주입
톰 롱의 를 읽다가 메모 테스트 코드 작성 시 의존성 주입 사용에 대해 설명하기 위한 예시가 이메일 발송과 관련되어 있다. 이메일 발송 기능이 들어가는 테스트 코드를 작성했던 개인적인 경험(흑역사)이 떠올랐다. 당시 작성했던 코드의 문제를 깨달은 과정을 적어본다. 작가는 아래 두 클래스의 예를 들어 의존성 주입을 사용하면 테스트 용이성이 크게 향상된다고 한다. 의존성을 주입하지 않은 클래스 (not good) // 고객에게 송장 리마인더를 보내는 클래스 class InvoiceReminder { private final AddressBook addressBook; private final EmailSender emailSender; // 여기를 보자! // 의존 객체가 생성자에서 생성된다. // 하드 코..
DB 계층 구조 설계 - 클로저 테이블 패턴
계층 구조인 조직도 테이블을 설계하게 되었다. 0. 기존에 접하던 테이블 구조 테이블 하나 id 컬럼 | 부모_id 컬럼 | 기타 컬럼 계층형 쿼리 사용 프로젝트에서 자주 보던 계층형 쿼리는 한 번에 이해하기에 어렵다고 느꼈었다. 계층이 깊은 경우는 더더욱. 나는 이해하기 쉬운 코드가 좋다. 이번에 테이블 설계를 하면서 이해하기 쉬운 쿼리를 쓸 수 있는 방법이 없나 찾아봤다. 그러다 빌 카윈 Bill Karwin이라는 개발자의 아래 자료를 보게 되었다. 자료에 대한 간단한 요약과 적용한 결과(MySQL)를 공유하고자 한다. https://www.slideshare.net/billkarwin/models-for-hierarchical-data Models for hierarchical data Tree-l..
자바로 간단한 http 웹 서버 구현
자바지기님의 유튜브 영상과 자료를 참고하여 실습을 진행한다. 기본으로 제공되는 프로젝트가 있으며 요구사항에 맞춰 코드를 발전시킨다. 요구사항마다 힌트가 있으나 우선 스스로 구현 방법을 생각해본다. https://www.youtube.com/watch?v=qgFVj916nX8&list=PLqaSEyuwXkSqV88SwDxuY56xmj6KsmzRN&index=1 https://www.slideshare.net/javajigi/http-web-server HTTP web server 구현 자바 기반으로 web server를 직접 구현하면서 HTTP 동작 원리에 대해 이해한다. www.slideshare.net 개발 환경 설정 지난 번의 간단한 자바 통신 구현에서 봤던 내용들이다. 프로젝트(위 슬라이드에 깃허브..