kenaito-dns/main.go

82 lines
2.3 KiB
Go
Raw Normal View History

2024-11-07 21:34:47 +08:00
package main
2024-11-07 23:54:55 +08:00
/*
* @Description 服务入口
* @Author www.odboy.cn
* @Date 20241107
*/
2024-11-07 21:34:47 +08:00
import (
2024-11-07 23:54:55 +08:00
"fmt"
"github.com/gin-gonic/gin"
2024-11-07 21:34:47 +08:00
"github.com/miekg/dns"
2024-11-07 23:54:55 +08:00
"kenaito-dns/config"
"kenaito-dns/controller"
"kenaito-dns/core"
"net/http"
"time"
2024-11-07 21:34:47 +08:00
)
func main() {
2024-11-07 23:54:55 +08:00
fmt.Println("[app] [info] kenaito-dns version = " + config.AppVersion)
go initDNSServer()
initRestfulServer()
}
func initDNSServer() {
2024-11-07 21:34:47 +08:00
// 注册 DNS 请求处理函数
2024-11-07 23:54:55 +08:00
dns.HandleFunc(".", core.HandleDNSRequest)
2024-11-07 21:34:47 +08:00
// 设置服务器地址和协议
2024-11-07 23:54:55 +08:00
server := &dns.Server{Addr: config.DnsServerPort, Net: "udp"}
2024-11-07 21:34:47 +08:00
// 开始监听
2024-11-07 23:54:55 +08:00
fmt.Printf("[dns] [info] Starting DNS server on %s\n", server.Addr)
2024-11-07 21:34:47 +08:00
if err := server.ListenAndServe(); err != nil {
2024-11-07 23:54:55 +08:00
fmt.Printf("[dns] [error] Failed to start DNS server: %s\n", err.Error())
2024-11-07 21:34:47 +08:00
}
}
2024-11-07 23:54:55 +08:00
func initRestfulServer() {
gin.SetMode(config.WebMode)
// 创建一个新的 Gin 引擎实例,使用 gin.New() 方法来创建一个不包含任何默认中间件的实例
router := gin.New()
// LoggerWithFormatter 中间件会写入日志到 gin.DefaultWriter
// 默认 gin.DefaultWriter = os.Stdout
// 自定义的日志格式化函数
router.Use(gin.LoggerWithFormatter(func(param gin.LogFormatterParams) string {
// 自定义日志格式
return fmt.Sprintf("[gin] [info] %s [Request] [%s] \"%s %s %s %d %s \"%s\" %s\"\n",
// 请求时间戳
param.TimeStamp.Format(config.AppTimeFormat),
// 客户端 IP 地址
param.ClientIP,
// 请求方法 (GET, POST 等)
param.Method,
// 请求路径
param.Path,
// 请求协议
param.Request.Proto,
// 响应状态码
param.StatusCode,
// 请求延迟时间
param.Latency,
// 用户代理
param.Request.UserAgent(),
// 错误信息(如果有的话)
param.ErrorMessage,
)
}))
// 使用 Recovery 中间件,处理任何出现的错误,并防止服务崩溃
router.Use(gin.Recovery())
server := &http.Server{
Addr: config.WebServerPort,
Handler: router,
ReadTimeout: config.WebReadTimeout * time.Second,
WriteTimeout: config.WebWriteTimeout * time.Second,
}
controller.InitRestFunc(router)
fmt.Printf("[gin] [info] Start Gin server: %s\n", config.WebServerPort)
err := server.ListenAndServe()
if err != nil {
fmt.Printf("[gin] [error] Failed to start Gin server: %s\n", config.WebServerPort)
2024-11-07 21:34:47 +08:00
}
}