如何请求一个 23M 的 json 文件

2019 年 3 月 13 日
 ahdw

我写了一个小脚本,需要下载一个 23M 的 json 文件,然后在这个 json 文件里查询信息。

问题是经常下载不全,然后出错。

这个 json 文件不定期更新,如果保存在本地的话不确定什么时候会过期。请问各位有没有好的办法?

2777 次点击
所在节点    问与答
13 条回复
ysc3839
2019 年 3 月 13 日
“问题是经常下载不全,然后出错。”
使用 TCP 传输的话不应该出现这种问题。如果频繁出现的话那需要检查一下网络环境了。
ahdw
2019 年 3 月 13 日
@ysc3839 意思就是无论如何都要每次通过网络请求这个大文件了?
tairan2006
2019 年 3 月 13 日
用 streaming
wspsxing
2019 年 3 月 13 日
用 aria2 等专业一点的下载器吧,,而且 http 有 head 方法(头里面配 md5 或者更新日期之类,不变就不用更新),,你服务器配置一下就可以放在本地了
yamedie
2019 年 3 月 13 日
如果下载期间这个远程的 json 文件内容发生了改变,就会造成“下载不全”。

下载 23M 到本地再查询 json 里的部分信息,是很低效的吧,如果是我,我会用 lowdb 做 json 数据库,再用 koa 开发一个查询条件 api,就很舒爽了
GoLand
2019 年 3 月 13 日
定期下载并更新到本地数据库里。收到一个查询请求的时候再异步下载更新一次,还能减小点误差。
ysc3839
2019 年 3 月 13 日
@ahdw 如果解决了下载出错的问题,并且没有流量限制的话,每次请求是较好的解决方案了。缓存也不是不行,但是缓存的话就会有更新不及时的问题,看你选择吧。
murmur
2019 年 3 月 13 日
23m 不全就是你网络或者配置问题 当年据说 12306 不就是直接下载了一个这么大的火车时刻表也没见挂掉
eslizn
2019 年 3 月 13 日
如果一定要这样做的话,那么做好一个加载的交互,配合 request range (如果服务器支持的话)来下载到本地并用 localstorage 之类的进行保存,至于过期问题,http head 一下资源的 modified 时间再由前端逻辑进行更新
awanabe
2019 年 3 月 14 日
可以拆解成多个小的 JSON 文件, 服务器维护每一个文件的版本号, 周期性检查是否有更新...
有更新就更新某一个小文件即可
MonoLogueChi
2019 年 3 月 14 日
如果有条件的话,建议上数据库,不能上数据库的话,可以尝试一下文件校验之类的,可以检查一下本地的是否是最新的,再有就是先压缩,请求到本地再解压,文本文件的压缩率一般都不会太低
neptuno
2019 年 3 月 14 日
存数据库慢慢下,过几分钟下一次,替换旧的
ahdw
2019 年 3 月 14 日
@murmur 就是下载 12306 的那个东西……

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/544332

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX