nodejs下mysql性能测试
发布于 14 年前 作者 qingdu 24408 次浏览 最后一次编辑是 8 年前

<p>近期对node下的几个mysql操作库做了一下简单的调研<br /> 主要是针对这3个module进行<br /> libmysqlclient,mysql-native, mysql</p><br/><h2>node-libmysqlclient</h2><br/><p><a href=“https://github.com/Sannis/node-mysql-libmysqlclient”>https://github.com/Sannis/node-mysql-libmysqlclient</a><br /> 基于libmysql的封装, 支持阻塞与非阻塞两种操作方式,目前在query部分功能比较完善,prepare statement方面还是有些bug,实际测试中一直出core</p><br/><h4>安装</h4><br/><p>npm install mysql-libmysqlclient</p><br/><h2>node-mysql</h2><br/><p><a href=“https://github.com/felixge/node-mysql”>https://github.com/felixge/node-mysql</a><br /> 纯node的实现, 支持prepare statement, 数据的获取支持事件与callback两种方式</p><br/><h4>安装</h4><br/><p>npm install mysql</p><br/><h2>node-mysql-native</h2><br/><p><a href=“https://github.com/sidorares/nodejs-mysql-native”>https://github.com/sidorares/nodejs-mysql-native</a></p><br/><p>纯node的实现, 内置有简单的连接池支持,支持prepare statement, 数据的获取只支持通过事件方式</p><br/><h4>安装</h4><br/><p>npm install mysql-native</p><br/><h2>测试设计</h2><br/><h4>测试表结构</h4><br/><pre lang=“mysql”>CREATE TABLE test10 (<br/> id int(10) unsigned NOT NULL DEFAULT ‘0’,<br/> txt varchar(500) DEFAULT ‘’<br/>) ENGINE=InnoDB DEFAULT CHARSET=utf8;<br/></pre><br/><h4>测试数据</h4><br/><p>分别生成了含10, 100, 500, 1500行记录的4张表<br /> 使用10个并发连接分别对其进行SELECT * FROM table的查询</p><br/><h2>测试结论</h2><br/><p><img title=“NewImage.jpg” src=“http://static.data.taobaocdn.com/up/nodeclub/2011/02/NewImage.jpg” border=“0” alt=“NewImage.jpg” width=“544” height=“125” /></p><br/><p>其中数值表示qps值</p><br/><p>在结果集较小时node-mysql-native明显胜出<br /> 当结果集增大到接近100行时,node-libmysqlclient开始表现出更佳的性能<br /> node-mysql性能与其他两个module差距比较大,如果对性能有一定要求的话,则其基本不可用</p><br/><h2>测试代码</h2><br/><p><a href=“http://code.google.com/p/cnodejs/source/browse/#svn%2Ftrunk%2Fmysql-benchmark”>http://code.google.com/p/cnodejs/source/browse/#svn%2Ftrunk%2Fmysql-benchmark</a></p>

15 回复

表格里的值含义是什么?

同问楼上的问题,还有表格中,num指的是?

num我知道,是表中的数据行数

我看错了,大家忽略我吧…

选择node-mysql-native了! <br/>另外,发现有很多memcached的nodejs的实现,能否给个建议,选哪一款较好。 <br/>谢谢

我测试了其中两个,貌似都不太靠谱,所以自己写了一个。过两天放出来

膜拜啊。。。

这个东东怎么在CYGWIN里面用

node-mysql 应该要配合node-mysql-pool 和node-mysql-cache 使用, 用上连接池,应该效率显著提升

nodejs有oracle的接口吗?

/*查询数据*/
client.query(sql).addListener('row',function(results){
	console.dir(results);
	/*HTTP返回*/
	response.writeHead(200,{'Content-Tyep':'text/plain'});
	var data = JSON.stringify(results);
	response.write(data + "\n");
	response.end();
}).addListener('end', function() {
	/*连接关闭*/
	client.close();
});

我用mysql-native查询mysql,console.dir(results)方法可以将我需要的查询结果输出在服务端,但是通过response.write(data + “\n”)输出在我访问的页面里的却是第一条数据。 请问用何方法才能在我访问的页面中获得我想要的查询结果呢?求助中

不知道 大家都是用什么工具测试性能的呢??求推荐

过来mark下,刚好用到

回到顶部