목차
connection 기본 연결 풀 예제
? 키 포인트 설명
1. SimpleConnectionPool 매개 변수
2. 연결을 얻고 해제하십시오
3. 스레드 안전
? 안전한 사용법 (컨텍스트 관리자와 함께)
⚠️ notes
? 마지막으로 : 연결 풀을 닫으십시오
백엔드 개발 파이썬 튜토리얼 Python psycopg2 연결 풀 예제

Python psycopg2 연결 풀 예제

Jul 28, 2025 am 03:01 AM
python Psycopg2

psycopg2.pool.simpleconnectionpool을 사용하여 데이터베이스 연결을 효과적으로 관리하고 빈번한 연결 생성 및 파괴로 인한 성능 오버 헤드를 피하십시오. 1. 연결 풀을 만들 때 연결 풀이 성공적으로 초기화되도록 최소 및 최대 연결 및 데이터베이스 연결 매개 변수를 지정하십시오. 2. getConn ()을 통해 연결을 가져 와서 putconn ()을 사용하여 데이터베이스 작업을 실행 한 후 풀에 연결을 반환하십시오. 끊임없이 Conn.Close () 호출 금지됩니다. 3. SimpleConnectionPool은 스레드 안전이며 다중 스레드 환경에 적합합니다. 4. 컨텍스트 관리자와 함께 컨텍스트 관리자를 구현하여 예외적으로 연결을 올바르게 반환 할 수 있는지 확인하는 것이 좋습니다. 5. 연결 풀은 글로벌 싱글 톤으로 사용되어야하며 프로그램이 종료되기 전에 CloseAll ()을 호출해야합니다. 이 솔루션은 중소형 응용 분야에 적합하며 대형 서비스는 SQLALCHEMY 또는 ASYNCPG를 고려할 수 있습니다.

Python psycopg2 연결 풀 예제

psycopg2 의 연결 풀을 사용하면 데이터베이스 연결을 효과적으로 관리하고 빈번한 연결 생성 및 파괴로 인한 성능 오버 헤드를 피할 수 있습니다. psycopg2 자체는 연결 풀링 기능을 제공하지 않지만 공식적으로 권장되는 psycopg2.pool 모듈 (실제로 psycopg2 패키지의 pool 하위 모듈)은 threading 에 따라 연결 풀링을 안전하게 관리 할 수 있습니다.

Python psycopg2 연결 풀 예제

다음은 psycopg2.pool.SimpleConnectionPool 사용하는 실질적인 예입니다.


connection 기본 연결 풀 예제

 psycopg2를 가져옵니다
psycopg2 가져 오기 풀에서

# 연결 풀 만들기 시도 :
    Connection_pool = psycopg2.pool.simpleconnectionpool (
        1, # 최소 연결 수 10, # 최대 연결 수 호스트 = "LocalHost",
        Database = "Your_db_name",
        user = "your_username",
        password = "your_password",
        포트 = "5432"
    ))

    Connection_pool 인 경우 :
        Print ( "연결 풀 생성 성공")

E로 예외를 제외하고 :
    print ( "연결 풀 생성 실패 :", e)

# 연결 풀에서 연결 받기 Conn = Connection_Pool.getConn ()

Conn :
    노력하다:
        커서 = conn.cursor ()
        cursor.execute ( "select version ();")
        db_version = cursor.fetchone ()
        print ( "데이터베이스 버전 :", db_version)

        # 거래 제출 (쓰기 작업 인 경우)
        conn.commit ()

    E로 예외를 제외하고 :
        print ( "데이터베이스 작동 오류 :", e)
        conn.rollback ()
    마지막으로:
        cursor.close ()
        # 연결 풀에 연결을 반환합니다. Connection_POOL.PUTCONN (CONN)
또 다른:
    인쇄 ( "연결 풀에서 연결을 얻을 수 없음")

# 프로그램 끝에서 모든 연결을 닫습니다 # connection_pool.closeall () # 일반적으로 응용 프로그램이 종료 될 때 호출됩니다.

? 키 포인트 설명

1. SimpleConnectionPool 매개 변수

  • MinConn : 최소 연결 수 (스타트 업에서 생성 된 연결 수)
  • MaxConn : 최대 연결 수 (연결 풀이 확장 할 수있는 연결 수)
  • 나머지 매개 변수는 표준 psycopg2.connect() 매개 변수 (예 : 호스트, 사용자, 암호 등)입니다.

