【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。在此基础上,可能还有读取其它数据库的需求,但只需要查询,不需要修改。为了防止这样的数据库被更改,导致异常,我们就需要使用具有不同权限的角色访问数据库,这样在一定程度上可以起到安全的作用。

相关推荐
琢磨先生TT20 分钟前
为什么很多后台系统功能不少,看起来却还是很廉价?
前端·vue.js·设计
一 乐2 小时前
交通感知与车路协同系统|基于springboot + vue交通感知与车路协同系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·交通感知与车路协同系统
踩着两条虫3 小时前
强强联合!VTJ.PRO 正式接入 DeepSeek V4,AI 编码能力再跃升
前端·vue.js·ai编程
Beginner x_u4 小时前
前端八股整理(Vue 02)|组件通信、生命周期、v-if 与 v-show
前端·javascript·vue.js
万物得其道者成4 小时前
Vue3 使用 Notification 浏览器通知,解决页面关闭后旧通知点击无法跳转问题
前端·vue.js·edge浏览器
一條狗4 小时前
学习日报 20260423|[特殊字符] 深度解析:Vue 3 SPA 部署到 Spring Boot 的 404/500 错误排查与完美解决方案-2
vue.js·spring boot·学习
LIO5 小时前
Vue 3 实战——搜索框检索高亮的优雅实现
前端·vue.js
_thought5 小时前
踩坑记录:Vue Devtools(Vue2版)在火狐浏览器上,未在控制台显示
前端·javascript·vue.js
军军君015 小时前
数字孪生监控大屏实战模板:交通云实时数据监控平台
前端·javascript·css·vue.js·typescript·前端框架·echarts
前端那点事6 小时前
Vue跨页面通信(8种主流方式|完整可运行Demo,Vue2/Vue3通用)
前端·vue.js