You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.7 KiB
67 lines
1.7 KiB
3 years ago
|
package statistics
|
||
|
|
||
|
import (
|
||
|
"Open_IM/pkg/common/config"
|
||
|
//"Open_IM/pkg/common/constant"
|
||
|
//"Open_IM/pkg/common/db"
|
||
|
//imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model"
|
||
|
"Open_IM/pkg/common/log"
|
||
|
//cp "Open_IM/pkg/common/utils"
|
||
|
"Open_IM/pkg/grpc-etcdv3/getcdv3"
|
||
|
pbStatistics "Open_IM/pkg/proto/statistics"
|
||
|
//open_im_sdk "Open_IM/pkg/proto/sdk_ws"
|
||
|
"Open_IM/pkg/utils"
|
||
|
//"context"
|
||
|
"net"
|
||
|
"strconv"
|
||
|
"strings"
|
||
|
|
||
|
"google.golang.org/grpc"
|
||
|
)
|
||
|
|
||
|
type statisticsServer struct {
|
||
|
rpcPort int
|
||
|
rpcRegisterName string
|
||
|
etcdSchema string
|
||
|
etcdAddr []string
|
||
|
}
|
||
|
|
||
|
func NewStatisticsGroupServer(port int) *statisticsServer {
|
||
|
log.NewPrivateLog("group")
|
||
|
return &statisticsServer{
|
||
|
rpcPort: port,
|
||
|
rpcRegisterName: config.Config.RpcRegisterName.OpenImGroupName,
|
||
|
etcdSchema: config.Config.Etcd.EtcdSchema,
|
||
|
etcdAddr: config.Config.Etcd.EtcdAddr,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (s *statisticsServer) Run() {
|
||
|
log.NewInfo("0", "group rpc start ")
|
||
|
ip := utils.ServerIP
|
||
|
registerAddress := ip + ":" + strconv.Itoa(s.rpcPort)
|
||
|
//listener network
|
||
|
listener, err := net.Listen("tcp", registerAddress)
|
||
|
if err != nil {
|
||
|
log.NewError("0", "Listen failed ", err.Error(), registerAddress)
|
||
|
return
|
||
|
}
|
||
|
log.NewInfo("0", "listen network success, ", registerAddress, listener)
|
||
|
defer listener.Close()
|
||
|
//grpc server
|
||
|
srv := grpc.NewServer()
|
||
|
defer srv.GracefulStop()
|
||
|
//Service registers with etcd
|
||
|
pbStatistics.RegisterUserServer(srv, s)
|
||
|
err = getcdv3.RegisterEtcd(s.etcdSchema, strings.Join(s.etcdAddr, ","), ip, s.rpcPort, s.rpcRegisterName, 10)
|
||
|
if err != nil {
|
||
|
log.NewError("0", "RegisterEtcd failed ", err.Error())
|
||
|
return
|
||
|
}
|
||
|
err = srv.Serve(listener)
|
||
|
if err != nil {
|
||
|
log.NewError("0", "Serve failed ", err.Error())
|
||
|
return
|
||
|
}
|
||
|
log.NewInfo("0", "group rpc success")
|
||
|
}
|