전체 글
-
23/12/14 스프링에서 static 사용을 지양하는 이유오늘/Today I.. 2023. 12. 14. 17:04
최근 자바책을 펴 볼 기회가 있었다. 그 책에서는 익숙하게 사용하였지만, 스프링에서는 뭔가 위화감이 드는 부분을 발견하였는데 스프링에선 클래스에 static을 쓰지 않는다는 것이다. 생각보다 사소한 변화였기에 왜 이상한지 그동안 알아차리지 못하였는데 그 이유를 적어보고자 한다. static을 지양하는 이유 첫번째. 스프링은 기본적으로 빈을 싱글톤으로 관리한다. 그렇기 때문에 하나만 생성되어 여러곳에서 공유하여 사용하는 것이 일반적인 사용방법인데, static은 인스턴스가 아닌 클래스 수준에서 관리되기 때문에 싱글톤 빈의 생명주기와 맞지 않게 된다. 두번째. 테스트 호환성 문제 static은 실행시점에 초기화된 후 종료시점까지 메모리에 남아있는다. 그래서 테스트 수행 시 한 테스트 케이스에서 static ..
-
23/12/13 Docker란?오늘/Today I.. 2023. 12. 13. 22:35
컨테이너 기반의 오픈소스 가상화 플랫폼 컨테이너란? 소프트웨어와 그 dependency를 하나로 패키징하는 것. 이렇게 패키징한 소프트웨어는 어느 환경에서도 동일하게 실행할 수 있다. 도커의 특징 1. 독립성과 표준화 컨테이너는 독립적으로 실행, 실행에 필요한 모든 요소를 포함하므로 어떤 환경에서도 동일하게 작동 2. 경량성 가상머신은 환경에 OS를 포함시키기 때문에 무겁다. 하지만 도커는 호스트 시스템의 운영체제를 공유하기 때문에 별도의 OS를 포함하지 않아서 훨씬 적은 자원을 사용한다. 3. 이식성 컨테이너는 어느 환경에서도 작동하기 때문에 이식성이 좋다 4. 버전관리 버전관리를 지원함. 5. 확장성 도커를 사용하는 이점 1. 환경 일관성 어떤 환경에서도 동일하게 작동하기 때문에 "저는 되는데 왜 서..
-
23/12/12 JPA와 QueryDSL 의 차이오늘/Today I.. 2023. 12. 13. 00:11
JPA (Java Persistence API) - 자바표준 ORM 기술. - SQL이 아닌 자바코드로 DB CRUD를 처리할 수 있게 도와줌 - 개발자가 SQL을 직접 작성하지 않아도 되어 편리 - DB 간 호환성을 높여줌 - 다만 쿼리에 오류가 있을 경우, 런타임에서만 확인가능 QueryDSL - Type-Safe한 쿼리를 작성할 수 있게 해주는 프레임워크 - 쿼리를 자바코드로 작성하기 때문에 컴파일 시점에 쿼리의 문법 오류를 잡아낼 수 있다. - 동적 쿼리 작성이 용이 - 코드 자동완성 등의 IDE 도움을 받을 수 있다. 선택 JPA는 쿼리작성의 편리성과 DB간 호환성 중요시 적합 QueryDSL은 Type - Safe한 쿼리 작성과 동적쿼리 필요시 적합 그렇지만 JPA로 기본적인 CRUD 연산을 ..
-
[스프링 팀프로젝트] IPv4 KPT스파르타코딩클럽/스프링 팀 프로젝트 - Back Office 2023. 12. 11. 15:05
IPv4 | Built with Notion Built with Notion, the all-in-one connected workspace with publishing capabilities. teamsparta.notion.site 1. 프로젝트 개요 프로젝트 명 : X보다 더 나은 Y 프로젝트 설명 : X와 Threads향을 조금씩 가미한 SNS 백엔드 서버 API 필수구현 사용자 인증 (회원가입, 로그인 및 로그아웃) 프로필관리 (프로필 수정, 비밀번호 수정) 게시글 CRUD 추가구현 소셜로그인 (카카오, 네이버) 백오피스 (admin 권한) 좋아요 팔로우 명예의전당 프로필 사진 업로드 게시물 멀티미디어 지원 기능 2. Keep 1. 소통을 중요시하며 자리 비움이나 문제가 생기면 빠르게 공유하겠습..
-
복합키(Composite key)란?스파르타코딩클럽/스프링 팀 프로젝트 - Back Office 2023. 12. 7. 20:52
복합키란 "두 개 이상의 열(column)을 결합하여 하나의 특별한 키로 만든 것" 특징 1. 각각의 키가 유일하지 않을 경우 여러 키를 결합하여 행의 유일성 보장 2. RDB에서 주로 사용되며, 연결테이블에서 많이 사용된다. 3. 종종 FK와 결합되어 사용되며, 두 테이블간의 관계를 보다 명확하게 표현 가능 간단히 내가 이해한것을 써보자면 복합키는 PK가 여러개이다. 그래서 DB는 여러개의 PK를 가진 객체가 서로 같은것인지 확인하기 위해 PK를 객체(=구현체)로 묶어서 확인한다. 프로젝트 내에서 Follow를 구현하기 위해 처음에 복합키를 고려하였다. @Entity @Getter @RequiredArgsConstructor @IdClass(FollowID.class) public class Follo..