Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

파이썬 - PostgreSQL의 with 문을 사용한 경우 연결 개체 누수

psycopg2를 이용하는 경우,

파이썬 - PostgreSQL 환경 구성
; https://www.sysnet.pe.kr/2/0/13077

다음과 같은 같이 코딩하면,

def test_postgre():
    import psycopg2

    with psycopg2.connect(...[생략]...) as db:
        with db.cursor() as cursor:
            sql = "SELECT * FROM TestTable"
            cursor.execute(sql)

with로 사용한 db 연결 개체가 닫히지 않는 현상이 있습니다. 실제로 저 코드를 실행하는 웹 페이지를 방문한 후 PostgreSQL CLI를 통해 pg_stat_activity 테이블을 보면,

# /usr/bin/psql
psql (11.2 (Debian 11.2-1.pgdg90+1))
Type "help" for help.

root=# select client_addr, client_port from pg_stat_activity;
 client_addr    | client_port 
----------------+-------------
 192.168.100.50 |       33380
 192.168.100.50 |       37612
 192.168.100.50 |       59440
 192.168.100.50 |       40936
 192.168.100.50 |       48864
 192.168.100.50 |       41622
 192.168.100.50 |       47890
 192.168.100.50 |       33652
                |          -1
 172.17.0.1     |       41070
                |            

예제를 실행한 192.168.100.50 측에서의 연결 개체가 남아 있는 것을 볼 수 있습니다.




이에 대한 해답은 ^^;

How to Work with PostgreSQL in Python
; https://khashtamov.com/en/postgresql-with-python-and-psycopg2/

with와 함께 closing을 함께 써줘야 합니다.

def test_postgre():
    import psycopg2
    from contextlib import closing

    with closing(psycopg2.connect(...[생략]...)) as db:
        with db.cursor() as cursor:
            sql = "SELECT * FROM TestTable"
            cursor.execute(sql)

실제로 저렇게 처리한 후에는 pg_stat_activity가 조용해졌습니다. ^^

다른 db provider도 그런 식일까요? 일례로 제가 테스트한 mysql의 경우에는,

with MySQLdb.connect(...[생략]...) as conn:
    conn.encoding = 'utf8'

    with conn.cursor() as cursor:

    query = "SELECT * FROM mytable;"
    cursor.execute(query)

(closing 없이도) 연결 개체를 잘 정리합니다. 마찬가지로 pymysql도 with 구문이 적용됐습니다. 다른 예로는, sqlite3의 경우 아예 지원이 안 되었죠! 이러한 처리가 dbapi2 명세에서 지정하지 않아 그런 것인지는 모르겠지만 암튼 with에 대한 처리를 할 때는 꼭 문서를 확인하든가, 직접 테스트를 해보는 것이 좋겠습니다. ^^;




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/20/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
638정성태1/3/200927475.NET Framework: 119. WPF - 의존 속성 정의에서 XamlParseException 발생하는 예 [2]
637정성태1/1/200929851기타: 26. 2008년 인기 순위 정리
636정성태12/31/200825168.NET Framework: 118. 2진 검색을 이용한 리스트 정렬 삽입파일 다운로드1
635정성태12/29/200827946오류 유형: 66. 파일 암호화 오류 - Recovery policy configured for this system contains invalid recovery certificate
634정성태12/29/200842308기타: 25. 가상 키보드 관련 정리 [4]
633정성태12/20/200827570기타: 24. RMClock for x64 [2]
632정성태12/19/200836154기타: 23. D820 - 배터리 없이 바이오스 업데이트 방법 [2]파일 다운로드1
631정성태12/10/200845164VC++: 36. Detours 라이브러리를 이용한 Win32 API - Sleep 호출 가로채기 [3]
630정성태12/9/200825768.NET Framework: 117. WPF - TreeView에서 항목이 펼쳐질 때 Cursors.Wait 사용파일 다운로드1
629정성태12/7/200835250.NET Framework: 116. 소켓 연결 시간 제한
628정성태12/6/200823320.NET Framework: 115. Marshal 타입 관련 2가지 자원 해제 메서드파일 다운로드1
627정성태12/6/200826096VS.NET IDE: 58. VS.NET IDE 팁 - 커서 위치 이동 [1]
626정성태12/6/200826114오류 유형: 65. TF53018: The application tier XXXXXXX is attempting to connect to a data tier with an incompatible version
625정성태12/6/200826517오류 유형: 64. TFS 2008 SP1 설치 - MsiApplyMultiplePatches returned 0x643
624정성태12/5/200827526.NET Framework: 114. WPF 이벤트에 속한 핸들러 확인 [2]파일 다운로드1
623정성태12/4/200832021디버깅 기술: 22. VS.NET SP1 + .NET Framework 소스 코드 디버깅 [2]파일 다운로드1
622정성태12/1/200834302오류 유형: 63. WPF - XamlParseException 대응 방법 [2]
621정성태11/30/200826258Team Foundation Server: 27. TeamBuild + VDPROJ 셋업 프로젝트 [1]
620정성태11/30/200825059디버깅 기술: 21. 올바른 이벤트 예외 정보 출력
619정성태11/30/200825125디버깅 기술: 20. 예외 처리를 방해하는 WPF Modal 대화창파일 다운로드1
618정성태11/29/200825299.NET Framework: 113. 이벤트에 속한 이벤트 핸들러 확인파일 다운로드1
617정성태11/26/200832183.NET Framework: 112. How to Interop DISPPARAMS [2]파일 다운로드2
616정성태11/26/200825047디버깅 기술: 19. C++/CLI - F11 디버깅 시의 변수 초기화파일 다운로드1
615정성태11/9/200834610.NET Framework: 111. WPF - Window, UserControl 클래스 상속 [1]
614정성태11/9/200834436.NET Framework: 110. WPF - 전역 예외 처리 [4]파일 다운로드1
613정성태11/8/200823906.NET Framework: 109. WPF - SystemColors 색상표파일 다운로드1
... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...