init.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. package main
  2. import (
  3. "app.yhyue.com/data_processing/common_utils/elastic"
  4. "app.yhyue.com/data_processing/common_utils/log"
  5. "app.yhyue.com/data_processing/common_utils/mongodb"
  6. "app.yhyue.com/data_processing/common_utils/mysqldb"
  7. "fmt"
  8. "os"
  9. "proposed_project/config"
  10. "sync"
  11. )
  12. var (
  13. MgoBid, MgoPro *mongodb.MongodbSim //mongodb连接
  14. MysqlTool, MysqlTool1 *mysqldb.Mysql
  15. saveSize int
  16. LastId string //增量拟建数据最后id
  17. TaskSingle bool
  18. pici int64 // 拟建增量数据pici时间
  19. updatePool chan []map[string]interface{}
  20. updateSp chan bool
  21. savePool chan map[string]interface{}
  22. saveSp chan bool
  23. AllPidMap map[string]*ID
  24. AllPidMapLock sync.Mutex
  25. AllPnMap map[string]*Pname
  26. AllPnMapLock sync.Mutex
  27. AllCodeMap map[string]string
  28. AllCodeMapLock sync.Mutex
  29. )
  30. func init() {
  31. config.Init("./common.toml")
  32. InitLog()
  33. InitMgo()
  34. TaskSingle = true
  35. saveSize = 200
  36. AllPidMap = make(map[string]*ID, 20000)
  37. AllPnMap = make(map[string]*Pname, 20000)
  38. AllCodeMap = make(map[string]string, 50000)
  39. updatePool = make(chan []map[string]interface{}, 5000)
  40. updateSp = make(chan bool, 1)
  41. savePool = make(chan map[string]interface{}, 5000)
  42. saveSp = make(chan bool, 2)
  43. }
  44. func InitLog() {
  45. logcfg := config.Conf.Log
  46. err := log.InitLog(
  47. log.Path(logcfg.LogPath),
  48. log.Level(logcfg.LogLevel),
  49. log.Compress(logcfg.Compress),
  50. log.MaxSize(logcfg.MaxSize),
  51. log.MaxBackups(logcfg.MaxBackups),
  52. log.MaxAge(logcfg.MaxAge),
  53. log.Format(logcfg.Format),
  54. )
  55. if err != nil {
  56. fmt.Printf("InitLog failed: %v\n", err)
  57. os.Exit(1)
  58. }
  59. }
  60. func InitMgo() {
  61. MgoBid = &mongodb.MongodbSim{
  62. MongodbAddr: config.Conf.DB.MongoB.Addr,
  63. DbName: config.Conf.DB.MongoB.Dbname,
  64. Size: config.Conf.DB.MongoB.Size,
  65. UserName: config.Conf.DB.MongoB.User,
  66. Password: config.Conf.DB.MongoB.Password,
  67. }
  68. MgoBid.InitPool()
  69. MgoPro = &mongodb.MongodbSim{
  70. MongodbAddr: config.Conf.DB.MongoP.Addr,
  71. DbName: config.Conf.DB.MongoP.Dbname,
  72. Size: config.Conf.DB.MongoP.Size,
  73. UserName: config.Conf.DB.MongoP.User,
  74. Password: config.Conf.DB.MongoP.Password,
  75. }
  76. MgoPro.InitPool()
  77. }
  78. func InitMysql() {
  79. dbcfg := config.Conf.DB.Mysql
  80. MysqlTool = &mysqldb.Mysql{
  81. Address: dbcfg.Addr,
  82. DBName: dbcfg.DbnameMedical,
  83. UserName: dbcfg.User,
  84. PassWord: dbcfg.Password,
  85. }
  86. MysqlTool.Init()
  87. MysqlTool1 = &mysqldb.Mysql{
  88. Address: dbcfg.Addr,
  89. DBName: dbcfg.DbnameBasic,
  90. UserName: dbcfg.User,
  91. PassWord: dbcfg.Password,
  92. }
  93. MysqlTool1.Init()
  94. }
  95. func InitEs() {
  96. Es = &elastic.Elastic{
  97. S_esurl: config.Conf.DB.Es.Addr,
  98. I_size: config.Conf.DB.Es.Size,
  99. }
  100. Es.InitElasticSize()
  101. }
  102. type Pname struct {
  103. Id map[string]string
  104. Lock sync.Mutex
  105. }
  106. type Key struct {
  107. Id string
  108. Lock sync.Mutex
  109. }
  110. type ID struct {
  111. Lock sync.Mutex
  112. P *Project
  113. }
  114. // Project 内存 项目信息
  115. type Project struct {
  116. Id string `json:"_id"`
  117. Ids []string `json:"ids,omitempty"`
  118. FirstTime int64 `json:"firsttime,omitempty"` //项目的最早时间
  119. LastTime int64 `json:"lasttime,omitempty"` //项目的最后时间
  120. ProjectName string `json:"projectname,omitempty"` //项目名称
  121. Owner string `json:"owner"`
  122. ApproveCode string `json:"approvecode"` // 审批代码
  123. ApproveNumber string `json:"approvenumber"`
  124. ApproveDept string `json:"approvedept"`
  125. TotalInvestment string `json:"total_investment"`
  126. ProjectAddr string `json:"projectaddr"`
  127. Funds string `json:"funds"`
  128. ProjectPeriod string `json:"projectperiod"`
  129. ProjectScale string `json:"project_scale"`
  130. ProjectStartDate int64 `json:"project_startdate"`
  131. ProjectCompleteDate int64 `json:"project_completedate"`
  132. ConstructionArea string `json:"construction_area"`
  133. FollowNum int `json:"follow_num"`
  134. FloorArea string `json:"floor_area"`
  135. ProjectPhone string `json:"project_phone"`
  136. ProjectPerson string `json:"project_person"`
  137. Area string `json:"area"` //地区
  138. City string `json:"city"` //地市
  139. District string `json:"district"` //区县
  140. Site string `json:"site"`
  141. }
  142. // Info 拟在建数据信息
  143. type Info struct {
  144. Id string `json:"_id"`
  145. Href string `json:"href"`
  146. Publishtime int64 `json:"publishtime"`
  147. Title string `json:"title"`
  148. ProjectName string `json:"projectname"`
  149. Area string `json:"area"`
  150. City string `json:"city"`
  151. District string `json:"district"`
  152. Infoformat int `json:"infoformat"`
  153. Site string `json:"site"`
  154. Topscopeclass []string `json:"topscopeclass"`
  155. Subscopeclass []string `json:"subscopeclass"`
  156. Buyerclass string `json:"buyerclass"`
  157. Owner string `json:"owner"`
  158. ApproveCode string `json:"approvecode"`
  159. ApproveDept string `json:"approvedept"`
  160. ApproveStatus string `json:"approvestatus"`
  161. ApproveTime string `json:"approvetime"`
  162. ApproveNumber string `json:"approvenumber"`
  163. ApproveContent string `json:"approvecontent"`
  164. ProjectType string `json:"projecttype"`
  165. ApproveCity string `json:"approvecity"`
  166. ProjectScale string `json:"project_scale"`
  167. TotalInvestment string `json:"total_investment"`
  168. ProjectAddr string `json:"projectaddr"`
  169. ProjectPeriod string `json:"projectperiod"`
  170. Funds string `json:"funds"`
  171. ProjectStartDate int64 `json:"project_startdate"`
  172. ProjectCompleteDate int64 `json:"project_completedate"`
  173. ConstructionArea string `json:"construction_area"`
  174. FloorArea string `json:"floor_area"`
  175. ProjectPhone string `json:"project_phone"`
  176. ProjectPerson string `json:"project_person"`
  177. }