技术解析

像全球城市这种数据你们一般放在数据库还是本地?
0
2021-06-04 00:43:59
idczone

范围是全球的所有国家-省 /州-主要城市,需要关键字搜索。目前我就搞了个 xml 放在本地美国服务器,几百 k 的大小,倒也可以。但是现在需要支持英文查询,扩展起来就有点麻烦了,想着要不要放到数据库里。这种基本不会变的数据你们一般放在数据库里还是本地?


数据库,github 上开源直接导入进去就行

放内存里?

city as a service

github raw 文件

- 使用 Git 对 xml 城市数据进行版本管理。对它的修改也要通过版本管理控制。对于这种不常变动的信息,可以充分发挥 Git 的优势。
- 开发同步程序,能够实现在改动后,将 xml 的城市数据同步到数据库。
- 如果后面由于业务的演化,还想要更强的定制性,那么就不要让同步程序直接访问数据库,而是开发一个 Rest 的服务。这样,就产生了 2 个微服务,其中,同步服务通过 Restful 接口将信息传递给主服务。
2 个微服务的优势是:如果需要收集更加全面的城市信息,只需要在保证接口的情况下,将城市信息服务的摊子丢给其他人,提升开发效率。
---
我之前开发的一个柯南追剧的网站(自己用)就存在和你类似的需求。
1000+集柯南(每周六从 wiki 挂 vpn 手动获取)、剧场版和 OVA (每年手动填写 csv 表格)。这些不同的数据源都通过单独的服务进行管理,而无需将逻辑泄露给主服务。以上的建议也是基于我在这里的实践经验提出。

在数据库查询 /变更起来岂不是很便利?为啥非要考虑本地存储呢?

主要是我想把这种写死的量也不大的数据当成资源文件,不用每次在搜索栏里输一下就得发个请求给后台,增加点效率

取决于你要不要一直改这个东西,不改的话本地最方便,而且可以直接装到内存里

感觉还是作为配置文件资源存在比较好一点,初始化后加载进内存(

数据库,带版本号字段,本地文件有什么优势吗。

整个 excel

放 etcd 里?全球节点同步

几百 k 的东西,又是要经常查询,考虑到修改,建议这样做:
1.保存在数据库里。
2.相关系统启动时,从数据库加载,加载到高速缓存里。
3.当数据库发生更改,使用事务同步到正在运行中的相关系统的缓存里去。

这种字典数据...肯定是统一管理,db 中,然后 load 到内存

缓存

???

放 js 里

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服