기본 콘텐츠로 건너뛰기

의존성과 아키텍처

설계는 변경과 관련이 있다.
의존성 : 클래스 의존성패키지 의존성(패키지에 포함된 클래스 사이의 의존성)
A -> B : A B 의존한다. B 변경되면 A 영향이 있다.

가이드
양방향 의존성을 피하라
다중성이 적은 방향을 피하라 : 1:N 검색삭제  비용이 커진다
패키지 사이의 의존성 사이클을 제거하라 *** (싸이클 제거)



리파지토리 구현 클래스를 인프라스트럭쳐 영역에 위치시켜서 인프라스트럭쳐에 대한 의존을 낮춰야한다.
인프라스트럭쳐는 표현, 응용, 도메인 영역을 지원한다.
도메인 객체의 영속성 처리, 트랙잭션, Rest Client 다른 영역에서 필요하는 하는 구현 기술, 보조기능을 지원한다.


객체와 디비는 다르다. 객체는 행동, 디비는 중복 제거를 한다.
이걸 해결하기 위해 JPA 사용하지만 Lazy loading 문제가 된다. 어디까지 읽어야 할까?
그러다 보면 조회하고, 비즈니스 처리하고, 체크하고 이런 식으로 로직이 만들어진다.
그리고 성능문제가 발생한다. 객체 그룹 조회 경계 모호해지며 트랜잭션 경계는 어디까지인가?

객체 참조가 필요할까
객체참조는 결합도가 가장 높은 의존성이다. 객체 참조를 끊자 

  • 함께 생성되고 함께 삭제되는 객체들을 함께 묶어라
  • 도메인 제약사항을 공유하는 객체들을 함께 묶어라.

댓글

이 블로그의 인기 게시물

[JPA] deleted instance passed to merge

org.springframework.dao.InvalidDataAccessApiUsageException: org.hibernate.ObjectDeletedException:   deleted instance passed to merge: 위와 같은 에러가 발생... em.remove(user)를 호출하면 user는 영속성 컨텍스트에서 제거된다. (Object is already marked for being deleted) 이후 트랜잭션을 커믹해서 플러시를 호출하면 실제 데이터베이스에 삭제 쿼리를 전달한다. 하지만 삭제된 엔티티를 한 트랜잭션내에서 다시 삭제할려고하면 해당 익셉션이 발생한다. 참조 : 자바 ORM 표준 JPA 프로그래밍

Spring Redis Cluster Configuration

# build.gradle compile  'org.springframework.data:spring-data-redis' compile  'biz.paluch.redis:lettuce:4.5.0.Final' #RedisConfiguration @Configuration @ EnableRedisRepositories ( basePackageClasses  = { MyAppDomains. class  }) public class  RedisConfiguration {      @Value ( "${spring.redis.host}" )      private  String  redisHost ;      @Value ( "${spring.redis.port}" )      private int  redisPort ;      @Bean          public  RedisConnectionFactory  myRedisConnectionFactory () {         RedisClusterConfiguration clusterConfig =  new  RedisClusterConfiguration() ;          clusterConfig.clusterNode( redisHost ,  redisPort ) ;         re...

xsl-fo를 이용한 pdf 생성기술

1. PDF 생성 기술 개발을 위해 적용가능한 오픈소스 1)  pdfbox - http://pdfbox.apache.org/ - License : Apache License Version 2.0 2)  iText - http://itextpdf.com/ - License : APGL License 3)  Apache FOP - http://xmlgraphics.apache.org/fop/ -> 유지보수 비용은 높지만, 무료이며 한글이 출력 가능한 Apache FOP를 적용 2. XSL-FO를 이용하여 PDF를 어떻게 생성 하는지 설명 * XSL-FO의 기본 프로세스 용어 설명 1) XSLT - XML 문서를 다른 XML 문서로 변환하는데 사용하는 XML 기반의 언어 - 원본 문서는 변경되지 않으며, 원본 문서를 기반으로 새로운 문서를 생성 2) XSL-FO - XSL-FO는 종이, 화면 등 다양한 매체에 출력 하기 위한 XML 기반의 마크업 언어 - 사용자는 XSL-FO를 통해 어떻게 정보가 PDF에 출력되는지 확인 가능 3) XSL-FO Formatter - XSL-FO 문서를 최종 결과물인 PDF(다른 매체도 가능)문서로 변환할 수 있는 Formatter 간략하게 애기하면,  XSL-FO를 Formatter로 변환하게 되면 PDF가 생성되며,  XSL-FO는 사용자가 직접 작성할 수도 있고 XML source와 XSLT stylesheet를 이용하여 동적으로 생성 가능하다. 3. 간단한 예제로 정리 1) 필요한 데이터를 XML에 기술한다. XML file  <?xml version="1.0" encoding="UTF-8"?> <root>   <name>홍길동</name> </root>  ...