zoukankan      html  css  js  c++  java
  • python三种数据库连接池方式

    psycopg2.pool – Connections pooling

    Creating new PostgreSQL connections can be an expensive operation. This module offers a few pure Python classes implementing simple connection pooling directly in the client application.

    class psycopg2.pool.AbstractConnectionPool(minconnmaxconn*args**kwargs)

    Base class implementing generic key-based pooling code.

    New minconn connections are created automatically. The pool will support a maximum of about maxconn connections. *args and **kwargsare passed to the connect() function.

    The following methods are expected to be implemented by subclasses:

    getconn(key=None)

    Get a free connection and assign it to key if not None.

    putconn(connkey=Noneclose=False)

    Put away a connection.

    If close is True, discard the connection from the pool.

    closeall()

    Close all the connections handled by the pool.

    Note that all the connections are closed, including ones eventually in use by the application.

    The following classes are AbstractConnectionPool subclasses ready to be used.

    class psycopg2.pool.SimpleConnectionPool(minconnmaxconn*args**kwargs)

    A connection pool that can’t be shared across different threads.

    Note

     

    This pool class is useful only for single-threaded applications.

    class psycopg2.pool.ThreadedConnectionPool(minconnmaxconn*args**kwargs)

    A connection pool that works with the threading module.

    Note

     

    This pool class can be safely used in multi-threaded applications.

    class psycopg2.pool.PersistentConnectionPool(minconnmaxconn*args**kwargs)

    A pool that assigns persistent connections to different threads.

    Note that this connection pool generates by itself the required keys using the current thread id. This means that until a thread puts away a connection it will always get the same connection object by successive getconn() calls. This also means that a thread can’t use more than one single connection from the pool.

    Note

     

    This pool class is mostly designed to interact with Zope and probably not useful in generic applications.

  • 相关阅读:
    使用logstash收集java、nginx、系统等常见日志
    day71-Auth模块,BBS小作业初始
    day70-django中间件
    day69-form源码,cookies与session
    day68-分布器的使用,forms组件
    day67-ajax发送数据,分页器等
    day66-图书管理系统,Ajax,choices参数等
    复习知识点-没搞清楚的总结
    day65-聚合查询,分组查询,F与Q查询,事务,参数
    day64-表单查询,双下查询,各种查询(model层,数据库操作)
  • 原文地址:https://www.cnblogs.com/shijingjing07/p/5764665.html
Copyright © 2011-2022 走看看