config.py 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491
  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. # AB实验配置
  17. AB_EXP_CODE = {
  18. 'rec_size_home': '003',
  19. 'rec_size_relevant': '004',
  20. 'rule_rank1': '011',
  21. 'rule_rank2': '016',
  22. 'rov_rank_appType_18_19': '019',
  23. 'rule_rank3': '023',
  24. 'rule_rank4': '024',
  25. 'rule_rank5': '025',
  26. 'rov_rank_appType_19': '027',
  27. 'day_rule_rank1': '026',
  28. 'day_rule_rank2': '030',
  29. 'ab_initial': '031',
  30. 'old_video': '034',
  31. 'region_rule_rank1': '037',
  32. 'rule_rank6': '040',
  33. }
  34. # abTest
  35. AB_TEST = {
  36. 'w_h_rate': [APP_TYPE['LONG_VIDEO']], # 视频宽高比实验(每组的前两个视频调整为横屏视频), 已下线
  37. 'position_insert': [APP_TYPE['SHORT_VIDEO'], APP_TYPE['LOVE_LIVE']],
  38. 'relevant_video_op': [APP_TYPE['LONG_VIDEO']], # 相关推荐强插实验(运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部)
  39. 'rank_by_h': [APP_TYPE['VLOG']], # 小时级别更新rov列表
  40. }
  41. # abCode
  42. AB_CODE = {
  43. 'initial': 10000, # 初始
  44. 'w_h_rate': 10001, # 视频宽高比实验(每组的前两个视频调整为横屏视频),已下线
  45. 'position_insert': 10002, # 按位置插入
  46. 'relevant_video_op': 10003, # 运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部
  47. 'rov_rank_appType_18_19': 30001, # 老好看视频 / 票圈最惊奇 首页/相关推荐逻辑更新实验
  48. 'rov_rank_appType_19': 30002, # 票圈最惊奇 首页/相关推荐逻辑更新实验 (2:2)
  49. 'rank_by_h': {
  50. 'rule_rank1': 20001,
  51. 'rule_rank2': 20002,
  52. 'rule_rank3': 20003,
  53. 'rule_rank4': 20004,
  54. 'rule_rank5': 20005,
  55. 'rule_rank6': 20006,
  56. }, # 小时级别更新rov列表实验
  57. 'rank_by_day': {
  58. 'day_rule_rank1': 40001,
  59. 'day_rule_rank2': 40002,
  60. }, # 天级别规则更新rov列表实验
  61. 'ab_initial': 20000, # ab实验相对实验组(无人工调整)
  62. 'old_video': 50001, # 固定位置插入老视频
  63. 'region_rank_by_h': {
  64. 'region_rule_rank1': 60001,
  65. }, # 地域分组小时级规则实验
  66. }
  67. # 小程序小时级列表key不同实验标识
  68. RULE_KEY = {
  69. 'initial': '',
  70. 'rule_rank1': 'rule1',
  71. 'rule_rank2': 'rule2',
  72. 'rule_rank3': 'rule3',
  73. 'rule_rank4': 'rule4',
  74. 'rule_rank5': 'rule5',
  75. 'rule_rank6': 'rule6',
  76. }
  77. # 小程序天级别规则列表key不同实验标识
  78. RULE_KEY_DAY = {
  79. 'initial': '',
  80. 'day_rule_rank1': 'rule1',
  81. 'day_rule_rank2': 'rule2',
  82. }
  83. # 小程序地域分组小时级列表key不同实验标识
  84. RULE_KEY_REGION = {
  85. 'initial': '',
  86. 'region_rule_rank1': 'rule1',
  87. }
  88. # pushFrom
  89. PUSH_FROM = {
  90. 'rov_recall': 'recall_pool', # rov召回池
  91. 'flow_recall': 'flow_pool', # 流量池
  92. 'top': 'op_manual', # 置顶
  93. 'bottom': 'bottom_strategy', # 一层兜底
  94. 'bottom_last': 'bottom_strategy_last', # 二层兜底
  95. 'position_insert': 'position_insert', # 按位置插入
  96. 'relevant_video_op': 'relevant_video_op', # 相关推荐强插
  97. 'rov_recall_h': 'recall_pool_h', # 小时级更新列表
  98. 'rov_recall_day': 'recall_pool_day', # 天级规则更新列表
  99. 'old_video': 'old_video_recall', # 老视频
  100. 'rov_recall_region_h': 'recall_pool_region_h', # 地域分组小时级更新列表
  101. 'rov_recall_region_day': 'recall_pool_region_day', # 地域分组天级更新列表
  102. }
  103. # category id mapping
  104. CATEGORY = {
  105. 'recommend': [55], # 推荐
  106. 'other': [] # 其他类别
  107. }
  108. # 前k个从ROV召回池中获取视频
  109. K = 3
  110. # 从流量池获取视频的概率设置
  111. P = 0.3
  112. P_18_19 = 1
  113. # ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  114. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  115. # 小程序小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.h.{rule_key}.{date}.{h}
  116. RECALL_KEY_NAME_PREFIX_BY_H = 'com.weiqu.video.recall.item.score.h.'
  117. # 小程序离线ROV模型结果与小程序小时级更新结果去重后 存放 redis key前缀,
  118. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.h.{rule_key}{date}.{h}
  119. RECALL_KEY_NAME_PREFIX_DUP_H = 'com.weiqu.video.recall.hot.item.score.dup.h.'
  120. # 每个mid存储对应小时级更新结果 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.h.mid.{mid}
  121. H_WITH_MID_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.h.mid.'
  122. # 记录 mid-小时级key 中数据所属(date,h),完整格式:com.weiqu.video.h.record.mid.{mid}
  123. H_WITH_MID_RECORD_KEY_NAME_PREFIX = 'com.weiqu.video.h.record.mid.'
  124. # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.{rule_key}
  125. H_VIDEO_FILER = 'com.weiqu.video.filter.h.item.'
  126. # 小程序天级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.day.{rule_key}.{date}
  127. RECALL_KEY_NAME_PREFIX_BY_DAY = 'com.weiqu.video.recall.item.score.day.'
  128. # 小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  129. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.now.{rule_key}.{date}
  130. RECALL_KEY_NAME_PREFIX_DUP_DAY_NOW = 'com.weiqu.video.recall.hot.item.score.dup.day.now.'
  131. # 使用前一天小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  132. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.pre.{rule_key}.{date}
  133. RECALL_KEY_NAME_PREFIX_DUP_DAY_PRE = 'com.weiqu.video.recall.hot.item.score.dup.day.pre.'
  134. # 小程序地域分组小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.region.h.{region}.{rule_key}.{date}.{h}
  135. RECALL_KEY_NAME_PREFIX_REGION_BY_H = 'com.weiqu.video.recall.item.score.region.h.'
  136. # 小程序地域分组天级更新结果与小程序地域分组小时级更新结果去重后 存放 redis key前缀,
  137. # 完整格式:com.weiqu.video.recall.hot.item.score.dup1.region.day.h.{region}.{rule_key}.{date}.{h}
  138. RECALL_KEY_NAME_PREFIX_DUP1_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup1.region.day.h.'
  139. # 小程序天级更新结果与 小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  140. # 完整格式:com.weiqu.video.recall.hot.item.score.dup2.region.day.h.{region}.{rule_key}.{date}.{h}
  141. RECALL_KEY_NAME_PREFIX_DUP2_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup2.region.day.h.'
  142. # 小程序离线ROV模型结果与 小程序天级更新结果/小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  143. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.h.{region}.{rule_key}.{date}.{h}
  144. RECALL_KEY_NAME_PREFIX_DUP_REGION_H = 'com.weiqu.video.recall.hot.item.score.dup.region.h.'
  145. # 地域分组小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.region.h.item.{region}.{rule_key}
  146. REGION_H_VIDEO_FILER = 'com.weiqu.video.filter.region.h.item.'
  147. # app应用 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}
  148. RECALL_KEY_NAME_PREFIX_APP = 'com.weiqu.video.recall.hot.item.score.app.'
  149. # app应用 小时级数据更新最终结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}.{h}
  150. APP_FINAL_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.app.'
  151. # appType:[18, 19]小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{appType}.{date}.{h}
  152. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.item.score.'
  153. # 小程序老视频更新结果存放 redis key 前缀,完整格式:'com.weiqu.video.recall.old.item.{date}'
  154. RECALL_KEY_NAME_PREFIX_OLD_VIDEOS = 'com.weiqu.video.recall.old.item.'
  155. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.6.{h}
  156. # RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.6.'
  157. # 流量池redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  158. FLOW_POOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  159. # 修改ROV的视频 redis key
  160. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  161. UPDATE_ROV_KEY_NAME_APP = 'com.weiqu.video.update.rov.item.score.app'
  162. # 首页推荐预曝光列表redis key 前缀,完整key格式:com.weiqu.video.hot.recommend.previewed.{appType}.{mid}
  163. PREVIEW_KEY_PREFIX = 'com.weiqu.video.hot.recommend.previewed.'
  164. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.{appType}.{mid}.{date}
  165. LAST_VIDEO_FROM_ROV_POOL_PREFIX = 'com.weiqu.video.rov.pool.last.'
  166. # 用户上一次在天级规则更新列表中对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.{appType}.{mid}.{date}
  167. LAST_VIDEO_FROM_RULE_DAY_POOL_PREFIX = 'com.weiqu.video.rule.day.pool.last.'
  168. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.pre.{appType}.{mid}.{date}
  169. LAST_VIDEO_FROM_ROV_POOL_PRE_PREFIX = 'com.weiqu.video.rov.pool.last.pre.'
  170. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.now.{appType}.{mid}.{date}
  171. LAST_VIDEO_FROM_ROV_POOL_NOW_PREFIX = 'com.weiqu.video.rov.pool.last.now.'
  172. # 用户上一次在region dup更新列表中对应的位置 redis key前缀,完整key格式:com.weiqu.video.region.dup.last.{dup}.{appType}.{mid}.{date}
  173. LAST_VIDEO_FROM_REGION_DUP_PREFIX = 'com.weiqu.video.region.dup.last.'
  174. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{h}
  175. # LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  176. # 本地记录视频的可分发数,控制分发,完整key格式:com.weiqu.video.flowpool.local.distribute.count.{videoId}.{flowPool}
  177. LOCAL_DISTRIBUTE_COUNT_PREFIX = 'com.weiqu.video.flowpool.local.distribute.count.'
  178. # 从ROV召回池获取视频的最大频次,限制每次请求的获取次数
  179. MAX_FREQ_FROM_ROV_POOL = 3
  180. # 兜底视频redis存储key
  181. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  182. # 生效中的置顶视频列表 redis key
  183. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  184. TOP_VIDEO_LIST_KEY_NAME_APP = 'com.weiqu.video.top.item.score.area.app'
  185. # 按位置排序redis存储key
  186. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  187. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  188. # rov召回池更新时间
  189. ROV_UPDATE_H = 6
  190. ROV_UPDATE_MINUTE = 30
  191. # 小时级召回池更新时间 每个小时的15分更新成功
  192. ROV_H_UPDATE_MINUTE = 15
  193. # 地域分组小时级召回池更新时间
  194. REGION_H_UPDATE_MINUTE = 30
  195. # 天级规则更新列表更新时间 00:30更新成功
  196. ROV_DAY_UPDATE_MINUTE = 0
  197. # 置顶视频区域 为 全部 的code
  198. ALL_AREA_CODE = '000000'
  199. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  200. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  201. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  202. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  203. }
  204. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  205. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  206. class DevelopmentConfig(BaseConfig):
  207. """开发环境配置"""
  208. # 报警内容 环境区分
  209. ENV_TEXT = "开发环境"
  210. # 测试环境redis地址
  211. REDIS_INFO = {
  212. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  213. 'port': 6379,
  214. 'password': 'Wqsd@2019',
  215. }
  216. # Hologres连接参数,本地使用
  217. HOLOGRES_INFO = {
  218. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  219. 'port': 80,
  220. 'dbname': 'dssm',
  221. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  222. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  223. }
  224. # 测试环境mysql地址
  225. MYSQL_INFO = {
  226. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  227. 'port': 3306,
  228. 'user': 'wx2016_longvideo',
  229. 'password': 'wx2016_longvideoP@assword1234',
  230. 'db': 'longvideo',
  231. 'charset': 'utf8'
  232. }
  233. # Hologres视频状态存储表名
  234. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  235. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  236. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  237. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  238. # 获取视频在流量池中的剩余可分发数接口地址
  239. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  240. # 日志服务配置
  241. ALIYUN_LOG = {
  242. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  243. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  244. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  245. 'PROJECT': 'rov-server-test',
  246. }
  247. # # AB实验配置
  248. # AB_EXP_CODE = {
  249. # 'rec_size_home': '003',
  250. # 'rec_size_relevant': '004',
  251. # 'rule_rank1_20': '011',
  252. # 'rule_rank1_50': '016'
  253. # }
  254. class TestConfig(BaseConfig):
  255. """测试环境配置"""
  256. # 报警内容 环境区分
  257. ENV_TEXT = "测试环境"
  258. # 测试环境redis地址
  259. REDIS_INFO = {
  260. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  261. 'port': 6379,
  262. 'password': 'Wqsd@2019',
  263. }
  264. # Hologres连接参数,服务器使用
  265. HOLOGRES_INFO = {
  266. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  267. 'port': 80,
  268. 'dbname': 'dssm',
  269. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  270. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  271. }
  272. # 测试环境mysql地址
  273. MYSQL_INFO = {
  274. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  275. 'port': 3306,
  276. 'user': 'wx2016_longvideo',
  277. 'password': 'wx2016_longvideoP@assword1234',
  278. 'db': 'longvideo',
  279. 'charset': 'utf8'
  280. }
  281. # Hologres视频状态存储表名
  282. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  283. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  284. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  285. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  286. # 获取视频在流量池中的剩余可分发数接口地址
  287. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  288. # 日志服务配置
  289. ALIYUN_LOG = {
  290. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  291. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  292. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  293. 'PROJECT': 'rov-server-test',
  294. }
  295. # # AB实验配置
  296. # AB_EXP_CODE = {
  297. # 'rec_size_home': '003',
  298. # 'rec_size_relevant': '004',
  299. # 'rule_rank1_20': '011',
  300. # 'rule_rank1_50': '016'
  301. # }
  302. class PreProductionConfig(BaseConfig):
  303. """预发布环境配置"""
  304. # 报警内容 环境区分
  305. ENV_TEXT = "预发布环境"
  306. # 线上环境redis地址
  307. REDIS_INFO = {
  308. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  309. 'port': 6379,
  310. 'password': 'Wqsd@2019',
  311. }
  312. # Hologres连接参数,服务器使用
  313. HOLOGRES_INFO = {
  314. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  315. 'port': 80,
  316. 'dbname': 'dssm',
  317. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  318. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  319. }
  320. # 生产环境mysql地址
  321. MYSQL_INFO = {
  322. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  323. 'port': 3306,
  324. 'user': 'wx2016_longvideo',
  325. 'password': 'wx2016_longvideoP@assword1234',
  326. 'db': 'longvideo',
  327. 'charset': 'utf8'
  328. }
  329. # Hologres视频状态存储表名
  330. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  331. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  332. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  333. VIDEO_FILTER_URL = 'http://prespeed-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  334. # 获取视频在流量池中的剩余可分发数接口地址
  335. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  336. # 日志服务配置
  337. ALIYUN_LOG = {
  338. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  339. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  340. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  341. 'PROJECT': 'rov-server',
  342. }
  343. # # AB实验配置
  344. # AB_EXP_CODE = {
  345. # 'rec_size_home': '003',
  346. # 'rec_size_relevant': '004',
  347. # 'rule_rank1': '011'
  348. # }
  349. class ProductionConfig(BaseConfig):
  350. """生产环境配置"""
  351. # 报警内容 环境区分
  352. ENV_TEXT = "生产环境"
  353. # 线上环境redis地址
  354. REDIS_INFO = {
  355. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  356. 'port': 6379,
  357. 'password': 'Wqsd@2019',
  358. }
  359. # Hologres连接参数,服务器使用
  360. HOLOGRES_INFO = {
  361. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  362. 'port': 80,
  363. 'dbname': 'dssm',
  364. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  365. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  366. }
  367. # 生产环境mysql地址
  368. MYSQL_INFO = {
  369. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  370. 'port': 3306,
  371. 'user': 'wx2016_longvideo',
  372. 'password': 'wx2016_longvideoP@assword1234',
  373. 'db': 'longvideo',
  374. 'charset': 'utf8'
  375. }
  376. # Hologres视频状态存储表名
  377. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  378. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  379. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  380. VIDEO_FILTER_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  381. # 获取视频在流量池中的剩余可分发数接口地址
  382. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  383. # 日志服务配置
  384. ALIYUN_LOG = {
  385. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  386. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  387. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  388. 'PROJECT': 'rov-server',
  389. }
  390. # # AB实验配置
  391. # AB_EXP_CODE = {
  392. # 'rec_size_home': '003',
  393. # 'rec_size_relevant': '004',
  394. # 'rule_rank1': '011'
  395. # }
  396. def set_config():
  397. # 获取环境变量 ROV_SERVER_ENV
  398. env = os.environ.get('ROV_SERVER_ENV')
  399. # env = 'dev'
  400. if env is None:
  401. # log_.error('ENV ERROR: is None!')
  402. return
  403. if env == 'dev':
  404. return DevelopmentConfig()
  405. elif env == 'test':
  406. return TestConfig()
  407. elif env == 'pre':
  408. return PreProductionConfig()
  409. elif env == 'pro':
  410. return ProductionConfig()
  411. else:
  412. # log_.error('ENV ERROR: is {}'.format(env))
  413. return