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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  188  189  [190]  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
303정성태7/20/200620987Team Foundation Server: 12. 사용자 계정 재생성에 따른 Version Control 영향
302정성태8/21/200622860Team Foundation Server: 11. TFS Team Build와 VC++ Project 설정
299정성태7/23/200622538개발 환경 구성: 5. VMWare - VM 생성 화면 캡쳐
300정성태7/15/200627961    답변글 개발 환경 구성: 5.1. VMWare 오류 유형 - The handle is invalid.
301정성태7/18/200622691    답변글 개발 환경 구성: 5.2. VMWare - 사용 후기.
298정성태7/14/200622377개발 환경 구성: 4. VMWare Server를 64bit 운영체제에 설치 시 주의 사항 [2]
296정성태7/10/200631632.NET Framework: 73. [ASP.NET] HTC(DHTML Control Behavior)를 WebResource.axd로 제공하는 방법 [3]
295정성태7/1/200625006VC++: 25. Microsoft National Language Support Downlevel APIs 1.0 사용 방법파일 다운로드1
294정성태6/30/200621506.NET Framework: 72. XSDObjectGen.EXE 기능 개선
293정성태6/29/200623380Team Foundation Server: 10. TFS 버전 컨트롤(TFVC)에 참여시킨 프로젝트의 로컬 경로를 옮기는 방법
290정성태6/26/200620738Team Foundation Server: 9. HTTPS를 통한 Team Server 접근 - 두 번째 이야기 [1]
291정성태6/26/200622139    답변글 Team Foundation Server: 9.1. [선행 작업] HTTPS 를 통한 Team Server 접근 - 두번째 이야기 [1]
292정성태6/26/200621735    답변글 Team Foundation Server: 9.2. TF30177 오류 발생
307정성태8/3/200623706    답변글 Team Foundation Server: 9.3. Team Server 접근 이름을 바꾸는 방법 [1]파일 다운로드1
308정성태2/18/200723449        답변글 Team Foundation Server: 9.4. Team Server HTTPS 접근 완료. ^^ [1]
288정성태6/26/200637930오류 유형: 10. error MSB6006: "aspnet_merge.exe" exited with code 1
286정성태6/23/200625889웹: 4. 웹 사이트 식별자(Identifier) 값 변경
285정성태6/20/200626280오류 유형: 9. [TFS] Report 관련 서비스를 조회할 때 rsErrorImpersonatingUser 오류 메시지 발생 [1]
284정성태6/19/200623911VS.NET IDE: 40. FxCop - IDE 에서 제공해 주는 SuppressMessage 코드
283정성태1/19/200725256Team Foundation Server: 8. 소스 세이프에서 TFS SourceControl 로 마이그레이션 [2]
279정성태12/27/200631227개발 환경 구성: 3. VS.NET 원격 디버깅 [1]
280정성태6/12/200630153    답변글 개발 환경 구성: 3.1. VS.NET 2003 원격 디버깅 설정
281정성태8/11/200631630    답변글 개발 환경 구성: 3.2. VS.NET 2005 원격 디버깅 설정
315정성태8/11/200632260        답변글 개발 환경 구성: 3.3. VS.NET 2005 원격 디버깅 설정 - ASP.NET F5 디버깅
278정성태6/11/200628418오류 유형: 8. [Outlook] 0x8004011D 에러 - "Exchange over the Internet" 환경
276정성태6/7/200621727Team Foundation Server: 7. 외부 빌드 머신 구성
... 181  182  183  184  185  186  187  188  189  [190]  191  192  193  194  195  ...