client.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package odbclient
  2. import (
  3. "context"
  4. "fmt"
  5. "runtime"
  6. "strings"
  7. ccfg "git.wecise.com/wecise/common/matrix/cfg"
  8. clog "git.wecise.com/wecise/common/matrix/logger"
  9. "git.wecise.com/wecise/odb-go/odb"
  10. "git.wecise.com/wecise/odb-go/odb/eventmsg"
  11. "github.com/scylladb/go-set/strset"
  12. )
  13. var cfg = ccfg.MConfig()
  14. var log = clog.New().WithConfig(cfg, "log")
  15. func init() {
  16. log.Info("cpu limit", 1)
  17. runtime.GOMAXPROCS(1)
  18. }
  19. var odbcfg *odb.Config
  20. func init() {
  21. odbpath := cfg.GetStrings("ODBPATH", "127.0.0.1:11001,47.92.151.165:11001")
  22. keyspace := cfg.GetString("KEYSPACE", "oktest")
  23. poolsize := cfg.GetInt("POOLSIZE", 0)
  24. odbpaths := strset.New()
  25. for _, p := range odbpath {
  26. odbpaths.Add(strings.Split(p, ",")...)
  27. }
  28. odbcfg = &odb.Config{
  29. Hosts: odbpaths.List(),
  30. Keyspace: keyspace,
  31. User: fmt.Sprint("测试客户端", cfg.GetString("N")),
  32. Pass: "********",
  33. PoolSize: poolsize,
  34. Debug: true,
  35. }
  36. }
  37. func Config() *odb.Config {
  38. return odbcfg
  39. }
  40. func NewClient() (c odb.Client, err error) {
  41. client, err := odb.NewClient(odbcfg)
  42. if err != nil {
  43. return nil, err
  44. }
  45. return client, nil
  46. }
  47. func Subscribe(client odb.Client, topic string) {
  48. sub := client.Subscribe(context.Background(), topic)
  49. go func() {
  50. defer func() {
  51. if err := sub.Unsubscribe(context.Background()); err != nil {
  52. log.Error(err)
  53. return
  54. }
  55. }()
  56. for m := range sub.Channel() {
  57. oem, err := eventmsg.FromMsgpack([]byte(m.Payload))
  58. if err != nil {
  59. log.Error(err)
  60. }
  61. log.Info(topic + " received " + m.Payload + "\n" + oem.YamlString())
  62. }
  63. }()
  64. }