udpdata.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. // extractudp
  2. package util
  3. import (
  4. "context"
  5. "encoding/json"
  6. "go.mongodb.org/mongo-driver/bson/primitive"
  7. "log"
  8. "net"
  9. "sensitiveWords.udp/proto_grpc"
  10. "strings"
  11. "time"
  12. )
  13. var task chan struct{} = make(chan struct{}, 1)
  14. var Udpclient UdpClient //udp对象
  15. var nextNodes []map[string]interface{}
  16. //udp通知抽取
  17. func ExtractUdp() {
  18. nextNodes = ObjArrToMapArr(Config["nextNode"].([]interface{}))
  19. Udpclient = UdpClient{Local: ":" + ObjToString(Config["udpport"]), BufSize: 1024}
  20. log.Println("udp start ", Config["udpport"])
  21. Udpclient.Listen(processUdpMsg)
  22. /*//临时测试
  23. sid := "1fffffffffffffffffffffff"
  24. eid := "9fffffffffffffffffffffff"
  25. QuerySensitiveWords(sid,eid )*/
  26. }
  27. func QuerySensitiveWords(sid, eid string) {
  28. log.Println("QuerySensitiveWords:", sid, eid)
  29. objSid, err := primitive.ObjectIDFromHex(sid)
  30. if err != nil {
  31. log.Println("转换sid err", err)
  32. return
  33. }
  34. objEid, err := primitive.ObjectIDFromHex(eid)
  35. if err != nil {
  36. log.Println("转换eid err", err)
  37. return
  38. }
  39. var num int64
  40. iter := QfwMgo85.GetMgoConn().C(Collection).Find(map[string]interface{}{
  41. "_id": map[string]interface{}{
  42. "$gte": objSid,
  43. "$lte": objEid,
  44. },
  45. }).Select(Fields).Iter()
  46. for tmp := map[string]interface{}{}; iter.Next(&tmp); tmp = map[string]interface{}{} {
  47. if win, isok := tmp["winner"].(string); isok {
  48. queryGrpcWinner := query_grpc(win, FindWinnerC)
  49. if queryGrpcWinner == "" {
  50. } else {
  51. tmp["winner"] = queryGrpcWinner
  52. }
  53. }
  54. if win, isok := tmp["s_winner"].(string); isok {
  55. queryGrpcWinner := query_grpc(win, FindWinnerC)
  56. if queryGrpcWinner == "" {
  57. } else {
  58. tmp["s_winner"] = queryGrpcWinner
  59. }
  60. }
  61. if agency, isok := tmp["agency"].(string); isok {
  62. queryGrpcAgency := query_grpc(agency, FindAgencyC)
  63. if queryGrpcAgency == "" {
  64. } else {
  65. tmp["agency"] = queryGrpcAgency
  66. }
  67. }
  68. if buyer, isok := tmp["buyer"].(string); isok {
  69. queryGrpcBuyer := query_grpc(buyer, FindBuyerC)
  70. if queryGrpcBuyer == "" {
  71. } else {
  72. tmp["buyer"] = queryGrpcBuyer
  73. }
  74. }
  75. num++
  76. }
  77. log.Println("处理完成:", num)
  78. }
  79. //grpc - 处理
  80. func query_grpc(enterprise, findC string) string {
  81. ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
  82. defer cancel()
  83. var CorpusType proto_grpc.CorpusType = proto_grpc.CorpusType_ALL
  84. switch findC {
  85. case "buyer":
  86. CorpusType = proto_grpc.CorpusType_BUYER
  87. case "agency":
  88. CorpusType = proto_grpc.CorpusType_BUYER
  89. case "winner":
  90. CorpusType = proto_grpc.CorpusType_BUYER
  91. default:
  92. CorpusType = proto_grpc.CorpusType_ALL
  93. }
  94. lenc := len(QAddrs)
  95. c := make(chan map[int]string, lenc)
  96. defer close(c)
  97. for i, v := range QAddrs {
  98. go func(index int, vc *proto_grpc.SensitiveWordsClient) {
  99. sensitiveWords, err := (*vc).Search(ctx, &proto_grpc.Request{Text: enterprise, Corpus: CorpusType})
  100. if err != nil {
  101. log.Println(index, err)
  102. return
  103. }
  104. c <- map[int]string{index: sensitiveWords.GetSensitiveWords()}
  105. return
  106. }(i, v)
  107. }
  108. result := []string{}
  109. var q int
  110. for v := range c {
  111. for _, vv := range v {
  112. if vv == "" {
  113. continue
  114. }
  115. result = append(result,vv)
  116. }
  117. q++
  118. if q >= lenc {
  119. break
  120. }
  121. }
  122. return strings.Join(result,",")
  123. }
  124. func processUdpMsg(act byte, data []byte, ra *net.UDPAddr) {
  125. task <- struct{}{}
  126. defer func() {
  127. <-task
  128. }()
  129. switch act {
  130. case OP_TYPE_DATA:
  131. var rep map[string]interface{}
  132. err := json.Unmarshal(data, &rep)
  133. if err != nil {
  134. log.Println(err)
  135. } else {
  136. sid, _ := rep["gtid"].(string)
  137. eid, _ := rep["lteid"].(string)
  138. if sid == "" || eid == "" {
  139. log.Println("err", "sid=", sid, ",eid=", eid)
  140. return
  141. }
  142. go Udpclient.WriteUdp([]byte("get:"+sid+"_"+eid), OP_NOOP, ra)
  143. log.Println("udp通知抽取id段", sid, " ", eid)
  144. QuerySensitiveWords(sid, eid)
  145. for _, m := range nextNodes {
  146. by, _ := json.Marshal(map[string]interface{}{
  147. "gtid": sid,
  148. "lteid": eid,
  149. "stype": ObjToString(m["stype"]),
  150. })
  151. err := Udpclient.WriteUdp(by, OP_TYPE_DATA, &net.UDPAddr{
  152. IP: net.ParseIP(m["addr"].(string)),
  153. Port: IntAll(m["port"]),
  154. })
  155. if err != nil {
  156. log.Println(err)
  157. }
  158. }
  159. log.Println("udp通知抽取完成,eid=", eid)
  160. }
  161. case OP_NOOP: //下个节点回应
  162. log.Println(string(data))
  163. }
  164. }