- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个脚本,它使用 SELECT 对 MySQL 执行 2 个查询,结果查询每个产生一个 226,393 行的结果集和另一个 529,976 行的结果集。当输入 REDIS 时,每行添加 4 次,每个要存储的唯一数据一个。
第一个查询似乎完成了,没问题,但第二个查询似乎停在了中间并停留在那里。我是 NODEjs 和 REDIS 的新手,并且有传统的 MySQL 背景。
代码如下:
// Start the server
http.createServer(function(req, res){
console.log('Request received');
for(var n = 0; n < qryArray.length; n++) {
var qry = qryArray[n];
// Send the query
//console.log( n + ' :: ' + qry);
connection.query(qry, function(err, rows, fields){
if(err){
console.log(err);
}else{
console.log('Query response ' + rows.length + ' rows');
//console.log(util.inspect(process.memoryUsage()));
errorCount = 0;
goodCount = 0;
for(var i = 0; i < rows.length; i++){
var row = rows[i];
j = 0;
//var fields = result.fields.map(function(f) { return f.name; })
fields.forEach(function(f){
if(f.name != 'latlng' && f.name != 'market' && f.name != 'technology'){
j++;
//console.log(('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng);
redisClient.hmset(('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng, row, function(error, result){
if(error){
errorCount++;
console.log(errorCount + ' ' + error + ' ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng + ' :: ' + JSON.stringify(row));
}else{
goodCount++;
console.log(goodCount);
//console.log(goodCount + ' Redis stored: ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + ' ' + result);
}
});
}
});
//goodCount++;
//console.log(goodCount);
}
console.log('Finished indexing ' + rows.length + ' rows ' + goodCount);
}
});
}
console.log('Queries processed');
}).listen(port);
console.log('Server running on port ' + port);
有人可以指出我哪里出了问题,或者如何针对大型数据集进行改进吗?谢谢!
在获取有关添加异步库以使用队列的指针后,我修改了代码,但得到了一个令人讨厌的错误:
{ [Error: Connection lost: The server closed the connection.] fatal: true, code: 'PROTOCOL_CONNECTION_LOST' }
这是添加了功能的新代码,请帮忙:
// Initialize the queue
var q = async.queue(function(task){
//console.log(('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng);
redisClient.hmset(task.hk, task.r, function(error, result){
if(error){
errorCount++;
console.log('Error: ' + errorCount);
//console.log(errorCount + ' ' + error + ' ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng + ' :: ' + JSON.stringify(row));
}else{
goodCount++;
console.log('Good: ' + goodCount);
//console.log(goodCount + ' Redis stored: ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + ' ' + result);
}
});
}, 50000);
// Assign callback for when all items in queue have been processed
q.drain = function(){
console.log('All queue items have been processed ' + goodCount);
}
// Start the server
http.createServer( function( req, res ){
console.log('Request received');
for(var n = 0; n < qryArray.length; n++) {
var qry = qryArray[n];
// Send the query
//console.log( n + ' :: ' + qry);
connection.query(qry, function(err, rows, fields){
if(err){
console.log(err);
}else{
console.log('Query response ' + rows.length + ' rows');
//console.log(util.inspect(process.memoryUsage()));
errorCount = 0;
goodCount = 0;
for(var i = 0; i < rows.length; i++){
var row = rows[i];
var j = 0;
//var fields = result.fields.map(function(f) { return f.name; })
fields.forEach(function(f){
if(f.name != 'latlng' && f.name != 'market' && f.name != 'technology'){
j++;
var hkey = ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng;
var task = {r: row, hk: hkey};
q.push(task, function(err){
if(err) console.log(err);
});
}
});
}
console.log('Finished indexing ' + rows.length + ' rows');
}
});
}
console.log('Queries processed');
}).listen(port);
console.log('Server running on port ' + port);
错误发生在 50K 队列项目成功完成后(队列已初始化为 50k 并发项目)。
断线问题改成MySQL pool机制,还是断线,求助。此外,在实际插入到 REDIS 之前需要花费大量时间,那里也有问题吗?
// Start the server
http.createServer(function(req, res){
res.writeHead(200);
res.end();
console.log('Request received');
pool.getConnection(function(err, connection){
if(err){
connection.release();
return console.log('Database connection error ' + err);
}
console.log('Database is connected ' + connection.threadId + ' ...');
for(var n = 0; n < qryArray.length; n++){
var qry = qryArray[n];
// Send the query
connection.query(qry, function(err, rows, fields){
connection.release();
if(err){
return console.log('Query error: ' + err);
}
console.log('Query response ' + rows.length + ' rows');
errorCount = 0;
goodCount = 0;
for(var i = 0; i < rows.length; i++){
var row = rows[i];
var j = 0;
fields.forEach(function(f){
if(f.name != 'latlng' && f.name != 'market' && f.name != 'technology'){
j++;
var hkey = ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng;
var task = {r: row, hk: hkey};
q.push(task, function(err){
if(err) console.log(err);
});
}
});
}
console.log('Finished indexing ' + rows.length + ' rows');
});
connection.on('error', function(err){
return console.log('Database connection error ' + err);
});
}
console.log('Queries processed');
});
}).listen(port);
console.log('Server running on port ' + port);
最佳答案
谢谢大家帮助我,脚本现在可以使用 MySQL 池、作业队列,我添加了 HTTP 调度程序以获取有关主要任务进度的简单状态报告:将 MySQL 数据集结果插入 REDIS。花了几个小时才完成(+300 万次插入)。
我发布了生成的脚本,希望它既可以改进,也可以帮助启发处于类似情况的其他人。
// MySQL initialization
var pool = mysql.createPool({
connectionLimit : 10,
host : 'localhost',
user : 'gta_ro',
password : 'glacier',
database : 'tower'
});
// Async Queue initialization
var insertCount = 0;
var q = async.queue(function(task, callback){
redisClient.hmset(task.hk, task.r, function(error, result){
if(error){
errorCount++;
console.log('Error: ' + errorCount);
//console.log(errorCount + ' ' + error + ' ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng + ' :: ' + JSON.stringify(row));
}else{
goodCount++;
console.log('Good: ' + goodCount);
//console.log(goodCount + ' Redis stored: ' + f.name.toUpperCase() + ' : ' + ('' + row[f.name]).toUpperCase() + ' ' + result);
}
});
return setImmediate(function() { callback() });
}, 1000);
// Async Queue Empty callback (triggered after last item has been consumed)
q.drain = function(){
console.log('All queue items have been processed ' + goodCount);
}
// Start the server
httpStarted = false;
http.createServer(function(req, res){
dispatcher.dispatch(req, res);
if(!httpStarted){
httpStarted = true;
console.log('Server running on port ' + port);
pool.getConnection(function(err, connection){
if(err){
connection.release();
return console.log('Database connection error ' + err);
}
console.log('Database is connected ' + connection.threadId + ' ...');
for(var n = 0; n < qryArray.length; n++){
var qry = qryArray[n];
// Send the query
connection.query(qry, function(err, rows, fields){
if(err){
return console.log('Query error: ' + err);
}
//connection.release();
console.log('Query response ' + rows.length + ' rows');
errorCount = 0;
goodCount = 0;
for(var i = 0; i < rows.length; i++){
var row = rows[i];
var j = 0;
fields.forEach(function(f){
if(f.name != 'latlng' && f.name != 'market' && f.name != 'technology'){
j++;
q.push({r: row, hk: ('' + row[f.name]).toUpperCase() + '~' + i + '-' + j + '~' + row.latlng}, function(err){
if(err) console.log(err);
});
}
});
}
console.log('Finished indexing');
});
connection.on('error', function(err){
return console.log('Database connection error ' + err);
});
}
console.log('Queries processed');
});
}
}).listen(port);
dispatcher.onGet('/', function(req, res){
if(httpStarted){
res.writeHead(200, {'Content-Type': 'text/html'});
res.end('MySQL Indexer running' + '\n');
console.log('MySQL Indexer running');
}
});
dispatcher.onGet('/status', function(req, res){
res.writeHead(200, {'Content-Type': 'text/html'});
res.end('Status ' + q.length() + '\n');
console.log('Status ' + q.length());
});
一些补充是添加一个 kill/link 来终止进程并改进状态报告,仅举几例。
关于javascript - Nodejs 卡住 MySQL 大量结果输入 REDIS HMSET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31166826/
我有一个测试即将进行,我想澄清两个有关参数的问题。 在我的笔记中指出,将参数传递给函数的推荐方法是使用“按引用传递” const type& x; // for "in" parameters
当我通过 OMG 2.5(Beta)推广的 UML 规范阅读以下概念时: in: Indicates that Parameter values are passed in by the caller
我试图在用户按下 Enter 时触发一个函数。我将此输入设置为只读的原因是限制用户在填充值后修改输入中的值。 该值来自将在点击属性中触发的弹出窗口。问题是 keyup.enter 没有触发该输入。 代
我在jQuery中使用模式弹出窗口控件,该弹出窗口具有由jQuery Tokenize输入插件提供动力的输入文本。问题是,当我在模式弹出文本框中键入内容时, token 化插件的搜索结果显示为隐藏在弹
我有一个问题。当我选中复选框时,系统工作正常,总值发生变化,但一旦我修改文本输入,它就会变为 0。我需要将此文本框输入排除在更改值之外。 这是 html: $15000 $
我正在努力让它发挥作用,但还是有些不对劲。 我想用 CSS 设置提交按钮的样式以匹配我已有的按钮。 风格: input[type="button"], input[type="submit"], b
import java.util.*;; public class selection { Scanner in=new Scanner(System.in); private
这可能是一个非常菜鸟的问题。假设我有一个带宽限制为 100MB/s 的网卡,那么输入/输出带宽是否有可能达到该限制 同时 ?或者我会在任何时候遇到这个不等式:in bandwidth + out ba
看着这个问题,Fill immutable map with for loop upon creation ,我很好奇是什么this表示在 Map(1 -> this) . scala> Map(1
我有这样的东西 一个 乙 问? 是或否 数字 数字或零 我想做的是: 如果 B1 = “Y”,则让用户在 B2 中输入一个数字。 如果 B1 = “N”,则将 B2 中的值更改为零,并且不允许用户在
我有一个包含许多列的表,我想添加 input标题单元格内的字段,但我希望输入适合根据正文内容的宽度。 这是没有 input 的样子领域: 这就是 input 的样子领域: 可以看出,像“index”和
关于为 FTP 客户端设置传出和传入文件夹,您遵循哪些最佳实践(如果有)?我们通常使用“outgoing”和“incoming”,但无论你如何表述方向,它都可以有两种解释方式,具体取决于名称相对于哪一
我正在尝试“求解”给定 d 的 Pell 方程:x^2 - d * y^2 = 1,或者至少我想得到最小的 x > 0 来求解方程。到目前为止,一切都很好。这是我的 Haskell 代码 minX :
我是VS Code的新手,可以使用Ctrl + Enter将代码运行到python交互式窗口中。我希望光标自动移动到下一行,因此我可以逐行浏览代码。 能做到吗? 最佳答案 如this blog pos
我正在创建一个 bool 值矩阵/二维数组,并且我想为 dategrid 推断一种不仅仅是“ANY”的类型。 let yearRange = [2000,2001,2002,2003,2004]; l
我有两个排序的列表,例如 a = [1, 4, 7, 8] b = [1, 2, 3, 4, 5, 6] 我想知道a中的每个项目是否在b中。对于上面的示例,我想找到 a_in_b = [True, T
菜鸟警报 这很奇怪 - 当我编写以下代码时,尝试在 AngularJS 中创建自定义指令: myModule.directive('myTab', function(){ console.lo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
假设我正在使用 gdscript 静态类型,并且对于一个函数参数,我事先不知道我会得到什么。这就是 python 中 typing.Any 的作用。如何使用 gdscript 做到这一点? 似乎 Va
我使用 dropzone 上传多个图像,并且工作正常,直到我想为每个图像插入品牌和网址。 我遇到的唯一问题是,当我要从输入字段获取值时,我会从服务器获取来自字段(品牌、网址)的未定义值,但如果我使用静
我是一名优秀的程序员,十分优秀!