db 测试数据库
This commit is contained in:
parent
7cab8f82d7
commit
935240b36b
|
@ -39,3 +39,10 @@ func DbDel(c *gin.Context) {
|
||||||
err := db_service.DbDel(request)
|
err := db_service.DbDel(request)
|
||||||
controllers.HandRes(c, nil, err)
|
controllers.HandRes(c, nil, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 测试连接
|
||||||
|
func DbTest(c *gin.Context) {
|
||||||
|
request := controllers.GetRequest(c).(*backend.DbTestRequest)
|
||||||
|
err := db_service.DbTest(request)
|
||||||
|
controllers.HandRes(c, nil, err)
|
||||||
|
}
|
||||||
|
|
|
@ -29,6 +29,10 @@ type DbAddRequest struct {
|
||||||
Status int `json:"status" form:"status" example:"1"`
|
Status int `json:"status" form:"status" example:"1"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type DbTestRequest struct {
|
||||||
|
Source string `json:"source" validate:"required" form:"source" example:""`
|
||||||
|
}
|
||||||
|
|
||||||
type DbEditRequest struct {
|
type DbEditRequest struct {
|
||||||
DbId int `json:"db_id" validate:"required" form:"db_id" example:""`
|
DbId int `json:"db_id" validate:"required" form:"db_id" example:""`
|
||||||
DbName string `json:"db_name" validate:"required" form:"db_name" example:""`
|
DbName string `json:"db_name" validate:"required" form:"db_name" example:""`
|
||||||
|
|
|
@ -22,6 +22,7 @@ var BackendRequestMap = map[string]func() interface{}{
|
||||||
common.ADMIN_OAUTH_V1 + "/sql/add": func() interface{} { return new(backend.DbAddRequest) },
|
common.ADMIN_OAUTH_V1 + "/sql/add": func() interface{} { return new(backend.DbAddRequest) },
|
||||||
common.ADMIN_OAUTH_V1 + "/sql/edit": func() interface{} { return new(backend.DbEditRequest) },
|
common.ADMIN_OAUTH_V1 + "/sql/edit": func() interface{} { return new(backend.DbEditRequest) },
|
||||||
common.ADMIN_OAUTH_V1 + "/sql/del": func() interface{} { return new(backend.DbDeleteRequest) },
|
common.ADMIN_OAUTH_V1 + "/sql/del": func() interface{} { return new(backend.DbDeleteRequest) },
|
||||||
|
common.ADMIN_OAUTH_V1 + "/sql/test": func() interface{} { return new(backend.DbTestRequest) },
|
||||||
|
|
||||||
// 消息渠道
|
// 消息渠道
|
||||||
common.ADMIN_OAUTH_V1 + "/channel/create": func() interface{} { return new(backend.ReportChannelCreateRequest) },
|
common.ADMIN_OAUTH_V1 + "/channel/create": func() interface{} { return new(backend.ReportChannelCreateRequest) },
|
||||||
|
|
|
@ -44,6 +44,7 @@ func RegisterAdminRoute(router *gin.Engine) {
|
||||||
sql.POST("/add", backend.DbAdd)
|
sql.POST("/add", backend.DbAdd)
|
||||||
sql.POST("/edit", backend.DbEdit)
|
sql.POST("/edit", backend.DbEdit)
|
||||||
sql.DELETE("/del", backend.DbDel)
|
sql.DELETE("/del", backend.DbDel)
|
||||||
|
sql.POST("/test", backend.DbTest)
|
||||||
}
|
}
|
||||||
//任务
|
//任务
|
||||||
cmd := v1.Group("/cmd")
|
cmd := v1.Group("/cmd")
|
||||||
|
|
|
@ -1,10 +1,15 @@
|
||||||
package db_service
|
package db_service
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"cron_admin/app/constants/common"
|
"cron_admin/app/constants/common"
|
||||||
|
"cron_admin/app/constants/errorcode"
|
||||||
"cron_admin/app/http/entities/backend"
|
"cron_admin/app/http/entities/backend"
|
||||||
"cron_admin/app/models/crondbmodel"
|
"cron_admin/app/models/crondbmodel"
|
||||||
"cron_admin/app/utils/mapstructure"
|
"cron_admin/app/utils/mapstructure"
|
||||||
|
"database/sql"
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
"xorm.io/builder"
|
"xorm.io/builder"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -60,3 +65,21 @@ func DbDel(request *backend.DbDeleteRequest) (err error) {
|
||||||
_, err = crondbmodel.GetInstance().GetDb().ID(request.DbId).Delete(&crondbmodel.CronDb{})
|
_, err = crondbmodel.GetInstance().GetDb().ID(request.DbId).Delete(&crondbmodel.CronDb{})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func DbTest(request *backend.DbTestRequest) (err error) {
|
||||||
|
// 打开数据库连接
|
||||||
|
db, err := sql.Open("mysql", request.Source)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer db.Close()
|
||||||
|
// 使用 context 来设置 Ping 的超时时间
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)
|
||||||
|
defer cancel()
|
||||||
|
// 测试连接
|
||||||
|
err = db.PingContext(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return errorcode.NewBusinessErr(301, fmt.Sprintf("数据库连接失败: %v", err))
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue