udpdata.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. new_name,b :=dealWithScoreRules(win)
  51. if b {tmp["winner"] = new_name}
  52. log.Println(new_name)
  53. } else {
  54. tmp["winner"] = queryGrpcWinner
  55. }
  56. }
  57. if win, isok := tmp["s_winner"].(string); isok {
  58. queryGrpcWinner := query_grpc(win, FindWinnerC)
  59. if queryGrpcWinner == "" {
  60. new_name,b :=dealWithScoreRules(win)
  61. if b {tmp["s_winner"] = new_name}
  62. } else {
  63. tmp["s_winner"] = queryGrpcWinner
  64. }
  65. }
  66. if agency, isok := tmp["agency"].(string); isok {
  67. queryGrpcAgency := query_grpc(agency, FindAgencyC)
  68. if queryGrpcAgency == "" {
  69. new_name,b :=dealWithScoreRules(agency)
  70. if b {tmp["agency"] = new_name}
  71. } else {
  72. tmp["agency"] = queryGrpcAgency
  73. }
  74. }
  75. if buyer, isok := tmp["buyer"].(string); isok {
  76. queryGrpcBuyer := query_grpc(buyer, FindBuyerC)
  77. if queryGrpcBuyer == "" {
  78. new_name,b :=dealWithScoreRules(buyer)
  79. if b {tmp["buyer"] = new_name}
  80. } else {
  81. tmp["buyer"] = queryGrpcBuyer
  82. }
  83. }
  84. num++
  85. }
  86. log.Println("处理完成:", num)
  87. }
  88. //grpc - 处理
  89. func query_grpc(enterprise, findC string) string {
  90. ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
  91. defer cancel()
  92. var CorpusType proto_grpc.CorpusType = proto_grpc.CorpusType_ALL
  93. switch findC {
  94. case "buyer":
  95. CorpusType = proto_grpc.CorpusType_BUYER
  96. case "agency":
  97. CorpusType = proto_grpc.CorpusType_BUYER
  98. case "winner":
  99. CorpusType = proto_grpc.CorpusType_BUYER
  100. default:
  101. CorpusType = proto_grpc.CorpusType_ALL
  102. }
  103. lenc := len(QAddrs)
  104. c := make(chan map[int]string, lenc)
  105. defer close(c)
  106. for i, v := range QAddrs {
  107. go func(index int, vc *proto_grpc.SensitiveWordsClient) {
  108. sensitiveWords, err := (*vc).Search(ctx, &proto_grpc.Request{Text: enterprise, Corpus: CorpusType})
  109. if err != nil {
  110. log.Println(index, err)
  111. return
  112. }
  113. c <- map[int]string{index: sensitiveWords.GetSensitiveWords()}
  114. return
  115. }(i, v)
  116. }
  117. result := []string{}
  118. var q int
  119. for v := range c {
  120. for _, vv := range v {
  121. if vv == "" {
  122. continue
  123. }
  124. result = append(result,vv)
  125. }
  126. q++
  127. if q >= lenc {
  128. break
  129. }
  130. }
  131. return strings.Join(result,",")
  132. }
  133. func processUdpMsg(act byte, data []byte, ra *net.UDPAddr) {
  134. task <- struct{}{}
  135. defer func() {
  136. <-task
  137. }()
  138. switch act {
  139. case OP_TYPE_DATA:
  140. var rep map[string]interface{}
  141. err := json.Unmarshal(data, &rep)
  142. if err != nil {
  143. log.Println(err)
  144. } else {
  145. sid, _ := rep["gtid"].(string)
  146. eid, _ := rep["lteid"].(string)
  147. if sid == "" || eid == "" {
  148. log.Println("err", "sid=", sid, ",eid=", eid)
  149. return
  150. }
  151. go Udpclient.WriteUdp([]byte("get:"+sid+"_"+eid), OP_NOOP, ra)
  152. log.Println("udp通知抽取id段", sid, " ", eid)
  153. QuerySensitiveWords(sid, eid)
  154. for _, m := range nextNodes {
  155. by, _ := json.Marshal(map[string]interface{}{
  156. "gtid": sid,
  157. "lteid": eid,
  158. "stype": ObjToString(m["stype"]),
  159. })
  160. err := Udpclient.WriteUdp(by, OP_TYPE_DATA, &net.UDPAddr{
  161. IP: net.ParseIP(m["addr"].(string)),
  162. Port: IntAll(m["port"]),
  163. })
  164. if err != nil {
  165. log.Println(err)
  166. }
  167. }
  168. log.Println("udp通知抽取完成,eid=", eid)
  169. }
  170. case OP_NOOP: //下个节点回应
  171. log.Println(string(data))
  172. }
  173. }