inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

querydsl와 jdbctemplate 의 성능 비교 질문입니다.

1054

이동하

작성한 질문수 1

1

안녕하세요 김영한님,

querydsl 강의를 수강중인 학생입니다.

수강중에 문득 querydsl 은 동적으로 query 를 만들어주는 도구이다 보니

jdbctemplate 와 querydsl 간의 성능에 따른 차이가 있을것으로 생각되어 검색을 해보았습니다.

아래의 stackover flow 에 기재된 내용으로는 약 6배 정도 차이가 난다고 적혀있는데요

실무에서 이정도의 성능적인 차이가 발생하는지 궁금합니다.

https://stackoverflow.com/questions/38123217/performance-tests-between-querydsl-sql-vs-jdbctemplate

만약에 이렇게 성능적으로 차이가 많이 발생하게 된다면

실제 service 단계에서도 서버의 메모리나 확장에 관해서도 많은 리소스가 추가로 투입이 되어야할것 같습니다.

최근들어 쿠버네티스를 통해서 이러한 성능적이슈를 효율적으로 관리한다고 귓동냥으로 듣기는 했습니다.

저의 생각으로는

휴먼리소스를 투입해서 jdbctemplate 으로 코딩 할것인가 아니면 자본을 투입하여 문제를 해결할것인가의 문제로 보여 어떤것에 가치를 두냐에따라 답이 다른것같습니다.

이러한 jpa, jdbctemplate 의 성능적인 관점에서 김영한님 생각이 궁금합니다.

약간은 수업의 방향에 어긋나는것 같은 질문이라 조심스럽습니다...

(ps. jpa 와 querydsl 의 성능을 비교하게 비슷할까요..? )

querydsl의성능 java JPA

답변 1

5

김영한

안녕하세요. 동하님 좋은 질문입니다.

결론부터 말씀드리면 실무에서 성능 차이는 거의 0에 가깝습니다.

왜냐하면 암달의 법칙 때문이지요.

실무에서 성능 지연이 있는 대부분의 경우는 애플리케이션 메모리 영역의 문제가 아니라 DB의 문제입니다.

예를들어서 상황에 따라 다르겠지만 전체 시간이 100ms가 걸린다고 하면

애플리케이션에서 차지하는 비중이 10ms 정도 되고, DB나 네트워크에서 차지하는 비중이 90ms가 됩니다.

애플리케이션 메모리의 속도를 50% 줄여도 5ms 밖에 절약이 안되는 것이지요.

따라서 실무에서는 대부분 네트워크나 데이터베이스 속도에 성능이 좌우되고, 애플리케이션 메모리에서 동작하는 기능은 거의 영향을 주지 않습니다. (실제로는 말씀드린 예제보다 훨씬 더 데이터베이스에 영향을 받습니다.)

그래서 애플리케이션 메모리나 CPU는 많이 사용하더라도, 개발을 더 생산적으로 그리고 효율적으로 할 수 있는 방법이 중요합니다.

그리고 성능 튜닝의 경우 정말 많은 사용자가 사용하는 특정 지점을 대상으로 일부 튜닝을 하는 것이 좋습니다.

도움이 되셨길 바래요.

SpringBoot 4.X에서의 Querydsl 설정

0

74

2

querydsl 오픈소스에 대한 질문

0

69

1

예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?

0

108

1

Querydsl 6.X버전에 대해서 어떻게 생각하시나요?

0

312

2

여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요

1

68

1

fetchResults()는 더이상 권장되지 않는다는데 맞나요?

0

159

1

querydsl sum() 메서드 없어요.

0

157

2

build 디렉터리 생성

0

135

2

자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?

0

113

2

현재 Querydsl에서 from절 서브쿼리를 지원하나요?

0

88

1

오타 제보 드립니다.

0

70

2

벌크 연산과 flush, clear

0

76

1

Run As Intellij 로 변경시 Q타입 import 불가

0

87

1

QHello import하기 문제 발생

0

147

2

등록된 함수 보는법(H2Dialect) 질문

0

68

2

5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의

1

195

2

[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??

1

200

1

querydsl 설정 문제

0

222

2

quey dsl 설정부분

0

157

2

count 쿼리 관련 질문입니다!

0

74

1

stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.

0

89

1

답변부탁드리겠습니다.

0

89

2

(OrderSpecifier)관련 내용 어디있을가요

0

64

1

중급문법 벌크연산에서

0

81

2