main.go 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. package main
  2. import (
  3. "app.yhyue.com/moapp/jybase/common"
  4. elastic "app.yhyue.com/moapp/jybase/es"
  5. "app.yhyue.com/moapp/jybase/mail"
  6. "app.yhyue.com/moapp/jybase/mongodb"
  7. "app.yhyue.com/moapp/jybase/mysql"
  8. "app.yhyue.com/moapp/jybase/redis"
  9. "bp.jydev.jianyu360.cn/BaseService/pushpkg/p"
  10. "flag"
  11. "fmt"
  12. "github.com/robfig/cron"
  13. "log"
  14. )
  15. var (
  16. cfg = new(Config)
  17. db = new(DB)
  18. Mysql *mysql.Mysql
  19. TiDb *mysql.Mysql
  20. TiDbData *mysql.Mysql
  21. TiDbPower *mysql.Mysql
  22. WorkOrder *mysql.Mysql
  23. ThirdParty *mysql.Mysql
  24. Jyactivities *mysql.Mysql
  25. debrisProductMysql *mysql.Mysql
  26. Base *mysql.Mysql
  27. BiService *mysql.Mysql
  28. DataAnalysisService *mysql.Mysql
  29. Es elastic.Es
  30. Mgo *mongodb.MongodbSim
  31. MgoLog *mongodb.MongodbSim
  32. MgoQyxy *mongodb.MongodbSim
  33. mode = flag.Int("m", 1, "")
  34. startTime, endTime = "00:00", "23:59"
  35. Gmail mail.GmailAuth
  36. )
  37. func main() {
  38. flag.Parse()
  39. common.ReadConfig(&cfg)
  40. log.Println("cfg ", cfg)
  41. common.ReadConfig("./db.json", &db)
  42. log.Println("db ", db)
  43. Gmail = mail.GmailAuth{
  44. SmtpHost: db.Mail.SmtpHost,
  45. SmtpPort: db.Mail.SmtpPort,
  46. User: db.Mail.User,
  47. Pwd: db.Mail.Pwd,
  48. }
  49. TiDb = &mysql.Mysql{
  50. Address: db.TiDb.Host + ":" + fmt.Sprint(db.TiDb.Port),
  51. UserName: db.TiDb.User,
  52. PassWord: db.TiDb.Password,
  53. DBName: db.TiDb.Database,
  54. MaxOpenConns: db.TiDb.PollSize,
  55. MaxIdleConns: db.TiDb.MaxIdle,
  56. }
  57. TiDb.Init()
  58. TiDbData = &mysql.Mysql{
  59. Address: db.TiDbData.Host + ":" + fmt.Sprint(db.TiDbData.Port),
  60. UserName: db.TiDbData.User,
  61. PassWord: db.TiDbData.Password,
  62. DBName: db.TiDbData.Database,
  63. MaxOpenConns: db.TiDbData.PollSize,
  64. MaxIdleConns: db.TiDbData.MaxIdle,
  65. }
  66. TiDbData.Init()
  67. TiDbPower = &mysql.Mysql{
  68. Address: db.TiDbPower.Host + ":" + fmt.Sprint(db.TiDbPower.Port),
  69. UserName: db.TiDbPower.User,
  70. PassWord: db.TiDbPower.Password,
  71. DBName: db.TiDbPower.Database,
  72. MaxOpenConns: db.TiDbPower.PollSize,
  73. MaxIdleConns: db.TiDbPower.MaxIdle,
  74. }
  75. TiDbPower.Init()
  76. ThirdParty = &mysql.Mysql{
  77. Address: db.ThirdParty.Host + ":" + fmt.Sprint(db.ThirdParty.Port),
  78. UserName: db.ThirdParty.User,
  79. PassWord: db.ThirdParty.Password,
  80. DBName: db.ThirdParty.Database,
  81. MaxOpenConns: db.ThirdParty.PollSize,
  82. MaxIdleConns: db.ThirdParty.MaxIdle,
  83. }
  84. ThirdParty.Init()
  85. Jyactivities = &mysql.Mysql{
  86. Address: db.Jyactivities.Host + ":" + fmt.Sprint(db.Jyactivities.Port),
  87. UserName: db.Jyactivities.User,
  88. PassWord: db.Jyactivities.Password,
  89. DBName: db.Jyactivities.Database,
  90. MaxOpenConns: db.Jyactivities.PollSize,
  91. MaxIdleConns: db.Jyactivities.MaxIdle,
  92. }
  93. Jyactivities.Init()
  94. debrisProductMysql = &mysql.Mysql{
  95. Address: db.DebrisProduct.Host + ":" + fmt.Sprint(db.DebrisProduct.Port),
  96. UserName: db.DebrisProduct.User,
  97. PassWord: db.DebrisProduct.Password,
  98. DBName: db.DebrisProduct.Database,
  99. }
  100. debrisProductMysql.Init()
  101. WorkOrder = &mysql.Mysql{
  102. Address: db.WorderOrder.Host + ":" + fmt.Sprint(db.WorderOrder.Port),
  103. UserName: db.WorderOrder.User,
  104. PassWord: db.WorderOrder.Password,
  105. DBName: db.WorderOrder.Database,
  106. MaxOpenConns: db.WorderOrder.PollSize,
  107. MaxIdleConns: db.WorderOrder.MaxIdle,
  108. }
  109. WorkOrder.Init()
  110. Mysql = &mysql.Mysql{
  111. Address: db.Mysql.Host + ":" + fmt.Sprint(db.Mysql.Port),
  112. UserName: db.Mysql.User,
  113. PassWord: db.Mysql.Password,
  114. DBName: db.Mysql.Database,
  115. MaxOpenConns: db.Mysql.PollSize,
  116. MaxIdleConns: db.Mysql.MaxIdle,
  117. }
  118. Mysql.Init()
  119. Base = &mysql.Mysql{
  120. Address: db.BaseService.Host + ":" + fmt.Sprint(db.BaseService.Port),
  121. UserName: db.BaseService.User,
  122. PassWord: db.BaseService.Password,
  123. DBName: db.BaseService.Database,
  124. MaxOpenConns: db.BaseService.PollSize,
  125. MaxIdleConns: db.BaseService.MaxIdle,
  126. }
  127. Base.Init()
  128. BiService = &mysql.Mysql{
  129. Address: db.BiService.Host + ":" + fmt.Sprint(db.BiService.Port),
  130. UserName: db.BiService.User,
  131. PassWord: db.BiService.Password,
  132. DBName: db.BiService.Database,
  133. MaxOpenConns: db.BiService.PollSize,
  134. MaxIdleConns: db.BiService.MaxIdle,
  135. }
  136. BiService.Init()
  137. DataAnalysisService = &mysql.Mysql{
  138. Address: db.DataAnalysis.Host + ":" + fmt.Sprint(db.DataAnalysis.Port),
  139. UserName: db.DataAnalysis.User,
  140. PassWord: db.DataAnalysis.Password,
  141. DBName: db.DataAnalysis.Database,
  142. MaxOpenConns: db.DataAnalysis.PollSize,
  143. MaxIdleConns: db.DataAnalysis.MaxIdle,
  144. }
  145. DataAnalysisService.Init()
  146. Es = elastic.NewEs(db.Es.Version, db.Es.Address, db.Es.DbSize, db.Es.UserName, db.Es.Password)
  147. redis.InitRedis(db.RedisServer)
  148. Mgo = mongodb.NewMgo(db.Mgo.Address, db.Mgo.DbName, db.Mgo.DbSize)
  149. MgoLog = mongodb.NewMgoWithUser(db.MgoLog.Address, db.MgoLog.DbName, db.MgoLog.User, db.MgoLog.Password, db.MgoLog.DbSize)
  150. MgoQyxy = mongodb.NewMgoWithUser(db.MgoQyxy.Address, db.MgoQyxy.DbName, db.MgoQyxy.User, db.MgoQyxy.Password, db.MgoQyxy.DbSize)
  151. InitArea()
  152. InitProduct(db.ProductArr)
  153. if *mode == 1 {
  154. go ordersClue() //后台订单进线索
  155. //一秒钟一次
  156. go p.VarTimeTask.RunInSecondTimeLoop("1秒钟定时任务", "", "", db.CornExp8, true, true, nil, func() {
  157. LockHandle() //绑定状态处理
  158. })
  159. //30分钟一次
  160. go p.VarTimeTask.RunInTimeLoop("30分钟定时任务", "", "", db.CornExp1, true, true, nil, func() {
  161. orders() //未支付订单
  162. messageSync() //聊天记录进线索
  163. userbase() //新绑定手机号进线索
  164. })
  165. //5分钟一次
  166. go p.VarTimeTask.RunInTimeSection("5分钟定时任务1", db.CornExp2Start, db.CornExp2End, db.CornExp2, func(dayFirst bool) {
  167. users() //新注册用户进线索
  168. saleLeads() //留资进线索
  169. eventReg() //渠道
  170. bigCustomer() //大客户线索
  171. MarketCustomer() //市场部线索
  172. AdvisoryCommittee() //咨询组线索
  173. SelectionDepartment() //运营部线索
  174. rebind() //取关重新关注处理
  175. activeUsers() //活跃用户处理
  176. inviteUser() //邀请用户
  177. nextYearActivity() //开年活动
  178. })
  179. //每天8点30
  180. c := cron.New()
  181. c.AddFunc(db.CornExp3, func() {
  182. users() //新注册用户进线索
  183. saleLeads() //留资进线索
  184. activeUsers() //活跃用户处理
  185. })
  186. c.Start()
  187. // 一天一次
  188. // tagAllSync()
  189. d := cron.New()
  190. d.AddFunc(db.CornExp4, func() {
  191. tagAllSync() //用户标签
  192. })
  193. d.Start()
  194. // 5分钟一次
  195. go p.VarTimeTask.RunInTimeLoop("5分钟定时任务2", "", "", db.CornExp5, true, true, nil, func() {
  196. //go p.VarTimeTask.RunInTimeSection("5分钟定时任务2", startTime, endTime, db.CornExp5, func(dayFirst bool) {
  197. everythingSync() //渠道
  198. ordersClue() //后台订单进线索
  199. kcSync() //移交客成
  200. kcAuto() //客成自动加入任务车
  201. tagAddSync() //用户标签增量
  202. autoExitSea() //自动退海
  203. Thaw() //自动解冻处理
  204. subscribeAddSync() //订阅增量
  205. CustomerChange()
  206. })
  207. //5分钟一次
  208. go p.VarTimeTask.RunInTimeLoop("5分钟定时任务3", "", "", db.CornExp6, true, true, nil, func() {
  209. //go p.VarTimeTask.RunInTimeSection("5分钟定时任务3", startTime, endTime, db.CornExp6, func(dayFirst bool) {
  210. subscribeAddSync() //订阅增量
  211. rderAcceptance() //工单生成
  212. })
  213. //自动进入任务车 1天一次
  214. g := cron.New()
  215. g.AddFunc(db.CornExp7, func() {
  216. readClue() //读取中间表进线索
  217. refundAuto() //客成移交销售
  218. autoTask() //超时未跟进加入任务车
  219. autoTasks() //按照下次跟进时间提前一天加入任务车
  220. ClueToDxTask()
  221. })
  222. g.Start()
  223. log.Println("个人邮件告警查询开始")
  224. WarningPerl() // 个人
  225. log.Println("部门邮件告警查询开始")
  226. WarningDm() // 部门
  227. log.Println("个人/部门邮件告警查询结束")
  228. h := cron.New()
  229. h.AddFunc(db.CornMail, func() {
  230. log.Println("个人邮件告警查询开始")
  231. WarningPerl() // 个人
  232. log.Println("部门邮件告警查询开始")
  233. WarningDm() // 部门
  234. log.Println("个人/部门邮件告警查询结束")
  235. UpperLimitAutoExitSea(db.AllocationCap)
  236. })
  237. h.Start()
  238. select {}
  239. } else {
  240. users()
  241. saleLeads()
  242. }
  243. }