config.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  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. # abTest
  13. AB_TEST = {
  14. 'w_h_rate': [APP_TYPE['LONG_VIDEO']], # 视频宽高比实验(每组的前两个视频调整为横屏视频)
  15. 'position_insert': [APP_TYPE['SHORT_VIDEO'],APP_TYPE['LOVE_LIVE']]
  16. }
  17. # abCode
  18. AB_CODE = {
  19. 'initial': 10000, # 初始
  20. 'w_h_rate': 10001, # 视频宽高比实验(每组的前两个视频调整为横屏视频)
  21. 'position_insert': 10002, # 按位置插入
  22. 'relevant_video_op': 10003, # 运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部
  23. }
  24. # pushFrom
  25. PUSH_FROM = {
  26. 'rov_recall': 'recall_pool', # rov召回池
  27. 'flow_recall': 'flow_pool', # 流量池
  28. 'top': 'op_manual', # 置顶
  29. 'bottom': 'bottom_strategy', # 一层兜底
  30. 'bottom_last': 'bottom_strategy_last', # 二层兜底
  31. 'position_insert': 'position_insert' # 按位置插入
  32. }
  33. # category id mapping
  34. CATEGORY = {
  35. 'recommend': [55], # 推荐
  36. 'other': [1, 2, 3] # 其他类别
  37. }
  38. # 前k个从ROV召回池中获取视频
  39. K = 3
  40. # 从流量池获取视频的概率设置
  41. P = 0.15
  42. # ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  43. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  44. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.{appType}.{h}
  45. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.'
  46. # 流量池redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  47. FLOW_POOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  48. # 修改ROV的视频 redis key
  49. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  50. # 首页推荐预曝光列表redis key 前缀,完整key格式:com.weiqu.video.hot.recommend.previewed.{appType}.{mid}
  51. PREVIEW_KEY_PREFIX = 'com.weiqu.video.hot.recommend.previewed.'
  52. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.{appType}.{mid}.{date}
  53. LAST_VIDEO_FROM_ROV_POOL_PREFIX = 'com.weiqu.video.rov.pool.last.'
  54. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{h}
  55. # LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  56. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{videoId}.{flowPool}
  57. LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  58. # 从ROV召回池获取视频的最大频次,限制每次请求的获取次数
  59. MAX_FREQ_FROM_ROV_POOL = 3
  60. # 兜底视频redis存储key
  61. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  62. # 生效中的置顶视频列表 redis key
  63. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  64. # 按位置排序redis存储key
  65. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  66. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  67. # rov召回池更新时间
  68. ROV_UPDATE_H = 6
  69. ROV_UPDATE_MINUTE = 30
  70. # 短视频召回池更新时间 每个小时的15分更新成功
  71. ROV_UPDATE_MINUTE_6 = 15
  72. # 置顶视频区域 为 全部 的code
  73. ALL_AREA_CODE = '000000'
  74. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  75. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  76. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  77. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  78. }
  79. class DevelopmentConfig(BaseConfig):
  80. """开发环境配置"""
  81. # 报警内容 环境区分
  82. ENV_TEXT = "开发环境"
  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.hologres.aliyuncs.com',
  92. 'port': 80,
  93. 'dbname': 'dssm',
  94. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  95. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  96. }
  97. # 测试环境mysql地址
  98. MYSQL_INFO = {
  99. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  100. 'port': 3306,
  101. 'user': 'wx2016_longvideo',
  102. 'password': 'wx2016_longvideoP@assword1234',
  103. 'db': 'longvideo',
  104. 'charset': 'utf8'
  105. }
  106. # Hologres视频状态存储表名
  107. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  108. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  109. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  110. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  111. # 获取视频在流量池中的剩余可分发数接口地址
  112. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  113. class TestConfig(BaseConfig):
  114. """测试环境配置"""
  115. # 报警内容 环境区分
  116. ENV_TEXT = "测试环境"
  117. # 测试环境redis地址
  118. REDIS_INFO = {
  119. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  120. 'port': 6379,
  121. 'password': 'Wqsd@2019',
  122. }
  123. # Hologres连接参数,服务器使用
  124. HOLOGRES_INFO = {
  125. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  126. 'port': 80,
  127. 'dbname': 'dssm',
  128. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  129. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  130. }
  131. # 测试环境mysql地址
  132. MYSQL_INFO = {
  133. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  134. 'port': 3306,
  135. 'user': 'wx2016_longvideo',
  136. 'password': 'wx2016_longvideoP@assword1234',
  137. 'db': 'longvideo',
  138. 'charset': 'utf8'
  139. }
  140. # Hologres视频状态存储表名
  141. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  142. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  143. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  144. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  145. # 获取视频在流量池中的剩余可分发数接口地址
  146. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  147. class PreProductionConfig(BaseConfig):
  148. """预发布环境配置"""
  149. # 报警内容 环境区分
  150. ENV_TEXT = "预发布环境"
  151. # 线上环境redis地址
  152. REDIS_INFO = {
  153. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  154. 'port': 6379,
  155. 'password': 'Wqsd@2019',
  156. }
  157. # Hologres连接参数,服务器使用
  158. HOLOGRES_INFO = {
  159. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  160. 'port': 80,
  161. 'dbname': 'dssm',
  162. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  163. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  164. }
  165. # 生产环境mysql地址
  166. MYSQL_INFO = {
  167. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  168. 'port': 3306,
  169. 'user': 'wx2016_longvideo',
  170. 'password': 'wx2016_longvideoP@assword1234',
  171. 'db': 'longvideo',
  172. 'charset': 'utf8'
  173. }
  174. # Hologres视频状态存储表名
  175. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  176. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  177. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  178. VIDEO_FILTER_URL = 'http://prespeed-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  179. # 获取视频在流量池中的剩余可分发数接口地址
  180. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  181. class ProductionConfig(BaseConfig):
  182. """生产环境配置"""
  183. # 报警内容 环境区分
  184. ENV_TEXT = "生产环境"
  185. # 线上环境redis地址
  186. REDIS_INFO = {
  187. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  188. 'port': 6379,
  189. 'password': 'Wqsd@2019',
  190. }
  191. # Hologres连接参数,服务器使用
  192. HOLOGRES_INFO = {
  193. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  194. 'port': 80,
  195. 'dbname': 'dssm',
  196. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  197. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  198. }
  199. # 生产环境mysql地址
  200. MYSQL_INFO = {
  201. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  202. 'port': 3306,
  203. 'user': 'wx2016_longvideo',
  204. 'password': 'wx2016_longvideoP@assword1234',
  205. 'db': 'longvideo',
  206. 'charset': 'utf8'
  207. }
  208. # Hologres视频状态存储表名
  209. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  210. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  211. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  212. VIDEO_FILTER_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  213. # 获取视频在流量池中的剩余可分发数接口地址
  214. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  215. def set_config():
  216. with open('env.conf', 'r') as env_f:
  217. line = env_f.read()
  218. env = line.split('=')[1].strip()
  219. if env == 'dev':
  220. return DevelopmentConfig()
  221. elif env == 'test':
  222. return TestConfig()
  223. elif env == 'pre':
  224. return PreProductionConfig()
  225. elif env == 'pro':
  226. return ProductionConfig()