- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个用 Nodejs 编写的系统,它首先必须将非常大的 csv 文件中的记录导入数据库。使用Sequelize作为我的 ORM,我创建了一个简单的模型,如下所示:
"use strict";
const Sequelize = require('sequelize');
const sequelize = new Sequelize('mm', 'root', 'password', {
host: 'localhost',
dialect: 'mysql',
logging: true,
pool: {max: 5, min: 0, idle: 100000},
});
const Index = sequelize.define('index', {
value: {type: Sequelize.FLOAT}
});
然后我编写了以下代码来遍历文件中的行,解释这些行,并将它们写入数据库:
let readline = require('readline');
let moment = require('moment');
let lineReader = readline.createInterface({
input: require('fs').createReadStream('files/price_index.csv')
});
lineReader.on('line', function (line) {
let splitted = line.split(',');
let dt = moment(parseInt(splitted[0]));
let value = parseFloat(splitted[1]);
console.log(dt.format(), value);
Index.create({value: value, createdAt: dt});
});
这工作正常,但它在每 3120 条记录后暂停约 3 秒。我尝试了 sqlite 和 mysql,但它总是在恰好 3120 条记录后暂停。
看到 Sequelize 也在那些 3120 条记录之后开始记录插入查询,我认为这种行为的原因是某种缓存机制,它将所有查询放入队列中,直到它无事可做,或者如果它达到了恰好 3120 条记录的神奇查询缓存限制。
我尝试在 Sequelize 的初始化中增加 pool.max
数字,但这似乎没有任何区别。
谁能证实我的缓存想法,或者解释一下这种行为的真正原因是什么?我能以某种方式改变这种行为,使其具有一致的吞吐量吗?欢迎所有提示!
最佳答案
我认为 3120 行将是 the high water mark for the createReadStream
buffer which is 64KiB .当缓冲区已满时,Node 将停止读取。
看起来 3120 个 line
事件都在同一个 Node 事件 tick 上运行,因此您处理了 3120 行,并为下一个 tick 安排了 3120 个异步 Index.create
调用.因此,您最终需要在每一侧进行大量处理。要么读取和调度查询,要么处理大量的调度查询。
当 3120 line
事件函数完成时,会发生一些垃圾收集,并且计划的 3120 sequelize create
调用有机会执行它们的操作。这是数据中的“暂停”,但 Node 仍在处理。所有 create
调用都需要几秒钟才能完成,然后进行更多的垃圾收集并返回到下一个 csv 数据 block 及其所有 line
事件。这个过程就这样来回进行。
在一个包含 10000 行的 csv 文件中,我看到 ~ 3 个查询能够在所有 10000 行 csv 数据被读取并计划插入之前运行。
您可能想使用 Readable Stream用更小的 block 。然后根据 sequelize 插入完成来阻止读取。您可能需要自己处理线路而不是使用 readline
.如果 csv 文件适合内存,只需读取整个文件,因为调度会更容易。
也许使用类似 queue
的东西管理插入,允许您的 Sequelize 池 max
作为 concurrency
。然后,一旦队列的 length
足够低,就允许读取再次发生。
虽然我不知道最终结果是否会更快,但最终结果可能非常相似。
关于mysql - 为什么 Sequelize 在 3120 条记录后暂停?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47052410/
我在 Window 2008 x64 上的 IIS 7 下托管了一个网站。 IIS 以 64 位模式运行,该站点有自己的 64 位应用程序池等。该网站大部分时间似乎运行良好,然后每小时突然卡住用户请求
我有一个 imageView 并希望它像这样工作: ImageViewer可见 5秒暂停 ImageView 不可见 5秒暂停 ImageViewer可见 等等... 我该怎么做?我试过 sleep
我在我的 JavaScript 函数中使用了下面的代码。我想在 10 秒后调用这个函数。然而该函数立即被触发!?!不确定发生了什么。 function testing() { //oth
我想暂停计时器,点击按钮后我想继续计时器计数...我搜索但找不到与此相关的功能.. 怎么办? 最佳答案 您将需要一个变量来跟踪自 Chronometer 启动以来耗时: long timeWhenSt
我目前有一个程序可以从麦克风收集声音信号并在 python 上实时显示波形。对于 matplotlib funcanimation,我正在尝试通过这种方式向我的程序添加一些暂停和启动按钮或功能。但它没
我有一个由套接字提供的热Observable。我可以使用pausable暂停套接字供稿。但是一旦“取消暂停”可观察对象,就需要显示套接字在暂停订阅时可能发送的最后一个值。我不想跟踪套接字手动发送的最后
我知道这是可能的,但我还没有找到方法,所以我在问。 在播放 3rd 方音乐(例如 Spotify)时开始在我的应用程序中播放 mp3 声音时。 Spotify 暂停,您必须恢复 Spotify,让它再
我正在尝试使用 iPhone 的前置摄像头录制有声视频。因为我还需要支持暂停/恢复功能,所以我需要使用 AVAssetWriter .我在网上找到了一个用 Objective-C 编写的示例,它几乎实
我知道互斥锁可以作为一种实现,但是我想知道是否有一种方法可以像视频播放一样暂停/恢复另一个线程。当其他正在运行的线程很复杂时,此方法更易于编程。 最佳答案 SIGTSTP是用于暂停进程的信号,如果您有
到目前为止,我已经看到了以下停止动画的技术,但我在这里寻找的是旋转 View 停止在当前的角度,而不是返回到 0。 struct DemoView: View { @State private
我一般在问有关多线程的问题。例如我锁定了一个互斥锁并恢复任务,然后我想挂起它,我的问题是,我应该在挂起之前解锁互斥锁吗?这样当我再次使用互斥锁恢复它时,它会成功恢复吗? 我刚刚开始使用多线程的东西,我
我有2个缩略图链接,单击它们时,它们会以灯箱样式打开视频。我的目标是让它们在打开时播放,在关闭时暂停(单击背景区域时关闭)。 我的HTML代码在这里: M
到目前为止,我没有将我发现的几种不同方法拼凑在一起: http://192.185.121.49/~steveobr/ 我需要所有的语音演示像第一个“商业”一样工作 正如您在实时示例中看到的那样,每个
所以我正在制作某种游戏,玩家可以在其中获得一些能力。玩家回合结束后,服务器应有 5 秒的超时时间,其中不执行任何代码,然后在该时间后结束回合。但是,如果客户端单击其中一项电源,服务器应停止 5 秒超时
我尝试将自己的方法添加到 Tween 类中以暂停/恢复所有补间。这就是我所拥有的: createjs.Tween.pauseAllTweens = function() { for ( var
我对 Azure 搜索标准级别的成本有疑问。是否可以将 Azure 搜索级别从标准更改为基本?是否可以暂时暂停 Azure 搜索标准?我在门户中没有看到此控件。我是否需要将 Azure 搜索实现重新创
如何用相同的代码制作play/Pause按钮。 - (IBAction)min:(id)sender { NSString *path = [[NSBundle mainBundle] pathF
我知道这很可能超出了沙箱范围,但我还是想问一下: 我想在我的应用程序中放置一个“暂停/播放”按钮,以暂停或播放任何背景音频。基本上,我希望实现在多任务栏中找到的播放/暂停按钮。 一个简单的例子是有人用
我正在制作一款编程游戏,玩家可以在其中对盟友的行为进行编程。玩家为给定的盟友编写decide()函数的主体,可以用任何java代码填写,但必须返回一个 Action 。我想为每个盟友提供一组有限的每个
我有功能 1 用于播放音乐,第二个用于设置实际音乐的暂停,我的暂停功能不起作用。我该如何设置暂停? function play(id){ var audio = new Audio('
我是一名优秀的程序员,十分优秀!