- 服务配置
- go.mod
- 配置文件
- 启动设置
服务配置
我们使用go.mod
来管理项目依赖。
go.mod
/go.mod
module github.com/gogf/gf-demos
require github.com/gogf/gf latest
其中注意module
名称设置为github.com/gogf/gf-demos
。
在实际项目的包依赖管理中会遇到很多细节问题,因此我们为您准备了《项目依赖管理》章节。
配置文件
这里主要配置了数据库的连接信息。
/config/config.toml
# 应用系统设置
[setting]
logpath = "/tmp/log/gf-demos"
# 数据库连接
[database]
[[database.default]]
host = "127.0.0.1"
port = "3306"
user = "root"
pass = "12345678"
name = "test"
type = "mysql"
启动设置
/boot/boot.go
package boot
import (
"github.com/gogf/gf/g"
"github.com/gogf/gf/g/os/glog"
"github.com/gogf/gf/g/net/ghttp"
)
func init() {
v := g.View()
c := g.Config()
s := g.Server()
// 模板引擎配置
v.AddPath("template")
v.SetDelimiters("${", "}")
// glog配置
logpath := c.GetString("setting.logpath")
glog.SetPath(logpath)
glog.SetStdoutPrint(true)
// Web Server配置
s.SetServerRoot("public")
s.SetLogPath(logpath)
s.SetNameToUriType(ghttp.NAME_TO_URI_TYPE_ALLLOWER)
s.SetErrorLogEnabled(true)
s.SetAccessLogEnabled(true)
s.SetPort(8199)
}
可以看到,我们的包初始化管理使用了包初始化方法init
,这样做的好处是可以在boot
目录中使用不同的go
文件注册不同的init
来分别实现不同的初始化配置管理,在业务比较复杂的项目中比较实用。如果仅仅是需要一个初始化方法即可完成配置,那么开发者可以自定义一个初始化方法,在main
包中直接调用即可。