2. 연결을 얻고 해제하십시오

  • getconn() 사용하여 연결을 얻습니다 (자동으로 작성 또는 재사용)
  • putconn(conn) 사용하여 수영장에 연결을 반환하십시오 (폐쇄되지 않음!)
  • conn.close() 수동으로 호출하지 마십시오. 그렇지 않으면 연결이 진정으로 닫히면 연결 풀이 실패하게됩니다.

3. 스레드 안전

  • SimpleConnectionPool 은 스레드 안전이며 다중 스레드 환경에 적합합니다
  • 각 스레드는 연결을 독립적으로 얻고 반환해야합니다

? 안전한 사용법 (컨텍스트 관리자와 함께)

컨텍스트 관리자를 캡슐화하여 연결이 자동으로 반환되도록 할 수 있습니다.

Python psycopg2 연결 풀 예제
 ContextLib import ContextManager에서

@contextManager
def get_db_connection () :
    conn = connection_pool.getConn ()
    노력하다:
        CONT를 산출하십시오
    마지막으로:
        Connection_Pool.putConn (Conn)

# get_db_connection ()과 함께 Conn으로 예제를 사용하십시오.
    커서 = conn.cursor ()
    cursor.execute ( "current_user;")
    print (cursor.fetchone ())
    cursor.close ()

이러한 방식으로 예외가 발생하더라도 연결이 올바르게 반환됩니다.


⚠️ notes

  • 연결 풀 객체는 글로벌 또는 싱글 톤이어야합니다. 반복적 인 생성을 피하십시오.
  • 응용 프로그램이 종료되어 모든 연결을 출시 할 때 connection_pool.closeall() 호출하십시오.
  • 동시성이 높은 시나리오에서는 데이터베이스 연결의 한계를 초과하지 않도록 합리적인 maxconn 설정하는 데주의를 기울이십시오.
  • Flask/Django와 같은 프레임 워크를 사용하는 경우 응용 프로그램 라이프 사이클과 함께 연결 풀을 관리하는 것이 좋습니다.

? 마지막으로 : 연결 풀을 닫으십시오

 # connection_pool.closeall () 프로그램이 종료되기 전에
인쇄 ( "모든 연결이 닫힌")

기본적으로 그게 다야. 이 예제는 중소형 응용 프로그램에 적합합니다. 대규모 서비스 인 경우 SQLAlchemy psycopg2 연결 풀링 또는 asyncpg 와 같은 비동기 솔루션을 사용하는 것이 좋습니다.

Python psycopg2 연결 풀 예제

위 내용은 Python psycopg2 연결 풀 예제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

파이썬에서 메모리 누출을 디버깅하기위한 일반적인 전략은 무엇입니까? 파이썬에서 메모리 누출을 디버깅하기위한 일반적인 전략은 무엇입니까? Aug 06, 2025 pm 01:43 PM

USETRACEMALLOCTOTRACKMORYALLOCATIONS 및 HIGH-MEMORYLINES; 2. MONITOROBJECTCOUNTSSWITHGCANDOBJGRAPHTECTETECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTESTEBSEPS;

파이썬에서 Timezones와 함께 일하는 방법? 파이썬에서 Timezones와 함께 일하는 방법? Aug 05, 2025 pm 04:53 PM

usezoneinfoforpython3.9 thecreateTimezone-awaredateTimes and convertBetweTimezoneswithastimezone (); 2. forpyThon3.6–3.8, usepytzwithlocalize () toavoiddsterrors;

Python을 사용하여 Excel에서 웹 양식으로 데이터 입력을 자동화하는 방법은 무엇입니까? Python을 사용하여 Excel에서 웹 양식으로 데이터 입력을 자동화하는 방법은 무엇입니까? Aug 12, 2025 am 02:39 AM

Python을 사용하여 Excel 데이터를 웹 양식으로 채우는 방법은 다음과 같습니다. 먼저 Pandas를 사용하여 Excel 데이터를 읽은 다음 Selenium을 사용하여 브라우저를 제어하여 양식을 자동으로 채우고 제출합니다. 특정 단계에는 팬더, OpenPyxL 및 Selenium 라이브러리 설치, 해당 브라우저 드라이버 다운로드, 팬더를 사용하여 Data.xlsx 파일의 이름, 이메일, 전화 및 기타 필드를 읽고 셀레늄을 통해 브라우저를 시작하여 대상 웹 페이지를 열고, 웹 드라이버 컨텐츠를 찾아서 데이터를 가로 채우고, 예외적 인 컨텐츠를 사용하고, 예외적 인 컨텐츠를 추가하고, 예외적 인 컨텐츠를 가득 채우고, 예외적 인 컨텐츠를 채우고, 데이터를 채우고, 데이터를 채우고, 데이터를 가득 채우고, 예외적 인 컨텐츠를 작성하고, 데이터를 채우고, 데이터를 가득 채우고, 데이터를 가로 지르고, 데이터를 가득 채우고, 데이터를 채우고, 예외적 인 컨텐츠를 가득 채우고, 예외적 인 것으로 모든 데이터 라인을 루프로 양식하고 처리합니다.

