beego自带有admin模块,有健康检查、性能调试、访问统计、计划任务等功能。
开启方法:
EnableAdmin = true
健康检查测试
在main.go的同一个目录下面创建一个check.go的文件
需要注意的是beego v2中,加入健康检查要用
admin.AddHealthCheck("database",&DatabaseCheck{}) 而不是
toolbox.AddHealthCheck("database",&DatabaseCheck{}),否则健康检查就会不生效
check.go
package main
import (
"database/sql"
"errors"
"github.com/beego/beego/v2/core/admin"
)
type DatabaseCheck struct {
}
func (*DatabaseCheck) Check() error {
//用户名密码:root\123456
//@tcp:已tcp连接
//(192.168.84.152:13306):数据库ip和端口号
//sql_demo:具体数据库
dsn := "root:root@tcp(localhost:3306)/beego"
//open函数只能检查格式是否正确,不正确立即中断程序
db, err := sql.Open("mysql", dsn)
if err != nil {
return errors.New("mysql connect fail1")
}
//判断数据库是否连接成功,可使用db中的Ping参数
err = db.Ping()
if err != nil {
return errors.New("mysql connect fail")
} else {
return nil
}
}
func init() {
admin.AddHealthCheck("database", &DatabaseCheck{})
}
main.go
在init方法中加入 orm.RegisterDriver("mysql", orm.DRMySQL)
package main
import (
_ "myproject/routers"
"github.com/beego/beego/v2/client/orm"
"github.com/beego/beego/v2/core/logs"
beego "github.com/beego/beego/v2/server/web"
_ "github.com/go-sql-driver/mysql" // 注意此行必须加
)
func init() {
orm.RegisterDriver("mysql", orm.DRMySQL)
_ = orm.RegisterDataBase("default", "mysql", "root:root@tcp(localhost:3306)/beego?charset=utf8")
logs.SetLogger("console")
}
func main() {
beego.Run()
}
启动项目 bee run
访问 localhost:8088/healthcheck
database的检查是正常的