sqlite mysql连接池_nodejs解决mysql和连接池(pool)自动断开问题

最近在做一个个人项目,数据库尝试使用了mongodb、sqlite和mysql。分享一下关于mysql的连接池用法。项目部署于appfog,项目中我使用连接池链接数据库,本地测试一切正常。上线以后,经过几次请求两个数据接口总是报503。一直不明就里,今天经过一番排查终于顺利解决了。

1.mysql 链接普通模式

var mysql = require(‘mysql’),

env = {

host : ‘localhost’,

user : ‘root’,

password : ‘2212’,

database : ‘image_marker’

};

db = mysql.createConnection(env);

db.connect();

exports.do = function (sql, callback) {

db.query(sql, callback);

}

MySQL中有一个名叫wait_timeout的变量,表示操作超时时间,当连接超过一定时间没有活动后,会自动关闭该连接,这个值默认为28800(即8小时)。对于这种普通连接的方式,在正式线上可能会遇到连接丢失的问题(No reconnection after connection lost错误日志),上github上看了下文档和issues,上面说到连接丢失后不会自动重新连接,会触发error事件。 所以可以使用下面这种方法来避免连接对视问题:

function handleError (err) {

if (err) {

// 如果是连接断开,自动重新连接

if (err.code === ‘PROTOCOL_CONNECTION_LOST’) {

connect();

} else {

console.error(err.stack || err);

}

}

}

// 连接数据库

function connect () {

db = mysql.createConnection(config);

db.connect(handleError);

db.on(‘error’, handleError);

}

var db;

connect();

2.使用连接池

对于丢失连接的问题,可以使用连接池(最新版mysql模块,用mysql.createPool()来创建的pool,当触发了connection的error事件时,会把该connection对象从连接池中移除。)

var mysql = require(‘mysql’);

var pool  = mysql.createPool(config);

pool.getConnection(function(err, connection) {

// Use the connection

connection.query( ‘SELECT something FROM sometable’, function(err, rows) {

// And done with the connection.

connection.end();

// Don’t use the connection here, it has been returned to the pool.

});

});

参考:https://cnodejs.org/topic/51cd3bcc73c638f3705998f5

使用了连接池后,有网友说每一次请求都用pool创建一个connection,改进我的代码如下连接:

http://www.2cto.com/kf/201404/292016.html

转载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLite 是一种嵌入式的数据库,不支持多线程,因此没有像 MySQL 那样的连接池。但是,我们可以通过编写一些代码来实现一个简单的 SQLite 连接池。 以下是一个使用 Python 编写的 SQLite 连接池的示例: ```python import sqlite3 from queue import Queue from threading import Lock class SQLitePool: def __init__(self, max_conn): self.max_conn = max_conn self.pool = Queue(max_conn) self.lock = Lock() self.conn_params = { "database": "test.db" } def get_conn(self): if self.pool.qsize() == 0 and self.max_conn > self.pool.qsize(): conn = sqlite3.connect(**self.conn_params) return conn else: return self.pool.get() def put_conn(self, conn): self.pool.put(conn) def close_all_conn(self): with self.lock: while not self.pool.empty(): conn = self.pool.get() conn.close() ``` 在上面的代码中,我们创建了一个 SQLite 连接池类 `SQLitePool`,它有三个方法: - `get_conn()`:从连接池中获取一个连接,如果连接池为空,则创建一个新的连接返回。 - `put_conn(conn)`:将连接放回连接池中。 - `close_all_conn()`:关闭连接池中的所有连接。 使用该连接池的示例代码如下: ```python def run_sqlite(): pool = SQLitePool(5) conn = pool.get_conn() cursor = conn.cursor() cursor.execute("CREATE TABLE IF NOT EXISTS user (id INTEGER PRIMARY KEY, name TEXT)") cursor.execute("INSERT INTO user (name) VALUES (?)", ("John",)) cursor.execute("INSERT INTO user (name) VALUES (?)", ("Jane",)) cursor.execute("SELECT * FROM user") rows = cursor.fetchall() for row in rows: print(row) cursor.close() pool.put_conn(conn) pool.close_all_conn() ``` 在上面的代码中,我们首先创建了一个 `SQLitePool` 对象,然后从连接池中获取一个连接并执行一些 SQL 语句。最后,我们将连接放回连接池中,并关闭所有连接。 需要注意的是,由于 SQLite 不支持多线程,因此在多线程环境下使用该连接池可能会出现问题,需要自行进行线程安全处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值