Skip to main content

pymysql-based database connection pool

Project description

PyMySQLPool

build status codecov pip version license

PyMySQLPool is a pymysql-based database connection pool, simple and lightweight.

Table of content

Features

  • Maintain a minimum number of connection pools by default.
  • If number of unuse connections less than zero, dynamically add connections to pool until current number of inuse connections equal maximum of pool.
  • Release the idle connections in regular until number of unuse connections equal minimum of pool.

Requirements

  • Python
    • CPython : >= 3.4
  • MySQL Server -- one of the following:
    • MySQL >= 5.5
    • MariaDB >= 5.5
  • PyMySQL: >= 0.9.2

Installation

Package is uploaded on PyPI

You can install with pip

$ pip install pymysql-pooling

Example

Make use of a simple table (Example in MySQL doc)

mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),
    -> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);

mysql> INSERT INTO pet
    -> VALUES ("Puffball", "Diane", "hamster", "f", "1999-03-30", NULL);
from pymysqlpool.pool import Pool


pool = Pool(host=HOST, port=PORT, user=USER, password=PASSWORD, db=DB)
pool.init()

connection = pool.get_conn()
cur = connection.cursor()
cur.execute('SELECT * FROM `pet` WHERE `name`=%s', args=("Puffball", ))
print(cur.fetchone())

pool.release(connection)

This example will print:

('Puffball', 'Diane', 'hamster', 'f', datetime.date(1999, 3, 30), None)

Support auto-commit mode, as following:

pool = Pool(host=HOST, port=PORT, user=USER, password=PASSWORD, db=DB, autocommit=True)

That's all.

Parameters for the pool initial:

  • host: Host of MySQL server
  • port: Port of MySQL server
  • user: User of MySQL server
  • password: Password of MySQL server
  • db: Database of MySQL server
  • charset: Charset of MySQL server
  • cursorclass: Class of MySQL Cursor
  • autocommit: auto commit mode
  • min_size: Minimum size of connection pool
  • max_size: Maximum size of connection pool
  • timeout: Watting time in the multi-thread environment
  • interval: Statistical cycle time
  • stati_mun: Statistical frequency
  • multiple: Regulation standard
  • counter: Counter
  • accumulation: Statiscal result

Roadmap

  • Connection Pool
  • Dynamically Create
  • Dynamically Release
  • Monitor Web Interface

Resources

License

PyMySQLPool is released under the MIT License. See LICENSE for more information.

Contributing

Thank you for your interest in contribution of PyMySQLPool, your help and contribution is very valuable.

You can submit issue and pull requests, please submit an issue before submitting pull requests.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pymysql-pooling-0.9.9.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

pymysql_pooling-0.9.9-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file pymysql-pooling-0.9.9.tar.gz.

File metadata

  • Download URL: pymysql-pooling-0.9.9.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.0

File hashes

Hashes for pymysql-pooling-0.9.9.tar.gz
Algorithm Hash digest
SHA256 b39ce76d1b27bb391804276f41d2dcd4fcde5f1b3ea189da9e79fe5fca1dc863
MD5 84f747e867b55cf1016a79cdd784e93f
BLAKE2b-256 c249d4f4ddf4fb8548014477d34ee6ead28447c2748058356b7f71d7e58fadd5

See more details on using hashes here.

File details

Details for the file pymysql_pooling-0.9.9-py3-none-any.whl.

File metadata

  • Download URL: pymysql_pooling-0.9.9-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.0

File hashes

Hashes for pymysql_pooling-0.9.9-py3-none-any.whl
Algorithm Hash digest
SHA256 e217ac0d60a90ca7660ceef332e29d2caa9dc009817221d67c6ce7181d70a5dc
MD5 68099a6d38ce4724ea36fee1781ed207
BLAKE2b-256 ecfce36c8bf695df373ec6d687d566de64fa8b2ed05d95794edcc92249cb5a74

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page