91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

用sqlalchemy構建Django連接池的實例

發布時間:2020-09-23 01:18:55 來源:腳本之家 閱讀:383 作者:pushiqiang 欄目:開發技術

都知道django每次請求都會連接數據庫和釋放數據庫連接。Django為每個請求使用新的數據庫連接。一開始這個方法行得通。然而隨著服務器上的負載的增加,創建/銷毀連接數據庫開始花大量的時間。要避免這個,你可以使用數據庫連接池,這里使用SQLAlchemy的連接池。使Django持久化數據庫連接。

但這種方法會改變django的代碼。對框架有侵入

方法 1

實現方法如下:

把django/db/backends/mysql文件夾全部拷貝出來,放在項目的一個libs/mysql下面,然后修改base.py文件。

或者把django/db/backends/mysql文件夾在django/db/backends/下面復制為mysql_pool文件夾,將base.py中所以import中的mysql替換為mysql_pool,這樣可以直接在settings.py中設置'ENGINE':'django.db.backends.mysql_pool'

找到

try: 
 import MySQLdb as Database
except ImportError as e: 
 from django.core.exceptions import ImproperlyConfigured 
 raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)

這段代碼,在下面添加:

from sqlalchemy import pool
Database = pool.manage(Database[,recycle=DATABASE_WAIT_TIMEOUT-1])
#其中DATABASE_WAIT_TIMEOUT為你定義的連接超時時間,必須小于等于mysql里面的wait_timeout()

結果如下

try: 
 import MySQLdb as Database
except ImportError as e: 
 from django.core.exceptions import ImproperlyConfigured 
 raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
from sqlalchemy import pool
Database = pool.manage(Database)

然后找到get_connection_params(self)函數代碼:

def get_connection_params(self):
 kwargs = {
  'conv':django_conversions,
  'charset':utf8
  }
  ...

修改為:

def get_connection_params(self):
 kwargs = {
  'charset':utf8
  }
  ...

注意:如果不改變此處的kwargs,將會出現:TypeError:unhashable type:'dict' 的錯誤。

原樣用kwargs傳的話,sqlalchemy的pool會報unhashable錯誤,那是因為kwargs中有個key(conv)對應的value(django_conversions)是個字典,在pool中會把(key,value)組成元組作為新的key保存在pool中,但是因為value(django_conversions)是dict,不允許作為key的

在mysql里使用 show status 或 show processlist查看連接情況

方法 2

直接在settings.py同級目錄下的init.py文件中添加如下代碼

from django.conf import settings
from django.db.utils import load_backend
import sqlalchemy.pool as pool
import logging
pool_initialized=False

def init_pool():
  if not globals().get('pool_initialized', False):
   global pool_initialized
   pool_initialized = True
   try:
    backendname = settings.DATABASES['default']['ENGINE']
    backend = load_backend(backendname)

    #replace the database object with a proxy.
    backend.Database = pool.manage(backend.Database)

    backend.DatabaseError = backend.Database.DatabaseError
    backend.IntegrityError = backend.Database.IntegrityError
    logging.info("Connection Pool initialized")
   except:
    logging.exception("Connection Pool initialization error")

init_pool()

然后修改django/db/backends/mysql/base.py文件

找到get_connection_params(self)函數代碼:

修改為:

def get_connection_params(self):
 kwargs = {
  'charset':utf8
  }
  ...

同理,不修改kwargs將會出現:TypeError:unhashable type:'dict' 的錯誤。

以上兩種方法都要改變django的代碼,有一定入侵性,第二種方法改變要小一點

django 1.7
python 2.7
sqlalchemy 1.0

這篇用sqlalchemy構建Django連接池的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湘乡市| 华池县| 兴安县| 万州区| 融水| 大化| 外汇| 南溪县| 当雄县| 临澧县| 平阳县| 泾源县| 霞浦县| 曲松县| 东乡县| 泽普县| 全椒县| 宝鸡市| 黑山县| 北海市| 修文县| 昭苏县| 抚州市| 全南县| 稻城县| 博湖县| 武乡县| 怀化市| 谢通门县| 万州区| 星座| 内丘县| 涞源县| 利川市| 东乡县| 迁安市| 康马县| 鄂尔多斯市| 石楼县| 赤水市| 杭锦旗|