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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13546정성태1/30/20243315Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20243096닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20243212오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20243281Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20243138오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20243372VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20243553Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
13539정성태1/26/20243660개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
13538정성태1/25/20244006닷넷: 2211. C# - NonGC(FOH) 영역에 .NET 개체를 생성파일 다운로드1
13537정성태1/24/20244122닷넷: 2210. C# - Native 메모리에 .NET 개체를 생성파일 다운로드1
13536정성태1/23/20244120닷넷: 2209. .NET 8 - NonGC Heap / FOH (Frozen Object Heap) [1]
13535정성태1/22/20244124닷넷: 2208. C# - GCHandle 구조체의 메모리 분석
13534정성태1/21/20243907닷넷: 2207. C# - SQL Server DB를 bacpac으로 Export/Import파일 다운로드1
13533정성태1/18/20244018닷넷: 2206. C# - TCP KeepAlive의 서버 측 구현파일 다운로드1
13532정성태1/17/20243999닷넷: 2205. C# - SuperSimpleTcp 사용 시 주의할 점파일 다운로드1
13531정성태1/16/20244013닷넷: 2204. C# - TCP KeepAlive에 새로 추가된 Retry 옵션파일 다운로드1
13530정성태1/15/20243565닷넷: 2203. C# - Python과의 AES 암호화 연동파일 다운로드1
13529정성태1/15/20243540닷넷: 2202. C# - PublishAot의 glibc에 대한 정적 링킹하는 방법
13528정성태1/14/20243671Linux: 68. busybox 컨테이너에서 실행 가능한 C++, Go 프로그램 빌드
13527정성태1/14/20243690오류 유형: 892. Visual Studio - Failed to launch debug adapter. Additional information may be available in the output window.
13526정성태1/14/20243765닷넷: 2201. C# - Facebook 연동 / 사용자 탈퇴 처리 방법
13525정성태1/13/20243556오류 유형: 891. Visual Studio - Web Application을 실행하지 못하는 IISExpress
13524정성태1/12/20243694오류 유형: 890. 한국투자증권 KIS Developers OpenAPI - GW라우팅 중 오류가 발생했습니다.
13523정성태1/12/20243379오류 유형: 889. Visual Studio - error : A project with that name is already opened in the solution.
13522정성태1/11/20243795닷넷: 2200. C# - HttpClient.PostAsJsonAsync 호출 시 "Transfer-Encoding: chunked" 대신 "Content-Length" 헤더 처리
13521정성태1/11/20243926닷넷: 2199. C# - 한국투자증권 KIS Developers OpenAPI의 WebSocket Ping, Pong 처리
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...