milvus/proxy/generate_entity_ids/server/generate_entity_ids.go
cai.zhang ce95fd4f20 Add interface for generated_ids
Signed-off-by: cai.zhang <cai.zhang@zilliz.com>
2020-09-04 11:25:20 +08:00

63 lines
955 B
Go

package main
import (
"context"
pb "github.com/czs007/suvlim/proxy/generate_entity_ids/proto"
"google.golang.org/grpc"
"log"
"net"
"sync"
"time"
)
var (
currentID int64 = 0
)
const (
port = ":10087"
)
type server struct {
pb.UnimplementedGreeterServer
}
func (s *server) GetEntityID(ctx context.Context, in *pb.Request) (*pb.Reply, error) {
var mutex sync.Mutex
var ids []int64
length := in.Length
for i := int64(0); i < length; i++ {
go func() {
mutex.Lock()
ids = append(ids, currentID)
currentID++
mutex.Unlock()
}()
}
for{
if int64(len(ids)) < length {
time.Sleep(time.Second)
} else {
break
}
}
return &pb.Reply{Ids: ids}, nil
}
func main() {
listen, err := net.Listen("tcp", port)
if err != nil{
log.Fatalf("failed to listen: %v", err)
}
s := grpc.NewServer()
pb.RegisterGreeterServer(s, &server{})
if err := s.Serve(listen); err != nil{
log.Fatalf("failed to serve: %v", err)
}
}