Files
open-im-server/internal/api/init.go
T

104 lines
2.6 KiB
Go
Raw Normal View History

2024-04-19 22:23:08 +08:00
package api
import (
"context"
"fmt"
"net"
"net/http"
"os"
"os/signal"
"strconv"
"syscall"
"time"
2025-01-10 14:20:43 +08:00
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
"github.com/openimsdk/tools/utils/datautil"
"github.com/openimsdk/tools/utils/network"
2024-04-19 22:23:08 +08:00
kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister"
"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics"
2024-12-27 17:34:56 +08:00
"github.com/openimsdk/tools/discovery"
2024-04-19 22:23:08 +08:00
"github.com/openimsdk/tools/errs"
"github.com/openimsdk/tools/log"
"github.com/openimsdk/tools/system/program"
)
type Config struct {
2024-05-14 18:21:36 +08:00
API config.API
Share config.Share
Discovery config.Discovery
2024-04-19 22:23:08 +08:00
}
func Start(ctx context.Context, index int, config *Config) error {
2024-05-14 18:21:36 +08:00
apiPort, err := datautil.GetElemByIndex(config.API.Api.Ports, index)
2024-04-19 22:23:08 +08:00
if err != nil {
return err
}
var client discovery.SvcDiscoveryRegistry
// Determine whether zk is passed according to whether it is a clustered deployment
2025-01-10 14:20:43 +08:00
client, err = kdisc.NewDiscoveryRegister(&config.Discovery, &config.Share, []string{
config.Share.RpcRegisterName.MessageGateway,
})
2024-04-19 22:23:08 +08:00
if err != nil {
return errs.WrapMsg(err, "failed to register discovery service")
}
var (
netDone = make(chan struct{}, 1)
netErr error
prometheusPort int
2024-04-19 22:23:08 +08:00
)
2024-12-24 10:51:38 +08:00
router, err := newGinRouter(ctx, client, config)
if err != nil {
return err
}
2024-05-14 18:21:36 +08:00
if config.API.Prometheus.Enable {
2024-04-19 22:23:08 +08:00
go func() {
prometheusPort, err = datautil.GetElemByIndex(config.API.Prometheus.Ports, index)
if err != nil {
netErr = err
netDone <- struct{}{}
return
}
2024-07-16 10:46:21 +08:00
if err := prommetrics.ApiInit(prometheusPort); err != nil && err != http.ErrServerClosed {
netErr = errs.WrapMsg(err, fmt.Sprintf("api prometheus start err: %d", prometheusPort))
2024-04-19 22:23:08 +08:00
netDone <- struct{}{}
}
}()
}
2024-05-14 18:21:36 +08:00
address := net.JoinHostPort(network.GetListenIP(config.API.Api.ListenIP), strconv.Itoa(apiPort))
2024-04-19 22:23:08 +08:00
server := http.Server{Addr: address, Handler: router}
log.CInfo(ctx, "API server is initializing", "address", address, "apiPort", apiPort, "prometheusPort", prometheusPort)
go func() {
err = server.ListenAndServe()
if err != nil && err != http.ErrServerClosed {
netErr = errs.WrapMsg(err, fmt.Sprintf("api start err: %s", server.Addr))
netDone <- struct{}{}
}
}()
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGTERM)
ctx, cancel := context.WithTimeout(context.Background(), 15*time.Second)
defer cancel()
select {
case <-sigs:
program.SIGTERMExit()
err := server.Shutdown(ctx)
if err != nil {
return errs.WrapMsg(err, "shutdown err")
}
case <-netDone:
close(netDone)
return netErr
}
return nil
}