Files
platform/cmd/main/main.go

56 lines
897 B
Go
Raw Normal View History

2025-03-15 16:07:45 +08:00
package main
import (
"log/slog"
"os"
"os/signal"
"platform/pkg/env"
"platform/pkg/logs"
2025-03-15 16:07:45 +08:00
"platform/web"
"syscall"
)
func main() {
// 退出信号
shutdown := make(chan os.Signal, 1)
signal.Notify(shutdown, syscall.SIGINT, syscall.SIGTERM)
// 初始化应用
2025-03-18 10:13:57 +08:00
env.Init()
logs.Init()
// 创建服务
2025-03-15 16:07:45 +08:00
app, err := web.New(&web.Config{
Listen: ":8080",
})
if err != nil {
2025-03-18 17:57:07 +08:00
slog.Error("Failed to create server", slog.Any("err", err))
2025-03-15 16:07:45 +08:00
return
}
// 异步运行服务
2025-03-15 16:07:45 +08:00
errCh := make(chan error)
defer close(errCh)
go func() {
err := app.Run()
2025-03-15 16:07:45 +08:00
if err != nil {
2025-03-18 17:57:07 +08:00
slog.Error("Failed to run server", slog.Any("err", err))
2025-03-15 16:07:45 +08:00
errCh <- err
}
errCh <- nil
}()
// 关闭服务
select {
case err = <-errCh:
2025-03-15 16:07:45 +08:00
case <-shutdown:
2025-03-18 17:57:07 +08:00
slog.Info("Received shutdown signal")
2025-03-15 16:07:45 +08:00
app.Stop()
err = <-errCh
}
if err != nil {
slog.Error("Server error", slog.Any("err", err))
}
2025-03-15 16:07:45 +08:00
}