config.py 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. # coding:utf-8
  2. class BaseConfig(object):
  3. # 产品标识
  4. APP_TYPE = {
  5. 'VLOG': 0, # vlog
  6. 'LOVE_LIVE': 4, # 票圈视频
  7. 'LONG_VIDEO': 5, # 内容精选
  8. 'SHORT_VIDEO': 6, # 票圈短视频
  9. 'WAN_NENG_VIDEO': 17, # 万能影视屋
  10. 'LAO_HAO_KAN_VIDEO': 18, # 老好看视频
  11. 'ZUI_JING_QI': 19, # 票圈最惊奇
  12. }
  13. # 数据存放路径
  14. DATA_DIR_PATH = './data'
  15. # oss 目标Bucket
  16. BUCKET_NAME = 'ali-recommend'
  17. # 训练数据截止时间距当前日期间隔天数
  18. TRAIN_DIFF = 7
  19. # 训练数据所需数据范围天数
  20. TRAIN_DELTA_DAYS = 30
  21. # 训练数据表名
  22. TRAIN_PROJECT = 'usercdm'
  23. TRAIN_TABLE = 'rov_feature_add_v1'
  24. # 训练数据文件存放路径
  25. TRAIN_DATA_FILENAME = 'train_data.pickle'
  26. # 预测数据截止时间距当前日期间隔天数
  27. PREDICT_DIFF = 1
  28. # 预测数据所需数据范围天数
  29. PREDICT_DELTA_DAYS = 1
  30. # 预测数据表名
  31. PREDICT_PROJECT = 'usercdm'
  32. PREDICT_TABLE = 'rov_predict_table_add_v1'
  33. # 预测数据文件存放路径
  34. PREDICT_DATA_FILENAME = 'predict_data.pickle'
  35. # 模型存放文件
  36. MODEL_FILENAME = 'model.pickle'
  37. # 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  38. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  39. # 流量池离线模型结果存放 redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  40. FLOWPOOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  41. # 兜底视频redis存储key
  42. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  43. # 兜底视频数量
  44. BOTTOM_NUM = 1000
  45. # 修改ROV的视频 redis key
  46. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  47. # 生效中的置顶视频列表 redis key
  48. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  49. # rovScore公差
  50. ROV_SCORE_D = 0.001
  51. class DevelopmentConfig(BaseConfig):
  52. """开发环境配置"""
  53. # 测试环境redis地址
  54. REDIS_INFO = {
  55. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  56. 'port': 6379,
  57. 'password': 'Wqsd@2019',
  58. }
  59. # Hologres连接参数,本地使用
  60. HOLOGRES_INFO = {
  61. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  62. 'port': 80,
  63. 'dbname': 'dssm',
  64. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  65. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  66. }
  67. # Hologres视频状态存储表名
  68. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  69. # 从流量池获取视频接口地址
  70. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  71. # 获取视频在流量池中的剩余可分发数接口地址
  72. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  73. # 计算完ROV通知后端接口地址
  74. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  75. # 获取置顶视频列表接口地址
  76. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  77. # logs 上传oss 目标Bucket指定目录
  78. OSS_FOLDER_LOGS = 'rov-offline/dev/logs/'
  79. # data 上传oss 目标Bucket指定目录
  80. OSS_FOLDER_DATA = 'rov-offline/dev/data/'
  81. class TestConfig(BaseConfig):
  82. """测试环境配置"""
  83. # 测试环境redis地址
  84. REDIS_INFO = {
  85. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  86. 'port': 6379,
  87. 'password': 'Wqsd@2019',
  88. }
  89. # Hologres连接参数,服务器使用
  90. HOLOGRES_INFO = {
  91. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  92. 'port': 80,
  93. 'dbname': 'dssm',
  94. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  95. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  96. }
  97. # Hologres视频状态存储表名
  98. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  99. # 从流量池获取视频接口地址
  100. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  101. # 获取视频在流量池中的剩余可分发数接口地址
  102. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  103. # 计算完ROV通知后端接口地址
  104. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  105. # 获取置顶视频列表接口地址
  106. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  107. # logs 上传oss 目标Bucket指定目录
  108. OSS_FOLDER_LOGS = 'rov-offline/test/logs/'
  109. # data 上传oss 目标Bucket指定目录
  110. OSS_FOLDER_DATA = 'rov-offline/test/data/'
  111. class PreProductionConfig(BaseConfig):
  112. """预发布环境配置"""
  113. # redis地址
  114. REDIS_INFO = {
  115. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  116. 'port': 6379,
  117. 'password': 'Wqsd@2019',
  118. }
  119. # Hologres连接参数,服务器使用
  120. HOLOGRES_INFO = {
  121. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  122. 'port': 80,
  123. 'dbname': 'dssm',
  124. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  125. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  126. }
  127. # Hologres视频状态存储表名
  128. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  129. # 从流量池获取视频接口地址
  130. GET_VIDEOS_FROM_POOL_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  131. # 获取视频在流量池中的剩余可分发数接口地址
  132. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  133. # 计算完ROV通知后端接口地址
  134. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videopre-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  135. # 获取置顶视频列表接口地址
  136. TOP_VIDEO_LIST_URL = 'http://speedpre.wx.com/longvideoapi/openapi/recommend/topVideoList'
  137. # logs 上传oss 目标Bucket指定目录
  138. OSS_FOLDER_LOGS = 'rov-offline/pre/logs/'
  139. # data 上传oss 目标Bucket指定目录
  140. OSS_FOLDER_DATA = 'rov-offline/pre/data/'
  141. class ProductionConfig(BaseConfig):
  142. """生产环境配置"""
  143. # 线上环境redis地址
  144. REDIS_INFO = {
  145. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  146. 'port': 6379,
  147. 'password': 'Wqsd@2019',
  148. }
  149. # Hologres连接参数,服务器使用
  150. HOLOGRES_INFO = {
  151. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  152. 'port': 80,
  153. 'dbname': 'dssm',
  154. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  155. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  156. }
  157. # Hologres视频状态存储表名
  158. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  159. # 从流量池获取视频接口地址
  160. GET_VIDEOS_FROM_POOL_URL = 'http://api-internal.piaoquantv.com/flowpool/video/getAllVideo'
  161. # 获取视频在流量池中的剩余可分发数接口地址
  162. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  163. # 计算完ROV通知后端接口地址
  164. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://longvideoapi-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  165. # 获取置顶视频列表接口地址
  166. TOP_VIDEO_LIST_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/topVideoList'
  167. # logs 上传oss 目标Bucket指定目录
  168. OSS_FOLDER_LOGS = 'rov-offline/pro/logs/'
  169. # data 上传oss 目标Bucket指定目录
  170. OSS_FOLDER_DATA = 'rov-offline/pro/data/'
  171. def set_config():
  172. # return DevelopmentConfig()
  173. # return TestConfig()
  174. # return PreProductionConfig()
  175. return ProductionConfig()