设为首页 加入收藏

TOP

Node.js mysql pool使用实例
2015-07-16 12:56:29 来源: 作者: 【 】 浏览:8
Tags:Node.js mysql pool 使用 实例

前段时间在写一个版本发布工具,用到express+mysql实现,当站点运行很长一段空白时间后,node进程会自动down掉,提示mysql连接错误,谷歌后发现是mysql自身的特性导致,因此后来改为mysql pool连解决次问题!


mysql模块为felixge/node-mysql


源码如下:


/**
?* Created by keva lin on 2015/4/22.
?*/
var express = require('express');
var router = express.Router();
var mysql = require('mysql');
var conf = require('../config/dbconnection');


//定义pool池
var pool = mysql.createPool(
? ? {
? ? ? ? host? ? ? ? : conf.dbMysql.host,
? ? ? ? user? ? ? ? : conf.dbMysql.user,
? ? ? ? password? ? : conf.dbMysql.password,
? ? ? ? database? ? : conf.dbMysql.database,
? ? ? ? port? ? ? ? : conf.dbMysql.port
? ? }
);


router.get('/', function(req, res) {
? ? var selectSites = "select *, date_format(do_time, '%Y-%m-%d %H:%i:%s') as time from siteinfo order by id";
? ? pool.getConnection(function(err, connection) {
? ? ? ? if (err) throw err;
? ? ? ? connection.query(selectSites, function(err, rows) {
? ? ? ? ? ? if (err) throw? err;
? ? ? ? ? ? res.render('sites', {title : '站点分布', results : rows})
? ? ? ? });
? ? ? ? //回收pool
? ? ? ? connection.release();
? ? });
});


module.exports = router;


下面的内容你可能也喜欢


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇贪心算法之活动选择问题--求解现.. 下一篇C#的未来:方法契约

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: