2023-12-05 16:50:47 +08:00
|
|
|
package connection
|
2023-05-19 12:51:23 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"strconv"
|
|
|
|
|
2023-12-05 16:50:47 +08:00
|
|
|
"go.uber.org/zap"
|
2023-09-21 09:45:27 +08:00
|
|
|
"google.golang.org/grpc"
|
2023-05-19 12:51:23 +08:00
|
|
|
"google.golang.org/grpc/metadata"
|
|
|
|
|
2023-12-05 16:50:47 +08:00
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
2023-09-21 09:45:27 +08:00
|
|
|
"github.com/milvus-io/milvus/pkg/util"
|
|
|
|
"github.com/milvus-io/milvus/pkg/util/funcutil"
|
2023-05-19 12:51:23 +08:00
|
|
|
)
|
|
|
|
|
2023-12-05 16:50:47 +08:00
|
|
|
func ZapClientInfo(info *commonpb.ClientInfo) []zap.Field {
|
|
|
|
fields := []zap.Field{
|
|
|
|
zap.String("sdk_type", info.GetSdkType()),
|
|
|
|
zap.String("sdk_version", info.GetSdkVersion()),
|
|
|
|
zap.String("local_time", info.GetLocalTime()),
|
|
|
|
zap.String("user", info.GetUser()),
|
|
|
|
zap.String("host", info.GetHost()),
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, v := range info.GetReserved() {
|
|
|
|
fields = append(fields, zap.String(k, v))
|
|
|
|
}
|
|
|
|
|
|
|
|
return fields
|
|
|
|
}
|
|
|
|
|
|
|
|
func GetIdentifierFromContext(ctx context.Context) (int64, error) {
|
2023-05-19 12:51:23 +08:00
|
|
|
md, ok := metadata.FromIncomingContext(ctx)
|
|
|
|
if !ok {
|
|
|
|
return 0, fmt.Errorf("fail to get metadata from the context")
|
|
|
|
}
|
|
|
|
identifierContent, ok := md[util.IdentifierKey]
|
|
|
|
if !ok || len(identifierContent) < 1 {
|
|
|
|
return 0, fmt.Errorf("no identifier found in metadata")
|
|
|
|
}
|
|
|
|
identifier, err := strconv.ParseInt(identifierContent[0], 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
return 0, fmt.Errorf("failed to parse identifier: %s, error: %s", identifierContent[0], err.Error())
|
|
|
|
}
|
|
|
|
return identifier, nil
|
|
|
|
}
|
|
|
|
|
2023-11-28 15:32:31 +08:00
|
|
|
func KeepActiveInterceptor(ctx context.Context, req any, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) {
|
2023-05-19 12:51:23 +08:00
|
|
|
// We shouldn't block the normal rpc. though this may be not very accurate enough.
|
|
|
|
// On the other hand, too many goroutines will also influence the rpc.
|
|
|
|
// Not sure which way is better, since actually we already make the `keepActive` asynchronous.
|
|
|
|
go func() {
|
2023-12-05 16:50:47 +08:00
|
|
|
identifier, err := GetIdentifierFromContext(ctx)
|
2023-05-19 12:51:23 +08:00
|
|
|
if err == nil && funcutil.CheckCtxValid(ctx) {
|
2023-12-05 16:50:47 +08:00
|
|
|
GetManager().KeepActive(identifier)
|
2023-05-19 12:51:23 +08:00
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
return handler(ctx, req)
|
|
|
|
}
|