config.py 8.5 KB

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