config.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. import os
  2. # from log import Log
  3. # log_ = Log()
  4. class BaseConfig(object):
  5. # 产品标识
  6. APP_TYPE = {
  7. 'VLOG': 0, # vlog
  8. 'LOVE_LIVE': 4, # 票圈视频
  9. 'LONG_VIDEO': 5, # 内容精选
  10. 'SHORT_VIDEO': 6, # 票圈短视频
  11. 'WAN_NENG_VIDEO': 17, # 万能影视屋
  12. 'LAO_HAO_KAN_VIDEO': 18, # 老好看视频
  13. 'ZUI_JING_QI': 19, # 票圈最惊奇
  14. 'APP': 13, # 票圈视频APP
  15. }
  16. # abTest
  17. AB_TEST = {
  18. 'w_h_rate': [APP_TYPE['LONG_VIDEO']], # 视频宽高比实验(每组的前两个视频调整为横屏视频), 已下线
  19. 'position_insert': [APP_TYPE['SHORT_VIDEO'], APP_TYPE['LOVE_LIVE']],
  20. 'relevant_video_op': [APP_TYPE['LONG_VIDEO']], # 相关推荐强插实验(运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部)
  21. 'rank_by_h': [APP_TYPE['VLOG']], # 小时级别更新rov列表
  22. }
  23. # abCode
  24. AB_CODE = {
  25. 'initial': 10000, # 初始
  26. 'w_h_rate': 10001, # 视频宽高比实验(每组的前两个视频调整为横屏视频),已下线
  27. 'position_insert': 10002, # 按位置插入
  28. 'relevant_video_op': 10003, # 运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部
  29. 'rank_by_h': 20001, # 小时级别更新rov列表实验
  30. }
  31. # pushFrom
  32. PUSH_FROM = {
  33. 'rov_recall': 'recall_pool', # rov召回池
  34. 'flow_recall': 'flow_pool', # 流量池
  35. 'top': 'op_manual', # 置顶
  36. 'bottom': 'bottom_strategy', # 一层兜底
  37. 'bottom_last': 'bottom_strategy_last', # 二层兜底
  38. 'position_insert': 'position_insert', # 按位置插入
  39. 'relevant_video_op': 'relevant_video_op', # 相关推荐强插
  40. }
  41. # category id mapping
  42. CATEGORY = {
  43. 'recommend': [55], # 推荐
  44. 'other': [] # 其他类别
  45. }
  46. # 前k个从ROV召回池中获取视频
  47. K = 3
  48. # 从流量池获取视频的概率设置
  49. P = 0.15
  50. # ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  51. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  52. # 小程序小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.h.{date}.{h}
  53. RECALL_KEY_NAME_PREFIX_BY_H = 'com.weiqu.video.recall.hot.item.score.h.'
  54. # app应用 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}
  55. RECALL_KEY_NAME_PREFIX_APP = 'com.weiqu.video.recall.hot.item.score.app.'
  56. # app应用 小时级数据更新最终结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}.{h}
  57. APP_FINAL_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.app.'
  58. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.6.{h}
  59. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.6.'
  60. # 流量池redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  61. FLOW_POOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  62. # 修改ROV的视频 redis key
  63. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  64. UPDATE_ROV_KEY_NAME_APP = 'com.weiqu.video.update.rov.item.score.app'
  65. # 首页推荐预曝光列表redis key 前缀,完整key格式:com.weiqu.video.hot.recommend.previewed.{appType}.{mid}
  66. PREVIEW_KEY_PREFIX = 'com.weiqu.video.hot.recommend.previewed.'
  67. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.{appType}.{mid}.{date}
  68. LAST_VIDEO_FROM_ROV_POOL_PREFIX = 'com.weiqu.video.rov.pool.last.'
  69. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{h}
  70. # LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  71. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{videoId}.{flowPool}
  72. LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  73. # 从ROV召回池获取视频的最大频次,限制每次请求的获取次数
  74. MAX_FREQ_FROM_ROV_POOL = 3
  75. # 兜底视频redis存储key
  76. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  77. # 生效中的置顶视频列表 redis key
  78. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  79. TOP_VIDEO_LIST_KEY_NAME_APP = 'com.weiqu.video.top.item.score.area.app'
  80. # 按位置排序redis存储key
  81. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  82. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  83. # rov召回池更新时间
  84. ROV_UPDATE_H = 6
  85. ROV_UPDATE_MINUTE = 30
  86. # 小时级召回池更新时间 每个小时的15分更新成功
  87. ROV_H_UPDATE_MINUTE = 15
  88. # 置顶视频区域 为 全部 的code
  89. ALL_AREA_CODE = '000000'
  90. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  91. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  92. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  93. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  94. }
  95. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  96. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  97. class DevelopmentConfig(BaseConfig):
  98. """开发环境配置"""
  99. # 报警内容 环境区分
  100. ENV_TEXT = "开发环境"
  101. # 测试环境redis地址
  102. REDIS_INFO = {
  103. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  104. 'port': 6379,
  105. 'password': 'Wqsd@2019',
  106. }
  107. # Hologres连接参数,本地使用
  108. HOLOGRES_INFO = {
  109. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  110. 'port': 80,
  111. 'dbname': 'dssm',
  112. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  113. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  114. }
  115. # 测试环境mysql地址
  116. MYSQL_INFO = {
  117. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  118. 'port': 3306,
  119. 'user': 'wx2016_longvideo',
  120. 'password': 'wx2016_longvideoP@assword1234',
  121. 'db': 'longvideo',
  122. 'charset': 'utf8'
  123. }
  124. # Hologres视频状态存储表名
  125. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  126. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  127. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  128. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  129. # 获取视频在流量池中的剩余可分发数接口地址
  130. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  131. # 日志服务配置
  132. ALIYUN_LOG = {
  133. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  134. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  135. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  136. 'PROJECT': 'rov-server-test',
  137. }
  138. # AB实验配置
  139. AB_EXP_CODE = {
  140. 'rec_size_home': '003',
  141. 'rec_size_relevant': '004',
  142. 'rule_rank1': '011'
  143. }
  144. class TestConfig(BaseConfig):
  145. """测试环境配置"""
  146. # 报警内容 环境区分
  147. ENV_TEXT = "测试环境"
  148. # 测试环境redis地址
  149. REDIS_INFO = {
  150. 'host': 'r-bp1ps6my7lzg8rdhwx682.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. # 测试环境mysql地址
  163. MYSQL_INFO = {
  164. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  165. 'port': 3306,
  166. 'user': 'wx2016_longvideo',
  167. 'password': 'wx2016_longvideoP@assword1234',
  168. 'db': 'longvideo',
  169. 'charset': 'utf8'
  170. }
  171. # Hologres视频状态存储表名
  172. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  173. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  174. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  175. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  176. # 获取视频在流量池中的剩余可分发数接口地址
  177. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  178. # 日志服务配置
  179. ALIYUN_LOG = {
  180. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  181. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  182. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  183. 'PROJECT': 'rov-server-test',
  184. }
  185. # AB实验配置
  186. AB_EXP_CODE = {
  187. 'rec_size_home': '003',
  188. 'rec_size_relevant': '004',
  189. 'rule_rank1': '011'
  190. }
  191. class PreProductionConfig(BaseConfig):
  192. """预发布环境配置"""
  193. # 报警内容 环境区分
  194. ENV_TEXT = "预发布环境"
  195. # 线上环境redis地址
  196. REDIS_INFO = {
  197. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  198. 'port': 6379,
  199. 'password': 'Wqsd@2019',
  200. }
  201. # Hologres连接参数,服务器使用
  202. HOLOGRES_INFO = {
  203. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  204. 'port': 80,
  205. 'dbname': 'dssm',
  206. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  207. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  208. }
  209. # 生产环境mysql地址
  210. MYSQL_INFO = {
  211. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  212. 'port': 3306,
  213. 'user': 'wx2016_longvideo',
  214. 'password': 'wx2016_longvideoP@assword1234',
  215. 'db': 'longvideo',
  216. 'charset': 'utf8'
  217. }
  218. # Hologres视频状态存储表名
  219. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  220. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  221. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  222. VIDEO_FILTER_URL = 'http://prespeed-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  223. # 获取视频在流量池中的剩余可分发数接口地址
  224. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  225. # 日志服务配置
  226. ALIYUN_LOG = {
  227. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  228. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  229. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  230. 'PROJECT': 'rov-server',
  231. }
  232. # AB实验配置
  233. AB_EXP_CODE = {
  234. 'rec_size_home': '003',
  235. 'rec_size_relevant': '004',
  236. 'rule_rank1': ''
  237. }
  238. class ProductionConfig(BaseConfig):
  239. """生产环境配置"""
  240. # 报警内容 环境区分
  241. ENV_TEXT = "生产环境"
  242. # 线上环境redis地址
  243. REDIS_INFO = {
  244. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  245. 'port': 6379,
  246. 'password': 'Wqsd@2019',
  247. }
  248. # Hologres连接参数,服务器使用
  249. HOLOGRES_INFO = {
  250. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  251. 'port': 80,
  252. 'dbname': 'dssm',
  253. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  254. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  255. }
  256. # 生产环境mysql地址
  257. MYSQL_INFO = {
  258. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  259. 'port': 3306,
  260. 'user': 'wx2016_longvideo',
  261. 'password': 'wx2016_longvideoP@assword1234',
  262. 'db': 'longvideo',
  263. 'charset': 'utf8'
  264. }
  265. # Hologres视频状态存储表名
  266. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  267. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  268. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  269. VIDEO_FILTER_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  270. # 获取视频在流量池中的剩余可分发数接口地址
  271. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  272. # 日志服务配置
  273. ALIYUN_LOG = {
  274. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  275. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  276. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  277. 'PROJECT': 'rov-server',
  278. }
  279. # AB实验配置
  280. AB_EXP_CODE = {
  281. 'rec_size_home': '003',
  282. 'rec_size_relevant': '004',
  283. 'rule_rank1': ''
  284. }
  285. def set_config():
  286. # 获取环境变量 ROV_SERVER_ENV
  287. env = os.environ.get('ROV_SERVER_ENV')
  288. # env = 'dev'
  289. if env is None:
  290. # log_.error('ENV ERROR: is None!')
  291. return
  292. if env == 'dev':
  293. return DevelopmentConfig()
  294. elif env == 'test':
  295. return TestConfig()
  296. elif env == 'pre':
  297. return PreProductionConfig()
  298. elif env == 'pro':
  299. return ProductionConfig()
  300. else:
  301. # log_.error('ENV ERROR: is {}'.format(env))
  302. return