main.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "log"
  6. "app.yhyue.com/moapp/jybase/common"
  7. elastic "app.yhyue.com/moapp/jybase/es"
  8. "app.yhyue.com/moapp/jybase/mongodb"
  9. "app.yhyue.com/moapp/jybase/mysql"
  10. "app.yhyue.com/moapp/jybase/redis"
  11. "github.com/robfig/cron"
  12. )
  13. var (
  14. cfg = new(Config)
  15. Mysql *mysql.Mysql
  16. TiDb *mysql.Mysql
  17. TiDbData *mysql.Mysql
  18. TiDbPower *mysql.Mysql
  19. ThirdParty *mysql.Mysql
  20. Jyactivities *mysql.Mysql
  21. Base *mysql.Mysql
  22. Es elastic.Es
  23. Mgo *mongodb.MongodbSim
  24. MgoLog *mongodb.MongodbSim
  25. MgoQyxy *mongodb.MongodbSim
  26. mode = flag.Int("m", 1, "")
  27. )
  28. func main() {
  29. flag.Parse()
  30. common.ReadConfig(&cfg)
  31. log.Println("cfg ", cfg)
  32. TiDb = &mysql.Mysql{
  33. Address: cfg.TiDb.Host + ":" + fmt.Sprint(cfg.TiDb.Port),
  34. UserName: cfg.TiDb.User,
  35. PassWord: cfg.TiDb.Password,
  36. DBName: cfg.TiDb.Database,
  37. MaxOpenConns: cfg.TiDb.PollSize,
  38. MaxIdleConns: cfg.TiDb.MaxIdle,
  39. }
  40. TiDb.Init()
  41. TiDbData = &mysql.Mysql{
  42. Address: cfg.TiDbData.Host + ":" + fmt.Sprint(cfg.TiDbData.Port),
  43. UserName: cfg.TiDbData.User,
  44. PassWord: cfg.TiDbData.Password,
  45. DBName: cfg.TiDbData.Database,
  46. MaxOpenConns: cfg.TiDbData.PollSize,
  47. MaxIdleConns: cfg.TiDbData.MaxIdle,
  48. }
  49. TiDbData.Init()
  50. TiDbPower = &mysql.Mysql{
  51. Address: cfg.TiDbPower.Host + ":" + fmt.Sprint(cfg.TiDbPower.Port),
  52. UserName: cfg.TiDbPower.User,
  53. PassWord: cfg.TiDbPower.Password,
  54. DBName: cfg.TiDbPower.Database,
  55. MaxOpenConns: cfg.TiDbPower.PollSize,
  56. MaxIdleConns: cfg.TiDbPower.MaxIdle,
  57. }
  58. TiDbPower.Init()
  59. ThirdParty = &mysql.Mysql{
  60. Address: cfg.ThirdParty.Host + ":" + fmt.Sprint(cfg.ThirdParty.Port),
  61. UserName: cfg.ThirdParty.User,
  62. PassWord: cfg.ThirdParty.Password,
  63. DBName: cfg.ThirdParty.Database,
  64. MaxOpenConns: cfg.ThirdParty.PollSize,
  65. MaxIdleConns: cfg.ThirdParty.MaxIdle,
  66. }
  67. ThirdParty.Init()
  68. Jyactivities = &mysql.Mysql{
  69. Address: cfg.Jyactivities.Host + ":" + fmt.Sprint(cfg.Jyactivities.Port),
  70. UserName: cfg.Jyactivities.User,
  71. PassWord: cfg.Jyactivities.Password,
  72. DBName: cfg.Jyactivities.Database,
  73. MaxOpenConns: cfg.Jyactivities.PollSize,
  74. MaxIdleConns: cfg.Jyactivities.MaxIdle,
  75. }
  76. Jyactivities.Init()
  77. Mysql = &mysql.Mysql{
  78. Address: cfg.Mysql.Host + ":" + fmt.Sprint(cfg.Mysql.Port),
  79. UserName: cfg.Mysql.User,
  80. PassWord: cfg.Mysql.Password,
  81. DBName: cfg.Mysql.Database,
  82. MaxOpenConns: cfg.Mysql.PollSize,
  83. MaxIdleConns: cfg.Mysql.MaxIdle,
  84. }
  85. Mysql.Init()
  86. Base = &mysql.Mysql{
  87. Address: cfg.BaseService.Host + ":" + fmt.Sprint(cfg.BaseService.Port),
  88. UserName: cfg.BaseService.User,
  89. PassWord: cfg.BaseService.Password,
  90. DBName: cfg.BaseService.Database,
  91. MaxOpenConns: cfg.BaseService.PollSize,
  92. MaxIdleConns: cfg.BaseService.MaxIdle,
  93. }
  94. Base.Init()
  95. Es = elastic.NewEs(cfg.Es.Version, cfg.Es.Address, cfg.Es.DbSize, cfg.Es.UserName, cfg.Es.Password)
  96. redis.InitRedis(cfg.RedisServer)
  97. Mgo = mongodb.NewMgo(cfg.Mgo.Address, cfg.Mgo.DbName, cfg.Mgo.DbSize)
  98. MgoLog = mongodb.NewMgoWithUser(cfg.MgoLog.Address, cfg.MgoLog.DbName, cfg.MgoLog.User, cfg.MgoLog.Password, cfg.MgoLog.DbSize)
  99. MgoQyxy = mongodb.NewMgoWithUser(cfg.MgoQyxy.Address, cfg.MgoQyxy.DbName, cfg.MgoQyxy.User, cfg.MgoQyxy.Password, cfg.MgoQyxy.DbSize)
  100. InitArea()
  101. if *mode == 1 {
  102. //30分钟一次
  103. a := cron.New()
  104. a.AddFunc(cfg.CornExp1, func() {
  105. orders() //未支付订单
  106. messageSync() //聊天记录进线索
  107. userbase() //新绑定手机号进线索
  108. })
  109. a.Start()
  110. //5分钟一次
  111. b := cron.New()
  112. b.AddFunc(cfg.CornExp2, func() {
  113. users() //新注册用户进线索
  114. saleLeads() //留资进线索
  115. eventReg() //渠道
  116. })
  117. b.Start()
  118. //每天8点30
  119. c := cron.New()
  120. c.AddFunc(cfg.CornExp3, func() {
  121. bigCustomer() //大客户线索
  122. users() //新注册用户进线索
  123. saleLeads() //留资进线索
  124. })
  125. c.Start()
  126. // 一天一次
  127. // tagAllSync()
  128. d := cron.New()
  129. d.AddFunc(cfg.CornExp4, func() {
  130. tagAllSync() //用户标签
  131. })
  132. d.Start()
  133. // 5分钟一次
  134. go ordersClue() //后台订单进线索
  135. e := cron.New()
  136. e.AddFunc(cfg.CornExp5, func() {
  137. go everythingSync() //渠道
  138. go ordersClue() //后台订单进线索
  139. go kcSync() //移交客成
  140. go kcAuto() //客成自动加入任务车
  141. go tagAddSync() //用户标签增量
  142. go autoExitSea() //自动退海
  143. })
  144. e.Start()
  145. //5分钟一次
  146. f := cron.New()
  147. f.AddFunc(cfg.CornExp6, func() {
  148. subscribeAddSync() //订阅增量
  149. })
  150. f.Start()
  151. //自动进入任务车 1天一次
  152. g := cron.New()
  153. g.AddFunc(cfg.CornExp7, func() {
  154. readClue() //读取中间表进线索
  155. refundAuto() //客成移交销售
  156. autoTask() //超时未跟进加入任务车
  157. autoTasks() //按照下次跟进时间提前一天加入任务车
  158. upperLimitAutoExitSea()
  159. })
  160. g.Start()
  161. h := cron.New()
  162. h.AddFunc(cfg.CornMail, func() {
  163. WarningPerl() // 个人
  164. WarningDm() // 部门
  165. })
  166. h.Start()
  167. select {}
  168. } else {
  169. refundAutoHistory()
  170. }
  171. }