main.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. package main
  2. import (
  3. "encoding/json"
  4. "flag"
  5. "log"
  6. mu "mfw/util"
  7. "net"
  8. qu "qfw/util"
  9. "time"
  10. "gopkg.in/mgo.v2/bson"
  11. )
  12. var udpclient mu.UdpClient //udp对象
  13. var nextNodes []map[string]interface{}
  14. var startDate, endDate, ip, port, stype, sid, eid string
  15. func main() {
  16. //2015-11-03,2017-04-01
  17. //2017-04-01,2017-06-01
  18. //2017-06-01,2018-06-01
  19. //2018-06-01,2019-02-20
  20. /*
  21. ObjectId("5d767728a5cb26b9b7748868")
  22. ObjectId("5d77c881a5cb26b9b7de209d") //9W条数据
  23. 56404035af5374672e00059c
  24. 5d4da9c8a5cb26b9b7b6bbcd 100万
  25. */
  26. flag.StringVar(&sid, "sid", "", "开始id")
  27. flag.StringVar(&eid, "eid", "", "结束id")
  28. flag.StringVar(&startDate, "start", "", "开始日期2006-01-02")
  29. flag.StringVar(&endDate, "end", "", "结束日期2006-01-02")
  30. flag.StringVar(&ip, "ip", "127.0.0.1", "ip")
  31. flag.StringVar(&port, "port", "1112", "dup端口")
  32. flag.StringVar(&stype, "stype", "", "stype")
  33. flag.Parse()
  34. var startid, endid bson.ObjectId
  35. if sid != "" && eid != "" {
  36. startid = qu.StringTOBsonId(sid)
  37. endid = qu.StringTOBsonId(eid)
  38. } else {
  39. start, _ := time.ParseInLocation(qu.Date_Short_Layout, startDate, time.Local)
  40. end, _ := time.ParseInLocation(qu.Date_Short_Layout, endDate, time.Local)
  41. startid = bson.NewObjectIdWithTime(start)
  42. endid = bson.NewObjectIdWithTime(end)
  43. }
  44. log.Println(startid, endid, ip, port, stype)
  45. udpclient = mu.UdpClient{Local: ":1470", BufSize: 1024}
  46. udpclient.Listen(processUdpMsg)
  47. by, _ := json.Marshal(map[string]interface{}{
  48. "gtid": startid,
  49. "lteid": endid,
  50. "stype": stype,
  51. })
  52. udpclient.WriteUdp(by, mu.OP_TYPE_DATA, &net.UDPAddr{
  53. IP: net.ParseIP(ip),
  54. Port: qu.IntAll(port),
  55. })
  56. b := make(chan bool, 1)
  57. <-b
  58. }
  59. func processUdpMsg(act byte, data []byte, ra *net.UDPAddr) {
  60. switch act {
  61. case mu.OP_TYPE_DATA:
  62. var mapInfo map[string]interface{}
  63. err := json.Unmarshal(data, &mapInfo)
  64. if err != nil {
  65. log.Println(err)
  66. } else {
  67. log.Println(mapInfo)
  68. }
  69. case mu.OP_NOOP: //下个节点回应
  70. log.Println("发送成功", string(data))
  71. }
  72. }