【Go实战】Gin-Vue-Admin对db-list的疑惑

背景

Gin-Vue-Admin是开源的全栈开发平台,可以担任企业内部后台管理的职责。官网地址是:gin-vue-admin | GVA 文档站。上图为在线demo展示页面。

它的后台使用Golang(The Go Programming Language (google.cn)),基于开源的Web框架Gin(Gin Web Framework (gin-gonic.com))。

它的前台使用渐进式JavaScript框架Vue(Introduction | Vue.js (vuejs.org))。

正文

使用Gin-Vue-Admin一段时间了,对于用户配置中数据库的配置充满了疑惑。看图说话:

config.yaml的一部分

如图所示,config.yaml配置给出pgsql(也有mysql等其它数据库配置段),又给出了db-list来配置数据库,我很奇怪为啥数据库要配置在多个地方?在互联网找不到相关资料之后,我打算还是从代码的层面来了解。

首先看看Gin-Vue-Admin的后台main函数,第一行调用了core.Viper()。Viper即是第三方Go配置管理的解决方案GitHub -- spf13/viper: Go configuration with fangs,支持JSON, TOML, YAML, HCL, envfile 和 Java 属性配置文件。

上图所示,Viper内部,会使用internal.ConfigDefaultFile,也就是config.yaml文件作为配置文件。后面会通过Viper的方法将config.yaml中的信息读入全局的变量GVA_CONFIG中,也即是config.Server结构体。

config.Server结构体为:

可以看到该后台服务支持mysql、pgsql、oracle、sqlite等数据库,也支持DBList,也就是一个数据库列表。

其中,指定的几个数据库只是一个GeneralDB包装,如Mysql、Pgsql。它们只是Dsn函数的实现不同。

而SpecializedDB,在GeneralDB的基础上,还加上了Disable、Type、AliasName三个变量。用于区分是什么数据库。

从中,我们就能得知,这些数据库结构,都是GeneralDB,也对应于config.yaml中数据库的配置。

也就是说,它们的作用没什么不同,都是用于和数据库进行连接。通常我们做开发,指定一个数据库就够用了,配置指定数据库的结构体即可。那么,为什么要设置多个数据库连接呢?

我考虑到有时,我们对安全性有更高的要求。

比如,Gin-Vue-Admin使用某个数据库,对该数据库进行CRUD。在此基础上,可能还有读取其它数据库的需求,但只需要查询,不需要修改。为了防止这样的数据库被更改,导致异常,我们就需要使用具有不同权限的角色访问数据库,这样在一定程度上可以起到安全的作用。

相关推荐
Xin_z_14 分钟前
Vue3 + Sticky 锚点跳转被遮挡问题解决方案
前端·javascript·vue.js
荒诞英雄30 分钟前
Vue3 Teleport我真是没招了
前端·vue.js
B站计算机毕业设计超人34 分钟前
计算机毕业设计Django+Vue.js高考推荐系统 高考可视化 大数据毕业设计(源码+LW文档+PPT+详细讲解)
大数据·vue.js·hadoop·django·毕业设计·课程设计·推荐算法
B站计算机毕业设计超人38 分钟前
计算机毕业设计Django+Vue.js音乐推荐系统 音乐可视化 大数据毕业设计 (源码+文档+PPT+讲解)
大数据·vue.js·hadoop·python·spark·django·课程设计
百思可瑞教育38 分钟前
Vue 前端与 Node.js 后端文件上传与处理实现
前端·javascript·vue.js·前端框架·node.js·ecmascript·百思可瑞教育
追风筝的人er1 小时前
企业管理系统如何实现自定义首页与千人千面?RuoYi Office 给出了完整方案
vue.js·spring boot·spring cloud
TT_Close1 小时前
“啪啪啪”三下键盘,极速拉起你的 uni-app 项目!
vue.js·uni-app·前端工程化
柯南95271 小时前
Electron 无边框窗口拖拽实现
vue.js·electron
顾青3 小时前
仅仅一行 CSS,竟让 2000 个节点的页面在弹框时卡成 PPT?
前端·vue.js·性能优化
用户4099322502123 小时前
如何在Vue3中优化生命周期钩子性能并规避常见陷阱?
前端·vue.js·trae