rpcpubserver.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package internal
  2. import (
  3. "os"
  4. "strings"
  5. "github.com/tal-tech/go-zero/core/discov"
  6. "github.com/tal-tech/go-zero/core/netx"
  7. )
  8. const (
  9. allEths = "0.0.0.0"
  10. envPodIp = "POD_IP"
  11. )
  12. // NewRpcPubServer returns a Server.
  13. func NewRpcPubServer(etcd discov.EtcdConf, listenOn string, opts ...ServerOption) (Server, error) {
  14. registerEtcd := func() error {
  15. pubListenOn := figureOutListenOn(listenOn)
  16. var pubOpts []discov.PubOption
  17. if etcd.HasAccount() {
  18. pubOpts = append(pubOpts, discov.WithPubEtcdAccount(etcd.User, etcd.Pass))
  19. }
  20. pubClient := discov.NewPublisher(etcd.Hosts, etcd.Key, pubListenOn, pubOpts...)
  21. return pubClient.KeepAlive()
  22. }
  23. server := keepAliveServer{
  24. registerEtcd: registerEtcd,
  25. Server: NewRpcServer(listenOn, opts...),
  26. }
  27. return server, nil
  28. }
  29. type keepAliveServer struct {
  30. registerEtcd func() error
  31. Server
  32. }
  33. func (ags keepAliveServer) Start(fn RegisterFn) error {
  34. if err := ags.registerEtcd(); err != nil {
  35. return err
  36. }
  37. return ags.Server.Start(fn)
  38. }
  39. func figureOutListenOn(listenOn string) string {
  40. fields := strings.Split(listenOn, ":")
  41. if len(fields) == 0 {
  42. return listenOn
  43. }
  44. host := fields[0]
  45. if len(host) > 0 && host != allEths {
  46. return listenOn
  47. }
  48. ip := os.Getenv(envPodIp)
  49. if len(ip) == 0 {
  50. ip = netx.InternalIp()
  51. }
  52. if len(ip) == 0 {
  53. return listenOn
  54. }
  55. return strings.Join(append([]string{ip}, fields[1:]...), ":")
  56. }