본문 바로가기

프로그래밍/Spring18

[Spring] 싱글톤 컨테이너 웹 어플리케이션과 싱글톤 1. 스프링은 기업용 온라인 서비스 기술을 지원하기 위해 탄생했다. 2. 스프링은 주로 웹 개발에 사용된다. 3. 여러 클라이언트의 요청을 받기 때문에 싱글톤 패턴을 이용한다. 만약 1초에 100개의 요청들이 들어온다면? 100개의 객체를 생성해야 할까? 1개의 객체만 생성하고 클라이언트 요청에 따라 돌려쓰는 방안이 필요하다. => 싱글톤 사용 싱글톤 코드 package hello.core.singleton; public class SingletonService { //1. static 영역에 객체를 딱 1개만 생성해둔다. private static final SingletonService instance = new SingletonService(); //2. public으로 열.. 2023. 7. 16.
[Spring] 스프링 컨테이너와 스프링 빈 ApplicationContext applicationContext = new AnnotationConfigApplicationContext(AppConfig.class); ApplicationContext를 스프링 컨테이너라고 한다. ApplicationContext는 인터페이스이다. 스프링 컨테이너는 XML을 기반으로 만들 수 있고, 어노테이션 기반의 자바 설정 클래스로 만들 수 있다. AppConfig 클래스를 만들었던 것이 어노테이션 기반의 자바 설정 클래스로 스프링 컨테이너를 만든 것이다. *스프링 컨테이너를 부를 때, BeanFactory, ApplicationContext로 구분해서 이야기한다. BeanFactory를 직접 사용하는 경우는 거의 없으므로 일반적으로 ApplicationCont.. 2023. 7. 14.
[Spring] 스프링 핵심 원리 이해2 - 객체 지향 원리 적용 새로운 할인 정책이 추가된다면, Service내의 Policy를 다시 할당해야 한다. // private final DiscountPolicy discountPolicy = new FixDiscountPolicy(); private final DiscountPolicy discountPolicy = new RateDiscountPolicy(); 다형성을 활용하고 인터페이스와 구현 객체를 분리했다. 하지만 OCP, DIP원칙을 지키고 있지 않다. 클라이언트 코드 자체를 수정했으므로 OCP 원칙에 어긋난다. 인터페이스를 참조하지만 구현 클래스에도 의존하고 있으므로(RateDiscountPolicy) DIP 원칙에 어긋난다. 이러한 문제를 해결하기 위해 AppConfig클래스를 만들어 원하는 할인 정책 및 저.. 2023. 7. 14.
[Spring] 스프링 핵심 원리 이해1 - 예제 만들기 회원 회원 회원을 가입하고 조회할 수 있다. 회원은 일반과 VIP 두 가지 등급이 있다. 회원 데이터는 자체 DB를 구축할 수 있고, 외부 시스템과 연동할 수 있다. (미확정) => MemberRepository 인터페이스를 만들어서 처리한다. 주문과 할인 정책 주문과 할인 정책 회원은 상품을 주문할 수 있다. 회원 등급에 따라 할인 정책을 적용할 수 있다. 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인을 적용해달라. (나중에 변경 될 수 있 다.) 할인 정책은 변경 가능성이 높다. 회사의 기본 할인 정책을 아직 정하지 못했고, 오픈 직전까지 고민을 미루고 싶다. 최악의 경우 할인을 적용하지 않을 수 도 있다. (미확정) => 할인 정책 인터페이스 구현체가 1개밖에 없는 경우 ~Imp.. 2023. 7. 13.
[Spring] 객체 지향 설계와 스프링 객체 지향 설계와 스프링 1. 스프링은 다음 기술로 다형성 + OCP, DIP를 가능하게 지원한다. DI(의존성 주입) DI 컨테이너 2. 클라이언트 코드의 변경 없이 기능 확장 3. 쉽게 부품을 교체하듯이 개발 스프링 프레임워크는 OCP, DIP 원칙을 지키면서 개발하다보니 만들어졌다. 정리 1. 모든 설계에 역할과 구현을 분리하자. 2. 공연을 설계 하듯이 배역만 만들어두고, 배우는 언제든지 유연하게 변경할 수 있도록 만드는 것이 좋다. 3. 이상적으로는 모든 설계에 인터페이스를 부여하자. 할인 정책에 대한 인터페이스를 만들어 놓고 나중에 수정하는 방식으로 간다. 실무 고민 1. 인터페이스를 도입하면 추상화라는 비용이 발생한다. 2. 기능을 확장할 가능성이 없다면, 구체 클래스를 직접 사용하고 향후 .. 2023. 7. 12.
[Spring] 좋은 객체 지향의 5가지 원칙(SOLID) SRP 단일 책임 원칙 Single Responsibility Priciple 1. 한 클래스는 하나의 책임만 가져야 한다. 2. 하나의 책임이라는 것은 모호하다. 클 수 있고, 작을 수 있다. 문맥과 상황에 따라 다르다. 3. 중요한 기준은 변경이다. 변경이 있을 때 파급 효과가 적으면 단일 책임 원칙을 잘 따른 것이다. 예) UI변경, 객체의 생성과 사용을 분리 OCP 개방 폐쇄 원칙 Open/Closed Principle 1. 소프트웨어 요소는 확장에는 열려 있으나 변경에는 닫혀 있어야 한다. 2. 인터페이스를 구현한 새로운 클래스를 하나 만들어서 새로운 기능을 구현한다. 문제점 MemberRepository m = new MemoryMemberRepository(); // 기존 코드 MemberR.. 2023. 7. 12.
[Spring] 좋은 객체 지향 프로그래밍이란? 추상화, 캡슐화, 상속, 다형성 객체 지향 프로그래밍이란? 1. 컴퓨터 프로그램을 명령어의 목록으로 보는 시각에서 벗어나 여러 개의 독립된 단위, 즉 "객체"들의 모임으로 파악하고자 하는 것이다. 각각의 객체는 메시지를 주고 받고, 데이터를 정리할 수 있다. (객체들의 모임이 메시지를 주고 받으며 협력한다.) 2. 객체 지향 프로그래밍은 프로그램을 유연하고 변경이 용이하게 하므로 대규모 소프트웨어 개발에 많이 사용된다. 다형성이란? 역할(인터페이스)과 구현(인터페이스를 상속받은 객체) 자동차 역할 - K3, 아반떼, 테슬라 모델3 등 자동차가 바뀌어도 운전자는 운전을 할 수 있다. 왜? 자동차의 인터페이스에 맞추어 개발을 했기 때문이다. K3전용 운전면허? 아반떼 전용 운전면허? No 자동차 세계를 무한.. 2023. 7. 12.
[Spring] 스프링이란? 스프링이란? 스프링은 스프링 기술들의 모임이다. 스프링 프레임워크, 스프링 부트, 스프링 데이터, 스프링 세션.. 등 스프링 프레임워크 핵심 기술: 스프링 DI 컨테이너, AOP, 이벤트, 기타 웹 기술: 스프링 MVC, 스프링 WebFlux 데이터 접근 기술: 트랜잭션, JDBC, ORM 지원, XML 지원 기술 통합: 캐시, 이메일, 원격접근, 스케줄링 테스트: 스프링 기반 테스트 지원 언어: 코틀린, 그루비 스프링부트 스프링을 편리하게 사용할 수 있도록 지원하는 기술, 최근에는 기본으로 사용된다. 1. Tomcat 같은 웹서버를 내장하여 별도의 웹서버를 설치하지 않아도 된다. 2. 손쉬운 빌드 구성을 위한 starter 종속성 제공 3. 3rd party 라이브러르 자동구성 4. 메트릭, 상태 확인.. 2023. 7. 12.