main.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "github.com/robfig/cron"
  6. "log"
  7. "app.yhyue.com/moapp/jybase/common"
  8. elastic "app.yhyue.com/moapp/jybase/es"
  9. "app.yhyue.com/moapp/jybase/mongodb"
  10. "app.yhyue.com/moapp/jybase/mysql"
  11. "app.yhyue.com/moapp/jybase/redis"
  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. /*//自动释放处理1
  102. //UpperLimitAutoExitSea(cfg.AllocationCap)
  103. //订单成线索处理
  104. //ordersClue() //后台订单进线索
  105. //客成移交失败
  106. //refundAuto()
  107. //自动分配1
  108. //saleLeads()
  109. //解冻处理
  110. Thaw()
  111. //userbase()*/
  112. if *mode == 1 {
  113. //30分钟一次
  114. a := cron.New()
  115. a.AddFunc(cfg.CornExp1, func() {
  116. orders() //未支付订单
  117. messageSync() //聊天记录进线索
  118. userbase() //新绑定手机号进线索
  119. })
  120. a.Start()
  121. //5分钟一次
  122. b := cron.New()
  123. b.AddFunc(cfg.CornExp2, func() {
  124. users() //新注册用户进线索
  125. saleLeads() //留资进线索
  126. eventReg() //渠道
  127. })
  128. b.Start()
  129. //每天8点30
  130. c := cron.New()
  131. c.AddFunc(cfg.CornExp3, func() {
  132. bigCustomer() //大客户线索
  133. users() //新注册用户进线索
  134. saleLeads() //留资进线索
  135. })
  136. c.Start()
  137. // 一天一次
  138. // tagAllSync()
  139. d := cron.New()
  140. d.AddFunc(cfg.CornExp4, func() {
  141. tagAllSync() //用户标签
  142. })
  143. d.Start()
  144. // 5分钟一次
  145. go ordersClue() //后台订单进线索
  146. e := cron.New()
  147. e.AddFunc(cfg.CornExp5, func() {
  148. go everythingSync() //渠道
  149. go ordersClue() //后台订单进线索
  150. go kcSync() //移交客成
  151. go kcAuto() //客成自动加入任务车
  152. go tagAddSync() //用户标签增量
  153. go autoExitSea() //自动退海
  154. go Thaw() //自动解冻处理
  155. })
  156. e.Start()
  157. //5分钟一次
  158. f := cron.New()
  159. f.AddFunc(cfg.CornExp6, func() {
  160. subscribeAddSync() //订阅增量
  161. })
  162. f.Start()
  163. //自动进入任务车 1天一次
  164. g := cron.New()
  165. g.AddFunc(cfg.CornExp7, func() {
  166. readClue() //读取中间表进线索
  167. refundAuto() //客成移交销售
  168. autoTask() //超时未跟进加入任务车
  169. autoTasks() //按照下次跟进时间提前一天加入任务车
  170. UpperLimitAutoExitSea(cfg.AllocationCap)
  171. })
  172. g.Start()
  173. h := cron.New()
  174. h.AddFunc(cfg.CornMail, func() {
  175. WarningPerl() // 个人
  176. WarningDm() // 部门
  177. })
  178. h.Start()
  179. select {}
  180. } else {
  181. refundAutoHistory()
  182. }
  183. }