woj-server/internal/app/server/server.go

96 lines
2.4 KiB
Go
Raw Normal View History

package server
2022-09-07 23:34:37 +08:00
import (
"context"
2023-12-18 20:55:37 +08:00
"errors"
2022-09-07 23:34:37 +08:00
"fmt"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/api/consumer"
2023-07-15 16:19:49 +08:00
"git.0x7f.app/WOJ/woj-server/internal/misc/config"
"git.0x7f.app/WOJ/woj-server/internal/misc/log"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/model"
2024-01-06 19:26:18 +08:00
"git.0x7f.app/WOJ/woj-server/internal/repo/db"
2023-07-15 16:19:49 +08:00
"git.0x7f.app/WOJ/woj-server/internal/web/router"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/pkg/utils"
"git.0x7f.app/WOJ/woj-server/pkg/zapasynq"
"github.com/hibiken/asynq"
2023-07-15 16:19:49 +08:00
"github.com/samber/do"
2022-09-07 23:34:37 +08:00
"go.uber.org/zap"
"net/http"
"os"
"os/signal"
"runtime"
2022-09-07 23:34:37 +08:00
"syscall"
"time"
)
func RunServerMigrate(i *do.Injector) error {
2024-01-06 19:26:18 +08:00
do.MustInvoke[db.Service](i).Migrate()
return nil
2023-12-19 01:09:02 +08:00
}
2023-12-18 20:55:37 +08:00
func RunServer(i *do.Injector) error {
2023-07-15 16:19:49 +08:00
conf := do.MustInvoke[config.Service](i).GetConfig()
slog := do.MustInvoke[log.Service](i).GetLogger("app.server")
2022-09-07 23:34:37 +08:00
2023-12-18 20:55:37 +08:00
// Prepare Router
2023-07-15 16:19:49 +08:00
routers := do.MustInvoke[router.Service](i).GetRouter()
2022-09-07 23:34:37 +08:00
2022-09-08 22:00:25 +08:00
// Create Server
2023-07-15 16:19:49 +08:00
addr := fmt.Sprintf("%s:%d", conf.WebServer.Address, conf.WebServer.Port)
2022-09-07 23:34:37 +08:00
server := &http.Server{
Addr: addr,
Handler: routers,
2022-09-07 23:34:37 +08:00
}
2022-09-08 22:00:25 +08:00
// Run Server
2022-09-07 23:34:37 +08:00
go func() {
2023-12-18 20:55:37 +08:00
if err := server.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
2023-07-15 16:19:49 +08:00
slog.Fatal("ListenAndServe Failed", zap.Error(err))
2022-09-07 23:34:37 +08:00
}
}()
// Create Queue
queueMux := asynq.NewServeMux()
{
2023-07-15 16:19:49 +08:00
handler := consumer.NewConsumer(i)
queueMux.HandleFunc(model.TypeProblemUpdate, handler.ProblemUpdate)
queueMux.HandleFunc(model.TypeSubmitUpdate, handler.SubmitUpdate)
}
queueSrv := asynq.NewServer(
asynq.RedisClientOpt{
Addr: fmt.Sprintf("%s:%d", conf.Redis.Address, conf.Redis.Port),
2023-07-15 16:19:49 +08:00
Password: conf.Redis.Password,
DB: conf.Redis.QueueDb,
},
asynq.Config{
2022-10-30 22:40:59 +08:00
Concurrency: utils.If(runtime.NumCPU() > 1, runtime.NumCPU()-1, 1),
2023-07-15 16:19:49 +08:00
Logger: zapasynq.New(slog),
Queues: map[string]int{model.QueueServer: 1},
},
)
// Run Queue
if err := queueSrv.Start(queueMux); err != nil {
2023-07-15 16:19:49 +08:00
slog.Fatal("queueSrv.Start Failed", zap.Error(err))
}
2022-09-07 23:34:37 +08:00
// Handle SIGINT and SIGTERM.
quit := make(chan os.Signal, 1)
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
<-quit
2023-07-15 16:19:49 +08:00
slog.Info("Shutting down server ...")
2022-09-07 23:34:37 +08:00
// Graceful Shutdown Server
2022-09-07 23:34:37 +08:00
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
err := server.Shutdown(ctx)
if err != nil {
2023-07-15 16:19:49 +08:00
slog.Warn("Server Shutdown Failed", zap.Error(err))
2022-09-08 22:00:25 +08:00
}
// Graceful Shutdown Queue
queueSrv.Shutdown()
2022-09-07 23:34:37 +08:00
return err
}