- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我最近通过Heroku成功部署了一个node.js服务器,机器可以在这里找到:https://congress-tracker-app.herokuapp.com/
它基本上是与 Twitter 的 API 通信,每次从我的预定义参数集(在本例中为推文的 ID)接收到一条推文时,它都会更新一个 .csv 文件。然后我使用 D3.js 显示该 CSV 以可视化数据。
正在使用 D3 javascript 库提取数据...d3.queue().defer(d3.csv, "public/data/twitterData.csv").await(更新)
然后更新回调函数传递数据,并创建我的可视化。
我有两个问题:
我无法让应用程序在后台运行,也就是在网页未打开时更新 CSV。我希望 Twitter API 继续与我的应用程序通信,这样数据就会随着时间的推移而积累,而无需有人保持页面打开。它是通过 Twitter 的流 API 获取的。
重新加载应用程序会使我的 CSV 清除回标题下的一行数据,这是我在初始构建中输入的。此外,当我将文件克隆到我的桌面时,公共(public)文件夹中的 CSV 不显示从 Twitter 获取的任何新数据。
在 Heroku 应用程序页面上,我的日志显示正在添加数据。出现“文件已保存”消息,当 fs.appendFile 向我的 CSV 添加一行时,我在代码中触发了该消息。消息如下:
如您所见,CSV 文件位于我的应用程序的公用文件夹中。我如何确保应用程序退出后 1) 服务器继续运行以及 2) 保存对我的 CSV 的更改?
这是我的部分代码:
var param = {follow: '21111098,958191744683782144,18061669,21111098,18061669,2891210047,1869975300,19394188,4107251,16056306,259459455,21111098,18061669,2891210047,1869975300,19394188,4107251,16056306,259459455,968650362,343041182,5558312,111671288,476256944,378631423,803694179079458816,30354991,224285242,45645232,235217558,20879626,150078976,278124059,102477372,249787913,381577682,15324851,435500714,823302838524739584,20597460,555355209,15745368,229966028,3001665106,2863210809,1397501864,78403308,253252536,47747074}
var followIds = ['21111098','958191744683782144','18061669','21111098','18061669','2891210047','1869975300','19394188','4107251','16056306','259459455','21111098','18061669','2891210047','1869975300','19394188','4107251','16056306','259459455','968650362','343041182','5558312','111671288','476256944','378631423','803694179079458816','30354991','224285242']
twitterClient.stream('statuses/filter',param,function(stream) {
stream.on('data', function(tweet) {
const fields = ["name","text","URL","time"]
for(i = 0; i <followIds.length; i++){
if(followIds[i] == tweet.user.id_str){ // if so, get contents
// WRITE TO CSV HERE:
let name = tweet.user.name;
let text = tweet.text;
let URL = `https://twitter.com/${tweet.user.screen_name}/status/${tweet.id_str}`
let time = tweet.created_at;
update = [{name,text,URL,time}]
var toCsv = {
data: update,
fields: fields,
hasCSVColumnTitle: false
};
var csv = json2csv(toCsv) + "\r\n";
fs.appendFile('public/data/twitterData.csv',csv,function(err){
if (err) throw err;
console.log('File Saved')
})
}
}
});
最佳答案
我认为您的问题的解决方案是启动“后台作业”——这会使您的长期运行的应用程序逻辑脱离正常的 HTTP 请求/响应周期。
https://devcenter.heroku.com/articles/background-jobs-queueing
Heroku dynos 具有临时文件系统——这意味着一旦您重新启动应用程序,您将丢失所有临时文件,包括您的 CSV。您可能希望在工作完成后将其推送到更永久的存储空间。
https://help.heroku.com/DGUDV63H/how-much-disk-space-on-the-dyno-can-i-use
关于javascript - Heroku Twitter API 应用部署,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48990916/
我正在尝试使用 Heroku Scheduler 在已部署的 Heroku 应用程序中调用 HTTP 端点,它基本上以固定速率在 Heroku bash 上运行命令。 当我运行 $ heroku ru
我有一个在 Heroku 上运行的应用程序,其中有一些我想不时更改的设置,并且我想使用 Heroku 配置变量来存储这些设置,以便它们持久存在。 我知道我可以从 Heroku 仪表板或 Heroku
我从模板 reagent-frontend 创建了一个 ClojureScript Reagent 应用程序。如何将生产应用程序部署到 Heroku?在为生产构建后(lein package/lein
我正在尝试在 heroku 上添加信用卡,然后消息显示“无法验证您的卡,请稍后再试或联系您的金融机构寻求帮助” 最佳答案 这是因为您的银行拒绝付款。 检查您是否输入了所有正确的详细信息 查看您银行的最
首先为我的英语感到抱歉,因为它不是我的母语,我不习惯它,它可能很难理解。 我正在尝试将我的 spike 应用程序连接到 heroku 以获取长期葡萄糖数据。 我在没有“部署分支”步骤的情况下成功完成了
Ec2 实例小时按小时计算。如果你只是启动和关闭一个实例,它仍然算作一小时。 Heroku 如何处理这个?按分钟还是按小时? 让我们假设我的应用程序使用超过 750 免费 Dyno 小时限制 最佳答案
好奇 heroku 如何创建应用程序名称。应用程序名称通常是英文单词,例如bloom-peaks 或formal-trail。一家大公司的 IT 部门也是如此。是否有用于名称生成的 unix 库? 最
有没有人在 Heroku 上成功使用过 docsplit?它有许多二进制依赖项。我已经搜索过,但没有找到任何人这样做。教程会很棒,但我真的很好奇其他人是否成功。 最佳答案 我的搜索没有找到任何做过这件
我想将一个应用程序部署到需要能够生成加密安全随机数的 heroku。我可以使用哪些熵源? 最佳答案 你的 Heroku dyno 基本上是一个 Ubuntu 服务器虚拟机,所以你应该可以访问 /dev
Heroku 可以显示自定义维护页面: heroku config:set MAINTENANCE_PAGE_URL=http://some_server/my_page.html 这需要某些网站的存
我正在开始使用 Heroku,并担心它是否会因我犯的错误而向我收费。例如,填充数据库超过 5MB。 那么,有没有办法为 Heroku 或通知系统设置计费限制,以便在我超过价格限制时发送通知? 先感谢您
如何更新我的 Heroku ,我的 Windows 终端显示以下内容: » Warning: heroku update available from 7.47.7 to 7.52.0. 请帮忙
我在免费的 Dyno 上运行基于 NodeJS 的应用程序,连接到 mongohq-MongoDB。我想迁移它以使用爱好 Dyno,这样做的动机不仅是避免 sleep 时间,而且是为了实现更高的 HT
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
如何将我的生产数据库拉到 heroku 上的暂存服务器? 我有两个 Remote ,production 和 staging。 来自documentation看来我想运行 heroku pg:copy
我有一个域example.com,我想将它用于位于example.herokuapp.com 的rails-app,我很困惑如何去做。 Heroku says "Zone apex domains (
我有一个 sinatra 应用程序,其中有一个 yml 文件来设置环境变量,我使用此方法调用它们 module MyConfig def config environment = ENV["RA
根据各种因素,一整天中,我的应用程序的负载可能会出现非常极端的增加。 那时,我想自动增加测功机的数量。 我想增加加载时间。因此,如果加载页面需要X倍的时间,请增加测功力。否则,请往下走。 这样的东西存
我想知道使用heroku工具栏在heroku帐户之间进行切换的最佳方法是什么。 我曾经有一个个人的heroku帐户,它是我所有职业性的heroku应用程序的协作者。问题是当我想进行一些对财务有影响的更
是否可以停止部署到当前正在构建的 Heroku ( git push heroku )? 类似 heroku run stopit! 顺便提一句。成功部署后回滚不是我想要的。 最佳答案 首先,安装He
我是一名优秀的程序员,十分优秀!