main.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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. // configFile = flag.String("c", "./config.yaml", "配置文件")
  26. mode = flag.Int("m", 1, "")
  27. )
  28. func main() {
  29. flag.Parse()
  30. common.ReadConfig(&cfg)
  31. // _ = config.LoadConfigWithYaml(*configFile, cfg)
  32. log.Println("cfg ", cfg)
  33. TiDb = &mysql.Mysql{
  34. Address: cfg.TiDb.Host + ":" + fmt.Sprint(cfg.TiDb.Port),
  35. UserName: cfg.TiDb.User,
  36. PassWord: cfg.TiDb.Password,
  37. DBName: cfg.TiDb.Database,
  38. MaxOpenConns: cfg.TiDb.PollSize,
  39. MaxIdleConns: cfg.TiDb.MaxIdle,
  40. }
  41. TiDb.Init()
  42. TiDbData = &mysql.Mysql{
  43. Address: cfg.TiDbData.Host + ":" + fmt.Sprint(cfg.TiDbData.Port),
  44. UserName: cfg.TiDbData.User,
  45. PassWord: cfg.TiDbData.Password,
  46. DBName: cfg.TiDbData.Database,
  47. MaxOpenConns: cfg.TiDbData.PollSize,
  48. MaxIdleConns: cfg.TiDbData.MaxIdle,
  49. }
  50. TiDbData.Init()
  51. TiDbPower = &mysql.Mysql{
  52. Address: cfg.TiDbPower.Host + ":" + fmt.Sprint(cfg.TiDbPower.Port),
  53. UserName: cfg.TiDbPower.User,
  54. PassWord: cfg.TiDbPower.Password,
  55. DBName: cfg.TiDbPower.Database,
  56. MaxOpenConns: cfg.TiDbPower.PollSize,
  57. MaxIdleConns: cfg.TiDbPower.MaxIdle,
  58. }
  59. TiDbPower.Init()
  60. ThirdParty = &mysql.Mysql{
  61. Address: cfg.ThirdParty.Host + ":" + fmt.Sprint(cfg.ThirdParty.Port),
  62. UserName: cfg.ThirdParty.User,
  63. PassWord: cfg.ThirdParty.Password,
  64. DBName: cfg.ThirdParty.Database,
  65. MaxOpenConns: cfg.ThirdParty.PollSize,
  66. MaxIdleConns: cfg.ThirdParty.MaxIdle,
  67. }
  68. ThirdParty.Init()
  69. Jyactivities = &mysql.Mysql{
  70. Address: cfg.Jyactivities.Host + ":" + fmt.Sprint(cfg.Jyactivities.Port),
  71. UserName: cfg.Jyactivities.User,
  72. PassWord: cfg.Jyactivities.Password,
  73. DBName: cfg.Jyactivities.Database,
  74. MaxOpenConns: cfg.Jyactivities.PollSize,
  75. MaxIdleConns: cfg.Jyactivities.MaxIdle,
  76. }
  77. Jyactivities.Init()
  78. Mysql = &mysql.Mysql{
  79. Address: cfg.Mysql.Host + ":" + fmt.Sprint(cfg.Mysql.Port),
  80. UserName: cfg.Mysql.User,
  81. PassWord: cfg.Mysql.Password,
  82. DBName: cfg.Mysql.Database,
  83. MaxOpenConns: cfg.Mysql.PollSize,
  84. MaxIdleConns: cfg.Mysql.MaxIdle,
  85. }
  86. Mysql.Init()
  87. Base = &mysql.Mysql{
  88. Address: cfg.BaseService.Host + ":" + fmt.Sprint(cfg.BaseService.Port),
  89. UserName: cfg.BaseService.User,
  90. PassWord: cfg.BaseService.Password,
  91. DBName: cfg.BaseService.Database,
  92. MaxOpenConns: cfg.BaseService.PollSize,
  93. MaxIdleConns: cfg.BaseService.MaxIdle,
  94. }
  95. Base.Init()
  96. Es = elastic.NewEs(cfg.Es.Version, cfg.Es.Address, cfg.Es.DbSize, cfg.Es.UserName, cfg.Es.Password)
  97. redis.InitRedis(cfg.RedisServer)
  98. Mgo = mongodb.NewMgo(cfg.Mgo.Address, cfg.Mgo.DbName, cfg.Mgo.DbSize)
  99. MgoLog = mongodb.NewMgoWithUser(cfg.MgoLog.Address, cfg.MgoLog.DbName, cfg.MgoLog.User, cfg.MgoLog.Password, cfg.MgoLog.DbSize)
  100. InitArea()
  101. if *mode == 1 {
  102. // 未支付订单 30分钟一次
  103. orders()
  104. a := cron.New()
  105. a.AddFunc(cfg.CornExp1, func() {
  106. orders()
  107. messageSync()
  108. })
  109. a.Start()
  110. // 新注册用户 5分钟一次
  111. // users()
  112. // saleLeads()
  113. b := cron.New()
  114. b.AddFunc(cfg.CornExp2, func() {
  115. users()
  116. saleLeads()
  117. eventReg()
  118. })
  119. b.Start()
  120. // 每天8点30
  121. c := cron.New()
  122. c.AddFunc(cfg.CornExp3, func() {
  123. bigCustomer()
  124. users()
  125. saleLeads()
  126. })
  127. c.Start()
  128. // userbase()
  129. cc := cron.New()
  130. cc.AddFunc(cfg.CornExp1, func() {
  131. userbase()
  132. })
  133. cc.Start()
  134. // 用户标签一天一次
  135. // tagAllSync()
  136. d := cron.New()
  137. d.AddFunc(cfg.CornExp4, func() {
  138. tagAllSync()
  139. })
  140. d.Start()
  141. // 用户标签增量 5分钟一次
  142. everythingSync()
  143. ordersClue()
  144. kcSync()
  145. tagAddSync()
  146. e := cron.New()
  147. e.AddFunc(cfg.CornExp5, func() {
  148. everythingSync()
  149. ordersClue()
  150. kcSync()
  151. kcAuto()
  152. tagAddSync()
  153. })
  154. e.Start()
  155. //订阅增量 5分钟一次
  156. subscribeAddSync()
  157. f := cron.New()
  158. f.AddFunc(cfg.CornExp6, func() {
  159. subscribeAddSync()
  160. })
  161. f.Start()
  162. //自动进入任务车 1天一次
  163. // autoTask()
  164. // autoTasks()
  165. g := cron.New()
  166. g.AddFunc(cfg.CornExp7, func() {
  167. autoTask()
  168. autoTasks()
  169. })
  170. g.Start()
  171. h := cron.New()
  172. h.AddFunc(cfg.CornExp5, func() {
  173. autoExitSea()
  174. })
  175. h.Start()
  176. select {}
  177. } else if *mode == 23 {
  178. hlyjSync()
  179. } else if *mode == 24 {
  180. hlyjSync2()
  181. } else if *mode == 25 {
  182. hlyjSync3()
  183. } else if *mode == 26 {
  184. everythingSync()
  185. } else if *mode == 27 {
  186. bigCustomer()
  187. } else if *mode == 28 {
  188. clueSync1()
  189. } else if *mode == 29 {
  190. hlyjSync4()
  191. }
  192. }