<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ko">
	<id>https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=Python_oracle_connection_pool</id>
	<title>Python oracle connection pool - 편집 역사</title>
	<link rel="self" type="application/atom+xml" href="https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=Python_oracle_connection_pool"/>
	<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;action=history"/>
	<updated>2026-05-19T14:51:34Z</updated>
	<subtitle>이 문서의 편집 역사</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1860&amp;oldid=prev</id>
		<title>2025년 6월 24일 (화) 03:28에 Devcafe님의 편집</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1860&amp;oldid=prev"/>
		<updated>2025-06-24T03:28:33Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 6월 24일 (화) 12:28 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l149&quot;&gt;149번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;149번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	•	커넥션 풀 재시도 로직&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	•	커넥션 풀 재시도 로직&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	•	비동기(asyncio) 구조로 전환&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;	•	비동기(asyncio) 구조로 전환&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[category:python]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[category:oracle]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1421&amp;oldid=prev</id>
		<title>2025년 5월 20일 (화) 21:30에 Devcafe님의 편집</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1421&amp;oldid=prev"/>
		<updated>2025-05-20T21:30:31Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 5월 21일 (수) 06:30 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot;&gt;1번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;1번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;좋습니다!&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;요구하신 구조에 맞춰 다음과 같이 수정하겠습니다:&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;⸻&lt;/del&gt;&lt;/div&gt;&lt;/td&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-added&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;요구사항 요약&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;요구사항 요약&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1419&amp;oldid=prev</id>
		<title>Devcafe: Devcafe님이 Python oracle connetion pool 문서를 Python oracle connection pool 문서로 이동했습니다</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1419&amp;oldid=prev"/>
		<updated>2025-05-20T21:29:42Z</updated>

		<summary type="html">&lt;p&gt;Devcafe님이 &lt;a href=&quot;/w/Python_oracle_connetion_pool&quot; class=&quot;mw-redirect&quot; title=&quot;Python oracle connetion pool&quot;&gt;Python oracle connetion pool&lt;/a&gt; 문서를 &lt;a href=&quot;/w/Python_oracle_connection_pool&quot; title=&quot;Python oracle connection pool&quot;&gt;Python oracle connection pool&lt;/a&gt; 문서로 이동했습니다&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 5월 21일 (수) 06:29 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;ko&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(차이 없음)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1418&amp;oldid=prev</id>
		<title>Devcafe: 새 문서: 좋습니다! 요구하신 구조에 맞춰 다음과 같이 수정하겠습니다:  ⸻  요구사항 요약 	1.	DB 접속 정보는 외부 파일에서 읽음 (예: db_config.json) 	2.	여러 개의 DB에 각각 Connection Pool을 생성하여 관리 	3.	각 DB를 식별자(db_key)로 구분해 사용 	4.	import 시 자동으로 모든 DB 접속 준비 	5.	execute(db_key, query)로 쿼리 실행 → 자동 커넥션 반납  ⸻  ✅ 1. 외부 설정 파일 (예: db_config.json...</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=Python_oracle_connection_pool&amp;diff=1418&amp;oldid=prev"/>
		<updated>2025-05-20T21:27:45Z</updated>

		<summary type="html">&lt;p&gt;새 문서: 좋습니다! 요구하신 구조에 맞춰 다음과 같이 수정하겠습니다:  ⸻  요구사항 요약 	1.	DB 접속 정보는 외부 파일에서 읽음 (예: db_config.json) 	2.	여러 개의 DB에 각각 Connection Pool을 생성하여 관리 	3.	각 DB를 식별자(db_key)로 구분해 사용 	4.	import 시 자동으로 모든 DB 접속 준비 	5.	execute(db_key, query)로 쿼리 실행 → 자동 커넥션 반납  ⸻  ✅ 1. 외부 설정 파일 (예: db_config.json...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;새 문서&lt;/b&gt;&lt;/p&gt;&lt;div&gt;좋습니다!&lt;br /&gt;
요구하신 구조에 맞춰 다음과 같이 수정하겠습니다:&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
요구사항 요약&lt;br /&gt;
	1.	DB 접속 정보는 외부 파일에서 읽음 (예: db_config.json)&lt;br /&gt;
	2.	여러 개의 DB에 각각 Connection Pool을 생성하여 관리&lt;br /&gt;
	3.	각 DB를 식별자(db_key)로 구분해 사용&lt;br /&gt;
	4.	import 시 자동으로 모든 DB 접속 준비&lt;br /&gt;
	5.	execute(db_key, query)로 쿼리 실행 → 자동 커넥션 반납&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
✅ 1. 외부 설정 파일 (예: db_config.json)&lt;br /&gt;
&lt;br /&gt;
{&lt;br /&gt;
  &amp;quot;DB1&amp;quot;: {&lt;br /&gt;
    &amp;quot;user&amp;quot;: &amp;quot;user1&amp;quot;,&lt;br /&gt;
    &amp;quot;password&amp;quot;: &amp;quot;pass1&amp;quot;,&lt;br /&gt;
    &amp;quot;dsn&amp;quot;: &amp;quot;host1:1521/service1&amp;quot;&lt;br /&gt;
  },&lt;br /&gt;
  &amp;quot;DB2&amp;quot;: {&lt;br /&gt;
    &amp;quot;user&amp;quot;: &amp;quot;user2&amp;quot;,&lt;br /&gt;
    &amp;quot;password&amp;quot;: &amp;quot;pass2&amp;quot;,&lt;br /&gt;
    &amp;quot;dsn&amp;quot;: &amp;quot;host2:1521/service2&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
✅ 2. 모듈 코드: oracle_pool.py&lt;br /&gt;
&lt;br /&gt;
# oracle_pool.py&lt;br /&gt;
&lt;br /&gt;
import cx_Oracle&lt;br /&gt;
import json&lt;br /&gt;
import os&lt;br /&gt;
&lt;br /&gt;
class OracleMultiPool:&lt;br /&gt;
    _instance = None&lt;br /&gt;
&lt;br /&gt;
    def __new__(cls, *args, **kwargs):&lt;br /&gt;
        if not cls._instance:&lt;br /&gt;
            cls._instance = super(OracleMultiPool, cls).__new__(cls)&lt;br /&gt;
        return cls._instance&lt;br /&gt;
&lt;br /&gt;
    def __init__(self, config_path=&amp;#039;db_config.json&amp;#039;, min=2, max=5, increment=1):&lt;br /&gt;
        if hasattr(self, &amp;quot;_initialized&amp;quot;) and self._initialized:&lt;br /&gt;
            return&lt;br /&gt;
        self.pools = {}&lt;br /&gt;
        self._initialized = False&lt;br /&gt;
&lt;br /&gt;
        # JSON 설정 읽기&lt;br /&gt;
        if not os.path.exists(config_path):&lt;br /&gt;
            print(f&amp;quot;[Error] DB config file &amp;#039;{config_path}&amp;#039; not found.&amp;quot;)&lt;br /&gt;
            return&lt;br /&gt;
&lt;br /&gt;
        try:&lt;br /&gt;
            with open(config_path, &amp;#039;r&amp;#039;) as f:&lt;br /&gt;
                config = json.load(f)&lt;br /&gt;
        except Exception as e:&lt;br /&gt;
            print(f&amp;quot;[Error] Failed to load DB config: {e}&amp;quot;)&lt;br /&gt;
            return&lt;br /&gt;
&lt;br /&gt;
        # 각 DB에 대해 커넥션 풀 생성&lt;br /&gt;
        for db_key, db_info in config.items():&lt;br /&gt;
            try:&lt;br /&gt;
                pool = cx_Oracle.SessionPool(&lt;br /&gt;
                    user=db_info[&amp;quot;user&amp;quot;],&lt;br /&gt;
                    password=db_info[&amp;quot;password&amp;quot;],&lt;br /&gt;
                    dsn=db_info[&amp;quot;dsn&amp;quot;],&lt;br /&gt;
                    min=min,&lt;br /&gt;
                    max=max,&lt;br /&gt;
                    increment=increment,&lt;br /&gt;
                    encoding=&amp;quot;UTF-8&amp;quot;&lt;br /&gt;
                )&lt;br /&gt;
                self.pools[db_key] = pool&lt;br /&gt;
                print(f&amp;quot;[Connected] Pool created for {db_key}&amp;quot;)&lt;br /&gt;
            except cx_Oracle.Error as e:&lt;br /&gt;
                print(f&amp;quot;[Error] Failed to connect {db_key}: {e}&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
        self._initialized = True&lt;br /&gt;
&lt;br /&gt;
    def execute(self, db_key, query, params=None, fetch=True):&lt;br /&gt;
        if db_key not in self.pools:&lt;br /&gt;
            print(f&amp;quot;[Error] No connection pool for &amp;#039;{db_key}&amp;#039;&amp;quot;)&lt;br /&gt;
            return None&lt;br /&gt;
&lt;br /&gt;
        conn = None&lt;br /&gt;
        try:&lt;br /&gt;
            conn = self.pools[db_key].acquire()&lt;br /&gt;
            cursor = conn.cursor()&lt;br /&gt;
            cursor.execute(query, params or {})&lt;br /&gt;
            result = cursor.fetchall() if fetch else None&lt;br /&gt;
            cursor.close()&lt;br /&gt;
            return result&lt;br /&gt;
        except cx_Oracle.Error as e:&lt;br /&gt;
            print(f&amp;quot;[{db_key}] Query error: {e}&amp;quot;)&lt;br /&gt;
            return None&lt;br /&gt;
        finally:&lt;br /&gt;
            if conn:&lt;br /&gt;
                self.pools[db_key].release(conn)&lt;br /&gt;
&lt;br /&gt;
    def close_all(self):&lt;br /&gt;
        for db_key, pool in self.pools.items():&lt;br /&gt;
            pool.close()&lt;br /&gt;
            print(f&amp;quot;[Closed] Pool for {db_key}&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
✅ 3. 사용 예: main.py&lt;br /&gt;
&lt;br /&gt;
from oracle_pool import OracleMultiPool&lt;br /&gt;
&lt;br /&gt;
# 클래스 인스턴스 생성 시 모든 DB에 접속&lt;br /&gt;
db = OracleMultiPool(config_path=&amp;#039;db_config.json&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
# DB1에 쿼리 실행&lt;br /&gt;
result = db.execute(&amp;quot;DB1&amp;quot;, &amp;quot;SELECT SYSDATE FROM dual&amp;quot;)&lt;br /&gt;
print(&amp;quot;[DB1] Result:&amp;quot;, result)&lt;br /&gt;
&lt;br /&gt;
# DB2에 쿼리 실행&lt;br /&gt;
result = db.execute(&amp;quot;DB2&amp;quot;, &amp;quot;SELECT USER FROM dual&amp;quot;)&lt;br /&gt;
print(&amp;quot;[DB2] Result:&amp;quot;, result)&lt;br /&gt;
&lt;br /&gt;
# 모든 커넥션 풀 종료&lt;br /&gt;
db.close_all()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
✅ 확장성 &amp;amp; 특징 요약&lt;br /&gt;
&lt;br /&gt;
항목	설명&lt;br /&gt;
DB 추가	db_config.json에 항목만 추가하면 자동 반영&lt;br /&gt;
쿼리 실행	db.execute(&amp;quot;DB1&amp;quot;, query) 식으로 간단히 사용&lt;br /&gt;
재사용	싱글톤 구조로 모든 곳에서 동일 인스턴스 사용&lt;br /&gt;
커넥션 자동 관리	acquire → execute → release 자동 처리&lt;br /&gt;
설정 분리	민감한 정보는 코드 외부 JSON으로 분리&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
⸻&lt;br /&gt;
&lt;br /&gt;
필요하면 다음도 지원 가능합니다:&lt;br /&gt;
	•	INSERT/UPDATE 트랜잭션 (commit 자동/수동)&lt;br /&gt;
	•	커넥션 풀 재시도 로직&lt;br /&gt;
	•	비동기(asyncio) 구조로 전환&lt;/div&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
</feed>