>백엔드 개발 >Golang >Go의 `database/sql`이 직접 PostgreSQL 쿼리보다 훨씬 느린 이유는 무엇입니까?

Go의 `database/sql`이 직접 PostgreSQL 쿼리보다 훨씬 느린 이유는 무엇입니까?

DDD
DDD원래의
2024-11-18 02:52:02812검색

Why is `database/sql` in Go so much slower than direct PostgreSQL queries?

데이터베이스/sql 쿼리와 직접 데이터베이스 쿼리 간의 쿼리 실행 시간 불일치

Go 애플리케이션에서는 상당한 시간 차이가 관찰됩니다. psql을 통해 PostgreSQL 데이터베이스를 직접 쿼리하는 경우와 데이터베이스/sql 패키지를 사용하는 경우를 비교합니다. 동일한 쿼리를 실행하는 동안 Database/sql은 약 24ms가 걸리는 반면 psql은 단 1ms 만에 쿼리를 처리한다는 것을 알 수 있습니다.

차이점 이해:

The 불일치는 두 가지 주요 요인에 기인할 수 있습니다:

1. 데이터베이스 연결 생성 및 관리:

  • psql: psql을 사용하여 직접 쿼리를 실행하면 열려 있는 상태로 유지되는 데이터베이스에 대한 단일 활성 연결이 설정됩니다. 세션 기간 동안.
  • database/sql: 이와 대조적으로, Database/sql은 연결 풀은 데이터베이스에 대한 여러 연결을 관리합니다. 처음에는 풀에 활성 연결이 없습니다. 데이터베이스/SQL을 사용하여 쿼리를 실행하면 풀에서 새로운 연결을 설정합니다.

2. 준비된 명령문 실행:

  • psql: psql을 통해 쿼리를 실행하는 경우 일반적으로 매개변수가 없는 "간단한 쿼리"입니다.
  • database/sql: 기본적으로 Database/sql은 준비된 문을 사용합니다. 쿼리에 매개변수가 없지만 쿼리에서 $1을 사용하면 데이터베이스/sql이 준비된 문을 생성하고 실행합니다.

쿼리 성능 최적화:

시간 차이를 최소화하려면 다음 최적화를 고려하세요.

1. 연결 풀 초기화:

  • 데이터베이스/SQL 연결을 초기화한 후 즉시 db.Ping() 메서드를 사용하여 풀에 하나 이상의 연결이 열려 있는지 확인하세요. 이렇게 하면 초기 연결 설정의 지연 시간이 줄어듭니다.

2. 연결 해제:

  • db.Query를 사용하여 쿼리를 실행한 후 행.Close() 메서드를 호출하여 연결을 풀로 다시 해제합니다. 그렇지 않으면 연결이 열린 상태로 유지되어 잠재적인 리소스 유출이 발생할 수 있습니다.

3. 가능한 경우 간단한 쿼리를 사용하세요.

  • 쿼리에 매개변수화가 필요하지 않은 경우 db.Query에서 직접 문자열로 지정하세요. 이렇게 하면 준비된 문을 생성하고 실행하는 오버헤드가 방지됩니다.

이러한 최적화를 구현하면 데이터베이스/SQL을 사용하는 쿼리 실행 시간을 대폭 줄이고 직접 데이터베이스 쿼리 성능에 더 가까워질 수 있습니다.

위 내용은 Go의 `database/sql`이 직접 PostgreSQL 쿼리보다 훨씬 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.