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

相关推荐
Hilaku9 分钟前
用好了 defineProps 才叫会用 Vue3,90% 的写法都错了
前端·javascript·vue.js
Dignity_呱18 分钟前
vue3对组件通信做了哪些升级?
前端·vue.js·面试
海奥华221 分钟前
go中的接口返回设计思想
开发语言·后端·golang
独立开阀者_FwtCoder1 小时前
最全301/302重定向指南:从SEO到实战,一篇就够了
前端·javascript·vue.js
飞川撸码5 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
roman_日积跬步-终至千里12 小时前
【Go语言基础【14】】defer与异常处理(panic、recover)
golang
TE-茶叶蛋12 小时前
Vue Fragment vs React Fragment
javascript·vue.js·react.js
Angindem12 小时前
从零搭建uniapp项目
前端·vue.js·uni-app
孔令飞13 小时前
Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践
ai·云原生·容器·golang·kubernetes
前端小白从0开始14 小时前
Vue3项目实现WPS文件预览和内容回填功能
前端·javascript·vue.js·html5·wps·文档回填·文档在线预览