我有一个NODE.JS Express服务器,它可以将JSON的大块分解成较小的部分,并通过URL将请求路由到移动设备和我正在创建的各种其他应用程序。
我刚刚从测试数据转移到实时数据,但是我发现NODE.JS不是使用最新版本的JSON,而是缓存和重用服务器运行时就位的JSON。
这是(部分)代码
var express = require('express'), http = require('http'); forever = require('forever'); var ppm = require('./data/ppm.json'); var stations= require('./data/stations.json'); var fgwstations= require('./data/fgwstations.json'); var app = express() .use(express.bodyParser()) .use(express.static('public')); app.all('/', function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header("Access-Control-Allow-Headers", "X-Requested-With"); next(); }); app.get('/ppm/all', function (req, res) { res.json(ppm); }); app.get('/*', function (req, res) { res.json(404, {status: 'datafeed not found please refer to documentation'}); }); http.createServer(app).listen(3000, function () { console.log("Data Server ready at http://localhost:3000"); });
代码中可能有错别字,因为我刚刚撕掉了很多块,因为适当的炮弹相当长,而且很多。我使用FOREVER函数使该服务器永久运行,因此它将在不打开shell命令的情况下运行
现在,我怀疑我可以执行某种fs.filewatch类型的函数,该函数将在每次更新JSON文件时重新启动服务器,但是重新启动服务器似乎有点麻烦,特别是当此数据每2-3分钟及以后更新一次时甚至更快。在重新启动过程中,仅需一个人执行请求或一个应用程序就请求数据即可引起问题。
有没有一种方法可以“重新读取”分配给var ppm的JSON文件(其他文件是静态的),还是重启服务器的唯一方法?
任何有关如何读取该文件并执行此操作的好主意将不胜感激,因为我相信有人会以一种更有效的方式进行操作。
当前的开发服务器是开源的(很多WIP),可以随时查看其功能
http://54.194.148.89:3000
Stop Harming.. 5
require()
缓存加载的所有内容,因为它旨在加载不应更改的代码模块。如果要重新加载某些内容,则必须删除缓存条目。
更好的方法是改用的组合fs.watch
,fs.readFile
然后JSON.parse
重新加载变化的数据。无需摆弄缓存或重新启动服务器。
更好的方法可能是使用某种数据库而不是文件系统。
require()
缓存加载的所有内容,因为它旨在加载不应更改的代码模块。如果要重新加载某些内容,则必须删除缓存条目。
更好的方法是改用的组合fs.watch
,fs.readFile
然后JSON.parse
重新加载变化的数据。无需摆弄缓存或重新启动服务器。
更好的方法可能是使用某种数据库而不是文件系统。