반응형

전체 글 169

[Querydsl] Querydsl 사용방법 3가지

직장 동료의 조언 덕분에 Querydsl 설정 방법에도 여러가지가 있다는 것을 알았습니다. 지난번에 작성한 Spring Data JPA 기반 Querydsl 사용해보자. ( Entity 관계 매핑 편, 테스트 코드 포함 )글에서는 QuerydslRepositorySupport를 상속받아 사용하는 방법에 대해서 작성하였습니다. 이번글에서는 이 것외에도 2가지가 더 있고 어떤 것을 선택했는지까지 작성하겠습니다. 모든 소스는 Github에 있습니다. 이동욱님의 티스토리를 참조해서 작성하였습니다. (https://jojoldu.tistory.com/372) Querydsl 사용방법 3가지 QuerydslRepositorySupport 상속받아 사용 JpaRepistory에서 Querldsl 사용 가능하도록 설정..

Develop/spring-data 2020.12.07

[JPA] JPA를 적용하며... mysql 함수 2번 호출되는 문제

왜 querydsl로 조회할때 mysql 함수가 두 번 발생하는 문제가 나타났습니다. 먼저 Spring Data JPA를 사용하면서 왜 mysql 함수를 썼어야 했는지부터 설명드리겠습니다. 진행중인 프로젝트는 mybatis를 사용했었습니다. 그리고 새로운 버전으로 업그레이드하면서 JPA를 도입했고 기존 mapper 쿼리를 걷어내면서 작업을 진행하고 있습니다. 그래서 mybatis를 걷어내기 전까지는 mysql를 함수를 사용하기로 하였습니다. ( 관리포인트를 2개로 나누는 것은 좋지 않다고 판단 ) 증상 querydsl로 아래 소스처럼 mysql function을 이용하여 조회하는 로직이 있습니다. 그런데 function이 두번 호출되고 있습니다. public StoreVo findByName(String..

Develop/spring-data 2020.12.06

org.springframework.dao.InvalidDataAccessApiUsageException

오늘도 어김없이 등장하는 Exception!! org.springframework.dao.InvalidDataAccessApiUsageException: Executing an update/delete query; nested exception is javax.persistence.TransactionRequiredException: Executing an update/delete query 증상 Querydsl로 Update, Delete하던 중 에러가 발생하였습니다. 에러가 발생한 코드는 다음과 같습니다. public Long deleteQuery(Long id) { // JpaQueryFactory 사용 시 // return jpaQueryFactory.delete(store) // .where(s..

TroubleShooting 2020.12.05

[junit] Auditor must not be null! Returned by: class com.example.demo.db.LoginUserAuditorAware!

Junit 테스트 코드를 작성하는 도중 Auditor must not be null 에러가 발생하였습니다. 증상 Junit 테스트 할 로직 중 SecurityContext 정보를 조회할 필요가 있었습니다. 그래서 @BeforeEach 메서드에서 SecurityContext를 Mock으로 임의의 데이터를 넣고 @Test를 실행하는 경우였습니다. @BeforeEach void setUp() { // SecurityContext에서 가져올 유저 정보 UserVo userVo = new UserVo(); userVo.setUserId(1L); List roleNames = Arrays.asList("ROLE_ADMIN"); // userDetails Mock 설정 UserDetails userDetails = ..

TroubleShooting 2020.12.04

[Java] if, else 에서 탈출해보자! interface활용

프로젝트를 진행하다보면 프로세스 로직에서 수많은 분기를 처리하기 위해 if, else가 무수히 달리는 것을 확인할 수 있습니다. 이번 글에서는 if, else를 최대한 줄이고 가독성을 높이는 작업을 진행해보겠습니다. 모든 예제 소스는 github에 올려두었습니다. 이번에 작성하는 글은 주관적인 생각입니다. 전 if, else가 많으면 확장성, 가독성이 좋치 않다고 생각하는 개발자1이기 때문에 이글을 작성합니다. 늘 그랬듯이 개발자는 소스를 보면 가장 이해가 빠르기 때문에 예제소스를 작성해보겠습니다. ProcessService.java @Slf4j @Service @RequiredArgsConstructor public class ProcessService { private final StoreReposi..

Develop/java 2020.12.03

[Monitoring] Actuator, Prometheus를 이용한 monitoring해보자! - 2편 ( monitoring application, prometheus docker 띄우기 )

모니터링 서비스가 없으면 정말 불편합니다. 간단한 예로 ~ 하루는 출근했는데 "** 서비스가 실행이 안되는데?" 확인해보니 메모리 초과로 셧다운되있었습니다. 개발 서버에서 테스트 중에 public망에 있던 서비스와 통신 중에 계속 에러가 발생 확인해보니 셧다운되있었습니다. ** 서비스 죽었어? 잠시만요... 터미널 열고 타자 다다다다다 ps -ef... docker ps .. 매번 이럴순 없습니다. 소스는 github에 올려놓았습니다. 1편 - actuator 적용한 application을 띄우기 2편 - monitoring application, prometheus docker로 띄우기 3편 - Grafana docker로 띄우기 4편 - AlertManager 적용 actuator는 Spring In..

Develop/devops 2020.12.02

[Optional] Java 유용한 Null 처리

Java 코드를 짜면서 가장 많이 발생하는 에러는 무엇일까?? 바로 NullPointException 입니다. 이 Exception을 최대한 줄일 수 있는 Optional에 대해서 정리하겠습니다. Java 8부터 Null처리로 Optional이 나왔다. 그러나 개발자들이 기대했던 것과 다르게 만들어져 말이 많았다.... NullPointException를 완벽하게 방어해낼 것이라는 예상과는 다르게 구멍이 있는 기능이다. Optional의 get()같은.. 그래서 주의사항이 26가지가 된다. 이 글에서는 주의사항에 다루기 전에 Optional이 무엇인지, 어떤 메소드가 있는지에 대해서 알아보겠습니다. Optional이란? T 타입의 객체를 Wrapper하는 Wrapper 클래스입니다. 코드를 작성하다보면 ..

Develop/java 2020.12.01

[JPA] JPA를 적용하며.. ( field convert 편 )

오늘도 JPA를 적용한 프로젝트를 진행 중입니다. 지난글 [JPA] JPA를 적용하며.. ( insert, update 분기 편 ) 에서는 insert, update 분기를 if문 없이 처리하는 유틸리티 함수를 적용했습니다. 이번글에서는 Entity의 field를 convert하는 방법에 대해서 정리하겠습니다. 사건 전말 Database Table 컬럼 중 동적으로 변하는 데이터가 있었습니다. 우리는 해당 컬럼을 varchar 타입으로 주고 Json 방식으로 저장하기로 하였습니다. 아래에 관련 table과 필드 ddl입니다. create table staff ( id bigint auto_increment primary key, age int null, name varchar(255) null, meta..

Develop/spring-data 2020.11.30

서비스에 대한 개발자 선택

실제 운영중인 서비스를 보면 왜 이렇게 만들어놨지? 하며 한숨쉴 때가 있습니다. 그리고 그 서비스를 이어받아 기능을 추가해야할 때 기존 방식에 맞춰야할지? 아니면 수습하면서 진행해야할지? 당연히 수습해야한다! 확장성, 유지보수성, 가독성 등을 고려했을 때 무조건 수정해야한다! 하지만 시간이 없는데? 정해진 시간내에 못하면 어떡하지? 새로운 트러블을 만드는 건데 어떡하지? 제가 내린 답은 의외로 간단합니다! 책임질 수 있다면 수습하시면 됩니다. 말은 쉽지만 실행하기엔 어려운 선택입니다. 저의 경험으로 예를 들어보겠습니다. 이번에 신규 서비스를 만들면서 배치를 만들어야했습니다. 배치를 만들 당시 "이건 Spring Batch로 만들어야해!!" 했으나 Spring Batch를 할 줄 몰라서 @Scheduler..

MindControl 2020.11.29

[Monitoring] Actuator, Prometheus를 이용한 monitoring해보자! - 1편 ( actuator 적용한 application을 띄우기 )

모니터링 서비스가 없으면 정말 불편합니다. 간단한 예로 ~ 하루는 출근했는데 "** 서비스가 실행이 안되는데?" 확인해보니 메모리 초과로 셧다운되있었습니다. 개발 서버에서 테스트 중에 public망에 있던 서비스와 통신 중에 계속 에러가 발생 확인해보니 셧다운되있었습니다. ** 서비스 죽었어? 잠시만요... 터미널 열고 타자 다다다다다 ps -ef... docker ps .. 매번 이럴순 없습니다. 소스는 github에 올려놓았습니다. 1편 - actuator 적용한 application을 띄우기 2편 - monitoring application, prometheus docker로 띄우기 3편 - Grafana docker로 띄우기 4편 - AlertManager 적용 actuator는 Spring In..

Develop/devops 2020.11.28

[JPA] JPA를 적용하며.. ( insert, update 분기 편 )

프로젝트를 진행하면서 JPA를 도입하였습니다. 지난글( [JPA] 프로젝트에 JPA를 적용하며.... ( save편 ) )에서는 JPA의 영속성을 이용하여 insert, update를 처리하는 방법에 대해서 정리하였습니다. 도입 배경 및 JPA 적용방법에 대해서 궁금하시면 제 블로그에 "JPA" 로 검색하시면 Querydsl, 로깅 처리방법까지 정리해두었습니다. insert, update를 메소드로 분리하여 각각 처리하였습니다. 그런데 한 메소드에서 처리할 수 없을까? 하고 고민하고 적용한 내용을 정리하겠습니다. 같은 API로 데이터가 있으면 update하고 없으면 insert하는 메소드 예제를 작성해보겠습니다. @Service @RequiredArgsConstructor // 의존성 주입 public ..

Develop/spring-data 2020.11.27

[JPA] 프로젝트에 JPA를 적용하며.... ( save편 )

이번 프로젝트를 진행하면서 JPA와 Querydsl을 도입하였습니다. SI 회사에서 근무했을 당시에는 mybatis를 사용했었습니다. SI 프로젝트는 90%이상이 mybatis일 것입니다. 그리고 스타트업으로 이직한 후 첫 프로젝트에서도 역시 mybatis를 사용했습니다. 미리 공부해뒀다면 jpa를 썼을텐데... 아쉬운 마음에 학습하고 이번 프로젝트를 진행할 떄 도입하기로 결정이 났습니다. ( 드디어..! ) Repository를 이용하여 findById(), save(), 그외 등등.. 을 사용하였습니다. 혹시나 프로젝트 기술스택에 대해서 궁금해하시는 분들을 위해서 적어봅니다. - - Querydsl-jpa - p6spy ( log설정 ) - pinpoint ( 모니터링 ) - flyway ( 기술검토..

Develop/spring-data 2020.11.26

[javascript] '==', '===' 차이 ( 나의 삽질.. )

프로젝트를 진행하는 값이 없는 경우 ( falsy ) 를 체크하기 위한 함수를 생성하였습니다. 서버에서 받은 파라미터가 falsy인지 체크하는 함수를 만들었습니다. function isNull(value) { return value == null || value == undefined || value == ''; } 이제 서버에서 받은 파라미터를 위에서 생성한 메서드에 넣고 null 체크를 하고 jquery show(), hide() 처리를 하려고 했습니다. const response = data.data; const $detailElement = $("[name=detailName]"); // value = 0 값이 내려왔습니다. if (isNull(response.value) ) { $detailEl..

Daily Develop 2020.11.25

flyway. DB 형상관리 및 다양한 기능을 제공! 재택근무 시 유용해요! 2탄

이전 글 ( flyway. DB 형상관리 및 다양한 기능을 제공! 재택근무 시 유용해요! 1탄 )에서 flyway에 대해서 간단하게 알아보았습니다. 이번글에서는 실제 환경에서 어떻게 사용하는 지 소스기반으로 정리하겠습니다. 모든 소스는 github에 올려두었습니다. 요즘 코로나로 인해 재택근무가 많아지는 상황입니다. 저도 재택근무를 한번 해봤는데 집에서 로컬 db 환경으로 작업해야하는 상황이 있었습니다. 물론 슬랙으로 동료분들과 db 변경사항을 공유했지만 누락되는 내용도 있었고 각자 로컬 db 스키마 정보가 달라서 작업하는데 어려움이 있었습니다. 이럴경우 아주 유용한 것이 flyway입니다. ( 이전 글과 동일한 내용입니다. ) 소스와 함께 정리하도록 하겠습니다. 이 글에서 다루는 Flyway 사용 방법..

Develop/database 2020.11.24

이런 개발자가 될 것이다. 남들 때문에 스트레스 받지 말자!!

32살 개발자 마음의 변천사에 대해 정리하려합니다. 글을 작성하면서 나는 어떻게 살아왔고 어떻게 변해왔고 어떻게 살아갈지 저도 정리하는 시간을 가져보려고 합니다. 전 직장은 SI 회사였습니다. 좋은 스펙을 가지고 있지 않은 제가 선택할 수 있었던 회사의 폭은 매우 좁았습니다. 더군다나 C++을 하던 제가 오픈소스의 신세계를 맛보고 Java로 옮겼기에 나이도 어느정도 차있는데 신입이므로 취업하기도 힘들었습니다. 회사에 입사했을 때 정말 이클립스는 어떻게 쓰는거지? 서블렛? MVC? 이게 다 뭐지.. 하면서 멘탈이 산산조각나면서 회사를 출퇴근하던게 엊그제 같았습니다.지금도 너무나 부족합니다..직장 동료들은 전공자, 학원출신으로 어느정도 기본 지식을 가지고 시작했기에 너무 비교되고 자꾸 작아지기만 했습니다. ..

MindControl 2020.11.23
728x90
반응형