cryptocurrency 거래에서 감정 분석이란 무엇입니까? cryptocurrency 거래에서 감정 분석이란 무엇입니까? Aug 14, 2025 am 11:15 AM

목차 cryptocurrency 거래에서 감정 분석이란 무엇입니까? cryptocurrency 투자에서 감정 분석의 주요 소스에서 감정 분석이 중요한 이유 a. 소셜 미디어 플랫폼 b. 뉴스 미디어 c. 감정 분석 및 기술을위한 도구 : 감정 분석에서 일반적으로 사용되는 도구 : 기술 채택 : 거래 전략에 거래가 사용하는 방법 : 전략 예 : BTC 거래 시나리오 시나리오 설정 : 감정 신호 : 결정 : 결과 : Smarter Cryptocurrency Trade and Trading Spectorment에서 감정을 사용하여 감정을 사용하여 감정을 사용하여 감정을 사용한 감정 분석의 한계 및 위험이 증가하고 있습니다. Hamid의 최근 2025 년 연구

VSCODE에서 Python Virtual Environment를 설정하는 방법 VSCODE에서 Python Virtual Environment를 설정하는 방법 Aug 06, 2025 am 02:30 AM

가상 환경 생성 : 프로젝트 폴더에서 Python-Mvenvvenv를 실행하십시오. 2. 가상 환경 활성화 : Windows는 Venv \ Scripts \ Activate를 사용합니다. MacOS/Linux는 Sourcevenv/bin/activate를 사용합니다. 3. VSCODE에서 프로젝트를 열고 Ctrl Shift P를 눌러 Python 통역사를 선택하고 가상 환경에서 통역사를 지정하십시오. 4. 효과적인 지 확인 : importsys; print (sys.Executable)를 실행하면 출력 경로가 VenV 폴더를 가리 려야합니다. 5. 선택적 구성 : 설정에서 python.terminal.a를 활성화합니다

파이썬 클래스 내에서 사용자 정의 반복기를 구현하는 방법은 무엇입니까? 파이썬 클래스 내에서 사용자 정의 반복기를 구현하는 방법은 무엇입니까? Aug 06, 2025 pm 01:17 PM

정의 __ () toreturntheiteratorobject, 일반적으로 selforaseparateiteratorinstance

Python에서 JSON 파일을 인쇄하는 방법은 무엇입니까? Python에서 JSON 파일을 인쇄하는 방법은 무엇입니까? Aug 07, 2025 pm 12:10 PM

JSON 파일을 아름답게하고 인쇄하려면 JSON 모듈의 Indent 매개 변수를 사용해야합니다. 특정 단계는 다음과 같습니다. 1. JSON.LOAD ()를 사용하여 JSON 파일 데이터를 읽습니다. 2. json.dump ()를 사용하고 4 또는 2로 계약을 설정하여 새 파일에 쓰면 형식화 된 JSON 파일을 생성하고 아름다운 인쇄를 완료 할 수 있습니다.

파이썬에서 인덱스를 사용하여 열거적으로 루프를 사용하는 방법 파이썬에서 인덱스를 사용하여 열거적으로 루프를 사용하는 방법 Aug 11, 2025 pm 01:14 PM

시퀀스를 가로 지르고 인덱스에 액세스 해야하는 경우 enumerate () 함수를 사용해야합니다. 1. enumerate ()는 자동으로 인덱스와 값을 제공하며, 이는 범위 (len (시퀀스))보다 간결합니다. 2. 시작 = 1과 같은 시작 매개 변수를 통해 시작 인덱스를 지정하여 1 기반 카운트를 달성 할 수 있습니다. 3. 첫 번째 항목을 건너 뛰거나 루프 수를 제한하거나 출력을 형식화하는 등 조건부 로직과 함께 사용할 수 있습니다. 4. 목록, 문자열 및 튜플과 같은 반복 가능한 객체에 적용 할 수 있으며 지원 요소 포장 풀기; 5. 코드 가독성을 향상시키고 카운터를 수동으로 관리하지 않고 오류를 줄입니다.

See all articles