config.py 67 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386
  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. 'PIAO_QUAN_VIDEO_PLUS': 21, # 票圈视频+
  16. 'JOURNEY': 22, # 票圈足迹
  17. 'BLESSING_YEAR': 3, # 票圈福年
  18. 'H5': 12, # H5
  19. }
  20. # 白名单(影视,宗教)过滤Redis
  21. REDIS_INFO_FILTER = {
  22. 'host': 'r-bp1258kbkv8dj81dwj.redis.rds.aliyuncs.com',
  23. 'port': 6379,
  24. 'password': 'Wqsd@2019',
  25. }
  26. REGION_CODE = {
  27. '北京': '110000', '天津': '120000', '河北省': '130000', '山西省': '140000', '内蒙古': '150000',
  28. '辽宁省': '210000', '吉林省': '220000', '黑龙江省': '230000',
  29. '上海': '310000', '江苏省': '320000', '浙江省': '330000', '安徽省': '340000', '福建省': '350000', '江西省': '360000',
  30. '山东省': '370000',
  31. '河南省': '410000', '湖北省': '420000', '湖南省': '430000', '广东省': '440000', '广西': '450000', '海南省': '460000',
  32. '重庆': '500000', '四川省': '510000', '贵州省': '520000', '云南省': '530000', '西藏': '540000',
  33. '陕西省': '610000', '甘肃省': '620000', '青海省': '630000', '宁夏': '640000', '新疆': '650000',
  34. '台湾省': '710000', '香港': '810000', '澳门': '820000',
  35. }
  36. CITY_CODE = {
  37. '广州': '440100', '深圳': '440300', '成都': '510100', '长沙': '430100',
  38. }
  39. # 本山祝福视频redis存储key
  40. BENSHAN_ZHUFU_KEY_NAME = 'benshanzf:videos'
  41. # 特殊地区屏蔽危险视频redis存储key
  42. SPECIAL_AREA_LIMIT_KEY_NAME = 'special:area:limit:videos'
  43. # 屏蔽视频配置 key:region_code, value:videos key list
  44. SHIELD_CONFIG = {}
  45. SHIELD_CONFIG2 = {
  46. '-1': [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  47. CITY_CODE['广州']: [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  48. CITY_CODE['深圳']: [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  49. CITY_CODE['成都']: [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  50. CITY_CODE['长沙']: [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  51. REGION_CODE['北京']: [SPECIAL_AREA_LIMIT_KEY_NAME, ],
  52. }
  53. # 涉政视频可分发的端
  54. POLITICAL_RECOMMEND_APP_TYPE_LIST = [
  55. APP_TYPE['VLOG'], # vlog
  56. APP_TYPE['LOVE_LIVE'], # 票圈视频
  57. APP_TYPE['APP'], # 票圈视频APP
  58. ]
  59. # abTest
  60. AB_TEST = {
  61. 'w_h_rate': [APP_TYPE['LONG_VIDEO']], # 视频宽高比实验(每组的前两个视频调整为横屏视频), 已下线
  62. 'position_insert': [APP_TYPE['SHORT_VIDEO'], APP_TYPE['LOVE_LIVE']],
  63. 'relevant_video_op': [APP_TYPE['LONG_VIDEO']], # 相关推荐强插实验(运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部)
  64. 'rank_by_h': [APP_TYPE['VLOG']], # 小时级别更新rov列表
  65. }
  66. # abCode
  67. AB_CODE = {
  68. 'initial': 10000, # 初始
  69. 'special_mid': 99999, # 特殊mid
  70. 'w_h_rate': 10001, # 视频宽高比实验(每组的前两个视频调整为横屏视频),已下线
  71. 'position_insert': 10002, # 按位置插入
  72. 'relevant_video_op': 10003, # 运营对某些视频给定一些相关视频,调整为对应视频相关推荐的头部
  73. 'rov_rank_appType_18_19': 30001, # 老好看视频 / 票圈最惊奇 首页/相关推荐逻辑更新实验
  74. 'rov_rank_appType_19': 30002, # 票圈最惊奇 首页/相关推荐逻辑更新实验 (2:2)
  75. 'rank_by_h': {
  76. 'rule_rank1': 20001,
  77. 'rule_rank2': 20002,
  78. 'rule_rank3': 20003,
  79. 'rule_rank4': 20004,
  80. 'rule_rank5': 20005,
  81. 'rule_rank6': 20006,
  82. }, # 小时级别更新rov列表实验
  83. 'rank_by_day': {
  84. 'day_rule_rank1': 40001,
  85. 'day_rule_rank2': 40002,
  86. }, # 天级别规则更新rov列表实验
  87. 'ab_initial': 20000, # ab实验相对实验组(无人工调整)
  88. 'old_video': 50001, # 固定位置插入老视频
  89. 'region_rank_by_h': {
  90. 'region_rule_rank1': 60001,
  91. 'region_rule_rank2': 60002,
  92. 'region_rule_rank3': 60003,
  93. 'region_rule_rank4': 60004,
  94. 'region_rule_rank4_appType_5_data2': 60005,
  95. 'region_rule_rank4_appType_5_data3': 60006,
  96. 'region_rule_rank4_appType_5_data4': 60007,
  97. 'region_rule_rank4_appType_0_data2': 60007,
  98. 'region_rule_rank4_appType_19_data2': 60008,
  99. 'region_rule_rank4_appType_19_data3': 60009,
  100. 'region_rule_rank4_appType_4_data2': 60011,
  101. 'region_rule_rank4_appType_4_data3': 60012,
  102. 'region_rule_rank4_appType_6_data2': 60013,
  103. 'region_rule_rank4_appType_6_data3': 60014,
  104. 'region_rule_rank4_appType_18_data2': 60015,
  105. 'region_rule_rank6_appType_0_data1': 60016,
  106. 'region_rule_rank6_appType_13_data2': 60017,
  107. 'abtest_095': 60010,
  108. 'abtest_095-1': 60000,
  109. 'abtest_112': 60018,
  110. 'abtest_082': 60019,
  111. 'abtest_117': 60020,
  112. 'abtest_120': 60021,
  113. 'abtest_121': 60022,
  114. 'abtest_122': 60023,
  115. 'abtest_130': 60024,
  116. 'abtest_139': 60025,
  117. 'app_abtest_110156': 60026,
  118. 'abtest_136': 60027,
  119. 'abtest_137': 60028,
  120. 'abtest_142': 60029,
  121. 'abtest_143': 60030,
  122. 'abtest_144': 60031,
  123. 'abtest_145': 60032,
  124. 'abtest_146': 60033,
  125. 'abtest_147': 60034,
  126. 'abtest_153': 60035,
  127. 'abtest_159': 60036,
  128. 'abtest_161': 60037,
  129. 'abtest_162': 60038,
  130. 'abtest_167': 60039,
  131. 'abtest_200': 60040,
  132. 'abtest_214': 60041,
  133. 'abtest_215': 60042,
  134. 'abtest_224': 60043,
  135. 'abtest_228': 60044,
  136. 'abtest_229': 60045,
  137. 'abtest_262': 60046,
  138. 'abtest_316': 60047,
  139. 'abtest_319': 60048,
  140. 'abtest_320': 60049,
  141. 'abtest_322': 60050,
  142. 'abtest_323': 60051,
  143. 'abtest_326': 60052,
  144. 'abtest_327': 60053,
  145. 'abtest_328': 60054,
  146. 'abtest_332': 60055,
  147. 'abtest_333': 60056,
  148. 'abtest_334': 60057,
  149. 'abtest_335': 60058,
  150. 'abtest_336': 60059,
  151. 'abtest_337': 60060,
  152. 'abtest_338': 60061,
  153. 'abtest_339': 60062,
  154. }, # 地域分组小时级规则实验
  155. 'rank_by_24h': {
  156. '24h_rule_rank1': 70001,
  157. '24h_rule_rank2': 70002,
  158. }, # 小时级规则更新过去24h数据实验
  159. 'top_video_relevant_appType_19': 80001, # 最惊奇电影类视频分享页相关推荐相似视频实验
  160. 'whole_movies': 90001, # 最惊奇首页/相关推荐 完整影视资源实验
  161. }
  162. # AB实验配置
  163. AB_EXP_CODE = {
  164. # '068': {
  165. # 'data_key': 'data1', 'rule_key': 'rule4',
  166. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank5_appType_0_data1')
  167. # }, # 票圈内容精选:data-vlog, rule-rule4
  168. '069': {
  169. 'data_key': 'data1', 'rule_key': 'rule4-1',
  170. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_095-1')
  171. }, # 最惊奇:data-vlog, rule-rule4
  172. # '072': {
  173. # 'data_key': 'data1', 'rule_key': 'rule4',
  174. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank5_appType_0_data1')
  175. # }, # 票圈视频:data-vlog, rule-rule4
  176. # '073': {
  177. # 'data_key': 'data1', 'rule_key': 'rule4',
  178. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank5_appType_0_data1')
  179. # }, # 票圈短视频:data-vlog, rule-rule4
  180. '074': {
  181. 'data_key': 'data1', 'rule_key': 'rule4-1',
  182. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_095-1')
  183. }, # 老好看视频:data-vlog, rule-rule4
  184. # '082': {
  185. # 'data_key': 'data2', 'rule_key': 'rule4',
  186. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_082')
  187. # }, # 票圈内容精选:data-[内容精选,vlog], rule-rule4
  188. # '083': {
  189. # 'data_key': 'data6', 'rule_key': 'rule3',
  190. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank4_appType_5_data4')
  191. # }, # 票圈内容精选:data-[内容精选,vlog, 票圈视频,票圈短视频], rule-rule3
  192. '095': {
  193. 'data_key': 'data1', 'rule_key': 'rule4',
  194. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_095')
  195. }, # vlog:data-vlog, rule-rule4
  196. '095-1': {
  197. 'data_key': 'data1', 'rule_key': 'rule4-1',
  198. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_095-1')
  199. },
  200. # '096': {
  201. # 'data_key': 'data3', 'rule_key': 'rule3',
  202. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank4_appType_4_data2')
  203. # }, # 票圈视频:data-[票圈视频,vlog], rule-rule3
  204. # '097': {
  205. # 'data_key': 'data6', 'rule_key': 'rule3',
  206. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank4_appType_4_data3')
  207. # }, # 票圈视频:data-[内容精选,vlog, 票圈视频,票圈短视频], rule-rule3
  208. # '098': {
  209. # 'data_key': 'data4', 'rule_key': 'rule3',
  210. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank4_appType_6_data2')
  211. # }, # 票圈短视频:data-[票圈短视频,vlog], rule-rule3
  212. # '099': {
  213. # 'data_key': 'data6', 'rule_key': 'rule3',
  214. # 'ab_code': AB_CODE['region_rank_by_h'].get('region_rule_rank4_appType_6_data3')
  215. # }, # 票圈短视频:data-[内容精选,vlog, 票圈视频,票圈短视频], rule-rule3
  216. # '112': {
  217. # 'data_key': 'data1', 'rule_key': 'rule4',
  218. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_112')
  219. # }, # 召回定位优化实验
  220. # '117': {
  221. # 'data_key': 'data6', 'rule_key': 'rule7',
  222. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_117')
  223. # }, # vlog 全数据实验 data-[vlog: 0.25, 内容精选: 0.25, 票圈视频: 0.25, 票圈短视频: 0.25], rule-rule7
  224. # '120': {
  225. # 'data_key': 'data3', 'rule_key': 'rule7',
  226. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_120')
  227. # }, # 票圈视频 分数据实验 data-[vlog: 0.5, 票圈视频: 0.5], rule-rule7
  228. '121': {
  229. 'data_key': 'data2', 'rule_key': 'rule7-1',
  230. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_121')
  231. }, # 内容精选 分数据实验 data-[vlog: 0.5, 内容精选: 0.5], rule-rule7
  232. # '122': {
  233. # 'data_key': 'data4', 'rule_key': 'rule7',
  234. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_122')
  235. # }, # 票圈短视频 分数据实验 data-[vlog: 0.5, 票圈短视频: 0.5], rule-rule7
  236. # '130': {
  237. # 'data_key': 'data1', 'rule_key': 'rule4',
  238. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_130')
  239. # }, # 095实验基础上去除大列表,进行兜底策略优化
  240. # '139': {
  241. # 'data_key': 'data1', 'rule_key': 'rule9', '30day_rule_key': 'rule1',
  242. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_139')
  243. # },
  244. # '136': {
  245. # 'data_key': 'data1', 'rule_key': 'rule10',
  246. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_136')
  247. # },
  248. # '137': {
  249. # 'data_key': 'data1', 'rule_key': 'rule11',
  250. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_137')
  251. # },
  252. # '142': {
  253. # 'data_key': 'data8', 'rule_key': 'rule7',
  254. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_142')
  255. # },
  256. # '143': {
  257. # 'data_key': 'data9', 'rule_key': 'rule7',
  258. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_143')
  259. # },
  260. '144': {
  261. 'data_key': 'data10', 'rule_key': 'rule7',
  262. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_144')
  263. },
  264. # '145': {
  265. # 'data_key': 'data11', 'rule_key': 'rule7',
  266. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_145')
  267. # },
  268. # '146': {
  269. # 'data_key': 'data12', 'rule_key': 'rule7',
  270. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_146')
  271. # },
  272. # '147': {
  273. # 'data_key': 'data13', 'rule_key': 'rule7',
  274. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_147')
  275. # },
  276. # '153': {
  277. # 'data_key': 'data1', 'rule_key': 'rule12',
  278. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_153')
  279. # },
  280. # '159': {
  281. # 'data_key': 'data14', 'rule_key': 'rule7',
  282. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_159')
  283. # }, # vlog 全数据实验 data-[vlog: 0.78, 票圈视频: 0.11, 票圈短视频: 0.08, 内容精选: 0.03], rule-rule7
  284. # '161': {
  285. # 'data_key': 'data1', 'rule_key': 'rule13',
  286. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_161')
  287. # },
  288. # '162': {
  289. # 'data_key': 'data1', 'rule_key': 'rule14',
  290. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_162')
  291. # },
  292. # '167': {
  293. # 'data_key': 'lhk_data', 'rule_key': 'lhk_rule',
  294. # 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_167')
  295. # },
  296. '200': {
  297. 'data_key': 'data1', 'rule_key': 'rule15',
  298. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_200')
  299. },
  300. '214': {
  301. 'data_key': 'data1', 'rule_key': 'rule16',
  302. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_214')
  303. },
  304. '215': {
  305. 'data_key': 'data1', 'rule_key': 'rule17',
  306. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_215')
  307. },
  308. '224': {
  309. 'data_key': 'data1', 'rule_key': 'rule18',
  310. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_224')
  311. },
  312. '228': {
  313. 'data_key': 'lhk_data', 'rule_key': 'lhk_rule1',
  314. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_228'),
  315. 'religion_class_name': 'catholicism',
  316. }, # 老好看 天主教 - 2插1
  317. '229': {
  318. 'data_key': 'lhk_data', 'rule_key': 'lhk_rule2',
  319. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_229'),
  320. 'religion_class_name': 'christianity'
  321. }, # 老好看 基督教 - 2插1
  322. '262': {
  323. 'data_key': 'data1', 'rule_key': 'rule4-2',
  324. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_262'),
  325. 'shield_config': SHIELD_CONFIG2,
  326. }, # vlog:data-vlog, rule-rule4-2
  327. '316': {
  328. 'data_key': 'data10', 'rule_key': 'rule19',
  329. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_316')
  330. },
  331. '319': {
  332. 'data_key': 'data10', 'rule_key': 'rule19',
  333. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_319')
  334. },
  335. '322': {
  336. 'data_key': 'data10', 'rule_key': 'rule7',
  337. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_322')
  338. },
  339. '323': {
  340. 'data_key': 'data10', 'rule_key': 'rule7',
  341. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_323')
  342. },
  343. '326': {
  344. 'data_key': 'data10', 'rule_key': 'rule7',
  345. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_326')
  346. },
  347. '327': {
  348. 'data_key': 'data10', 'rule_key': 'rule7',
  349. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_327')
  350. },
  351. '328': {
  352. 'data_key': 'data10', 'rule_key': 'rule7',
  353. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_328')
  354. },
  355. '332': {
  356. 'data_key': 'data10', 'rule_key': 'rule7',
  357. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_332')
  358. },
  359. '333': {
  360. 'data_key': 'data10', 'rule_key': 'rule7',
  361. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_333')
  362. },
  363. '334': {
  364. 'data_key': 'data10', 'rule_key': 'rule7',
  365. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_334')
  366. },
  367. '335': {
  368. 'data_key': 'data10', 'rule_key': 'rule7',
  369. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_335')
  370. },
  371. '336': {
  372. 'data_key': 'data10', 'rule_key': 'rule7',
  373. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_336')
  374. },
  375. '337': {
  376. 'data_key': 'data10', 'rule_key': 'rule7',
  377. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_337')
  378. },
  379. '338': {
  380. 'data_key': 'data10', 'rule_key': 'rule7',
  381. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_338')
  382. },
  383. '339': {
  384. 'data_key': 'data10', 'rule_key': 'rule7',
  385. 'ab_code': AB_CODE['region_rank_by_h'].get('abtest_339')
  386. }
  387. }
  388. # APP ab实验配置
  389. APP_AB_CODE = {
  390. # 首页推荐
  391. '10003': {
  392. '110156': {
  393. 'data_key': 'data7', 'rule_key': 'rule8',
  394. 'ab_code': AB_CODE['region_rank_by_h'].get('app_abtest_110156')
  395. }, # 票圈视频APP 分数据实验 data-[vlog: 0.5, 票圈视频APP: 0.5], rule-rule8
  396. },
  397. # 相关推荐
  398. '10037': {},
  399. }
  400. # 默认全量配置
  401. INITIAL_CONFIG = {
  402. APP_TYPE['VLOG']: '095', # vlog
  403. APP_TYPE['LOVE_LIVE']: '144', # 票圈视频
  404. APP_TYPE['LONG_VIDEO']: '121', # 内容精选
  405. APP_TYPE['LAO_HAO_KAN_VIDEO']: '074', # 老好看视频
  406. APP_TYPE['ZUI_JING_QI']: '069', # 最惊奇
  407. 'other': '095-1', # 其他端默认配置
  408. }
  409. # 小程序小时级列表key不同实验标识
  410. RULE_KEY = {
  411. 'initial': '',
  412. 'rule_rank1': 'rule1',
  413. 'rule_rank2': 'rule2',
  414. 'rule_rank3': 'rule3',
  415. 'rule_rank4': 'rule4',
  416. 'rule_rank5': 'rule5',
  417. 'rule_rank6': 'rule6',
  418. }
  419. # 小程序地域分组小时级列表key不同实验标识
  420. DATA_KEY_REGION = {
  421. 'initial': '',
  422. 'region_rule_rank3': 'data1'
  423. }
  424. # 小时级规则更新过去24h数据列表key不同实验标识
  425. RULE_KEY_24H = {
  426. 'initial': '',
  427. '24h_rule_rank1': 'rule1',
  428. '24h_rule_rank2': 'rule2',
  429. }
  430. # pushFrom
  431. PUSH_FROM = {
  432. 'rov_recall': 'recall_pool', # rov召回池
  433. 'flow_recall': 'flow_pool', # 流量池
  434. 'top': 'op_manual', # 置顶
  435. 'bottom': 'bottom_strategy', # 一层兜底
  436. 'bottom_last': 'bottom_strategy_last', # 二层兜底
  437. 'bottom2': 'bottom_strategy2', # 兜底策略2
  438. 'position_insert': 'position_insert', # 按位置插入
  439. 'relevant_video_op': 'relevant_video_op', # 相关推荐强插
  440. 'rov_recall_h': 'recall_pool_h', # 小时级更新列表
  441. 'rov_recall_24h': 'recall_pool_24h', # 小时级更新相对24h列表
  442. 'rov_recall_day': 'recall_pool_day', # 天级规则更新列表
  443. 'old_video': 'old_video_recall', # 老视频
  444. 'rov_recall_region_h': 'recall_pool_region_h', # 地域分组小时级更新列表
  445. 'rov_recall_region_day': 'recall_pool_region_day', # 地域分组天级更新列表
  446. 'rov_recall_region_24h': 'recall_pool_region_24h', # 地域分组小时级更新24h列表
  447. 'rov_recall_24h_dup': 'rov_recall_24h_dup', # 小时级更新24h筛选后剩余数据列表
  448. 'rov_recall_48h': 'recall_pool_48h', # 小时级更新相对48h列表
  449. 'rov_recall_48h_dup': 'rov_recall_48h_dup', # 小时级更新48h筛选后剩余数据列表
  450. 'top_video_relevant_appType_19': 'relevant_video', # 相似视频
  451. 'whole_movies': 'whole_movies', # 完整影视
  452. 'talk_videos': 'talk_videos', # 影视解说
  453. 'special_mid': 'special_mid_videos', # 特殊mid指定视频
  454. 'rov_recall_30day': 'recall_pool_30day', # 天级更新相对30天列表
  455. 'sim_hot_vid_recall': 'sim_hot_vid_recall', # 相似视频召回
  456. 'fast_flow_recall': 'fast_flow_recall', #快速流量池召回
  457. 'normal_flow_recall': 'normal_flow_recall', # 普通流量池召回
  458. 'hot_3_day_recall': 'hot_3_day_recall', # 3天召回
  459. 'hot_recall': 'hot_recall', # hot召回
  460. 'w2v_recall': 'w2v_recall', #word2vec
  461. 'u2i_tag_recall':'u2i_tag_recall', #u2i_tag_recall
  462. 'u2u2i_recall':'u2u2i_recall', #u2u2i_recall
  463. }
  464. # category id mapping
  465. CATEGORY = {
  466. 'recommend': [55], # 推荐
  467. 'other': [] # 其他类别
  468. }
  469. # 前k个从ROV召回池中获取视频
  470. K = 3
  471. # 从流量池获取视频的概率设置
  472. P = 0.3
  473. P_18_19 = 1
  474. # 小程序离线ROV模型结果存放 redis key前缀,完整格式:recall:item:score:rov:applet:{date}
  475. RECALL_KEY_NAME_PREFIX = 'recall:item:score:rov:applet:'
  476. # # 小程序小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.h.{rule_key}.{date}.{h}
  477. # RECALL_KEY_NAME_PREFIX_BY_H = 'com.weiqu.video.recall.item.score.h.'
  478. # # 小程序相对24h数据更新结果与 小程序小时级更新结果 去重后 存放 redis key前缀,
  479. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.24h.h.{rule_key}.{date}.{h}
  480. # RECALL_KEY_NAME_PREFIX_DUP_24H_H = 'com.weiqu.video.recall.hot.item.score.dup.24h.h.'
  481. # # 小程序离线ROV模型结果与小程序小时级更新结果去重后 存放 redis key前缀,
  482. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.h.{rule_key}{date}.{h}
  483. # RECALL_KEY_NAME_PREFIX_DUP_H = 'com.weiqu.video.recall.hot.item.score.dup.h.'
  484. # # 每个mid存储对应小时级更新结果 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.h.mid.{appType}.{mid}
  485. # H_WITH_MID_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.h.mid.'
  486. # # 记录 mid-小时级key 中数据所属(date,h),完整格式:com.weiqu.video.h.record.mid.{appType}.{mid}
  487. # H_WITH_MID_RECORD_KEY_NAME_PREFIX = 'com.weiqu.video.h.record.mid.'
  488. #
  489. # # 每个mid存储对应小时级更新结果 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.h.24h.mid.{appType}.{mid}
  490. # H_WITH_MID_RECALL_KEY_NAME_PREFIX_24H = 'com.weiqu.video.recall.hot.item.score.h.24h.mid.'
  491. # # 记录 mid-小时级key 中数据所属(date,h),完整格式:com.weiqu.video.h.24h.record.mid.{appType}.{mid}
  492. # H_WITH_MID_RECORD_KEY_NAME_PREFIX_24H = 'com.weiqu.video.h.24h.record.mid.'
  493. #
  494. # # 每个mid存储对应小时级更新结果 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.h.region.24h.mid.{appType}.{mid}
  495. # H_WITH_MID_RECALL_KEY_NAME_PREFIX_REGION_24H = 'com.weiqu.video.recall.hot.item.score.h.region.24h.mid.'
  496. # # 记录 mid-小时级key 中数据所属(date,h),完整格式:com.weiqu.video.h.region.24h.record.mid.{appType}.{mid}
  497. # H_WITH_MID_RECORD_KEY_NAME_PREFIX_REGION_24H = 'com.weiqu.video.h.region.24h.record.mid.'
  498. # 用户上一次在 相对30天 天级更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:30day:{appType}:{mid}
  499. LAST_VIDEO_FROM_30DAY_PREFIX = 'recall:last:item:30day:'
  500. # 记录 mid-上一次在 地域分组小时级 更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:30day:{appType}:{mid}
  501. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_30DAY = 'recall:last:record:30day:'
  502. # 用户上一次在 地域分组小时级 更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:h:{appType}:{mid}
  503. LAST_VIDEO_FROM_REGION_H_PREFIX = 'recall:last:item:region:h:'
  504. # 记录 mid-上一次在 地域分组小时级 更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:h:{appType}:{mid}
  505. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_H = 'recall:last:record:region:h:'
  506. # 用户上一次在dup1 分地域24h更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:dup1:24h:{appType}:{mid}
  507. LAST_VIDEO_FROM_REGION_DUP1_24H_PREFIX = 'recall:last:item:region:dup1:24h:'
  508. # 记录 mid-上一次在dup1 分地域24h更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:dup1:24h:{appType}:{mid}
  509. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_DUP1_24H = 'recall:last:record:region:dup1:24h:'
  510. # 用户上一次在dup2 24h更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:dup2:24h:{appType}:{mid}
  511. LAST_VIDEO_FROM_REGION_DUP2_24H_PREFIX = 'recall:last:item:region:dup2:24h:'
  512. # 记录 mid-上一次在dup2 24h更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:dup2:24h:{appType}:{mid}
  513. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_DUP2_24H = 'recall:last:record:region:dup2:24h:'
  514. # 用户上一次在dup3 24h更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:dup3:24h:{appType}:{mid}
  515. LAST_VIDEO_FROM_REGION_DUP3_24H_PREFIX = 'recall:last:item:region:dup3:24h:'
  516. # 记录 mid-上一次在dup3 24h更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:dup2:24h:{appType}:{mid}
  517. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_DUP3_24H = 'recall:last:record:region:dup3:24h:'
  518. # 用户上一次在dup2 48h更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:dup2:48h:{appType}:{mid}
  519. LAST_VIDEO_FROM_REGION_DUP2_48H_PREFIX = 'recall:last:item:region:dup2:48h:'
  520. # 记录 mid-上一次在dup2 48h更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:dup2:48h:{appType}:{mid}
  521. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_DUP2_48H = 'recall:last:record:region:dup2:48h:'
  522. # 用户上一次在dup3 48h更新列表中对应的位置 redis key前缀,完整key格式:recall:last:item:region:dup3:48h:{appType}:{mid}
  523. LAST_VIDEO_FROM_REGION_DUP3_48H_PREFIX = 'recall:last:item:region:dup3:48h:'
  524. # 记录 mid-上一次在dup3 48h更新列表中对应的位置key 中数据所属(date,h),完整格式:recall:last:record:region:dup2:48h:{appType}:{mid}
  525. RECORD_KEY_NAME_PREFIX_LAST_VIDEO_REGION_DUP3_48H = 'recall:last:record:region:dup3:48h:'
  526. # # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.{rule_key}
  527. # H_VIDEO_FILER = 'com.weiqu.video.filter.h.item.'
  528. # # 小程序天级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.day.{rule_key}.{date}
  529. # RECALL_KEY_NAME_PREFIX_BY_DAY = 'com.weiqu.video.recall.item.score.day.'
  530. # # 小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  531. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.now.{rule_key}.{date}
  532. # RECALL_KEY_NAME_PREFIX_DUP_DAY_NOW = 'com.weiqu.video.recall.hot.item.score.dup.day.now.'
  533. # # 使用前一天小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  534. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.pre.{rule_key}.{date}
  535. # RECALL_KEY_NAME_PREFIX_DUP_DAY_PRE = 'com.weiqu.video.recall.hot.item.score.dup.day.pre.'
  536. # # 小程序小时级24h数据更新结果存放 redis key前缀,
  537. # # 完整格式:com.weiqu.video.recall.item.score.apptype.24h.{appType}.{data_key}.{rule_key}.{date}.{h}
  538. # RECALL_KEY_NAME_PREFIX_BY_24H = 'com.weiqu.video.recall.item.score.apptype.24h.'
  539. # # 小程序离线ROV模型结果与小程序小时级24h更新结果去重后 存放 redis key前缀,
  540. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.24h.{rule_key}.{date}.{h}
  541. # RECALL_KEY_NAME_PREFIX_DUP_24H = 'com.weiqu.video.recall.hot.item.score.dup.24h.'
  542. # # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.apptype.h.item.24h.{appType}.{data_key}.{rule_key}
  543. # H_VIDEO_FILER_24H = 'com.weiqu.video.filter.apptype.h.item.24h.'
  544. # 小程序相对30天数据天级更新结果存放 redis key前缀,
  545. # 完整格式:recall:item:score:30day:{data_key}:{rule_key}:{date}
  546. RECALL_KEY_NAME_PREFIX_30DAY = 'recall:item:score:30day:'
  547. # 小程序地域分组小时级更新结果存放 redis key前缀,
  548. # 完整格式:recall:item:score:region:h:{region}:{data_key}:{rule_key}:{date}:{h}
  549. RECALL_KEY_NAME_PREFIX_REGION_BY_H = 'recall:item:score:region:h:'
  550. # 小程序地域分组天级更新结果与小程序地域分组小时级更新结果去重后 存放 redis key前缀,
  551. # 完整格式:com.weiqu.video.recall.hot.item.score.dup1.region.day.h.{region}.{rule_key}.{date}.{h}
  552. # RECALL_KEY_NAME_PREFIX_DUP1_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup1.region.day.h.'
  553. # 小程序地域分组小时级更新24h结果与小程序地域分组小时级更新结果去重后 存放 redis key前缀,
  554. # 完整格式:recall:item:score:region:dup1:region24h:{region}:{data_key}:{rule_key}:{date}:{h}
  555. RECALL_KEY_NAME_PREFIX_DUP1_REGION_24H_H = 'recall:item:score:region:dup1:region24h:'
  556. # 小程序天级更新结果与 小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  557. # 完整格式:com.weiqu.video.recall.hot.item.score.dup2.region.day.h.{region}.{rule_key}.{date}.{h}
  558. # RECALL_KEY_NAME_PREFIX_DUP2_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup2.region.day.h.'
  559. # 小程序24h更新结果与 小程序地域分组24h更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  560. # 完整格式:recall:item:score:region:dup2:24h:{region}:{data_key}:{rule_key}:{date}:{h}
  561. RECALL_KEY_NAME_PREFIX_DUP2_REGION_24H_H = 'recall:item:score:region:dup2:24h:'
  562. # 小程序小时级24h数据 筛选后的剩余数据 更新结果 与 小程序24h更新结果/小程序地域分组24h更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  563. # 完整格式:recall:item:score:region:dup3:24h:{region}:{data_key}:{rule_key}:{date}:{h}
  564. RECALL_KEY_NAME_PREFIX_DUP3_REGION_24H_H = 'recall:item:score:region:dup3:24h:'
  565. # 小程序48h更新结果与 小程序地域分组24h更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  566. # 完整格式:recall:item:score:region:dup2:48h:{region}:{data_key}:{rule_key}:{date}:{h}
  567. RECALL_KEY_NAME_PREFIX_DUP2_REGION_48H_H = 'recall:item:score:region:dup2:48h:'
  568. # 小程序小时级48h数据 筛选后的剩余数据 更新结果 与 小程序48h更新结果/小程序地域分组24h更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  569. # 完整格式:recall:item:score:region:dup3:48h:{region}:{data_key}:{rule_key}:{date}:{h}
  570. RECALL_KEY_NAME_PREFIX_DUP3_REGION_48H_H = 'recall:item:score:region:dup3:48h:'
  571. # 小程序离线ROV模型结果与 小程序天级更新结果/小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  572. # 完整格式:recall:item:score:region:dup4:rov:{region}:{data_key}:{rule_key}:{date}:{h}
  573. RECALL_KEY_NAME_PREFIX_DUP_REGION_H = 'recall:item:score:region:dup4:rov:'
  574. # 地域分组小时级视频状态不符合推荐要求的列表 redis key,
  575. # 完整格式:com.weiqu.video.filter.apptype.region.h.item.{region}.{appType}.{data_key}.{rule_key}
  576. # REGION_H_VIDEO_FILER = 'com.weiqu.video.filter.apptype.region.h.item.'
  577. # # 小程序地域分组小时级更新24h结果存放 redis key前缀,
  578. # # 完整格式:com.weiqu.video.recall.item.score.apptype.region.24h.{region}.{appType}.{data_key}.{rule_key}.{date}.{h}
  579. # RECALL_KEY_NAME_PREFIX_REGION_BY_24H = 'com.weiqu.video.recall.item.score.apptype.region.24h.'
  580. # # 小程序天级更新结果与 小程序地域分组小时级更新24h结果 去重后 存放 redis key前缀,
  581. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.day.24h.{region}.{rule_key}.{date}.{h}
  582. # RECALL_KEY_NAME_PREFIX_DUP_REGION_DAY_24H = 'com.weiqu.video.recall.hot.item.score.dup.region.day.24h.'
  583. # # 小程序离线ROV模型结果与 小程序天级更新结果/小程序地域分组小时级更新24h结果 去重后 存放 redis key前缀,
  584. # # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.24h.{region}.{rule_key}.{date}.{h}
  585. # RECALL_KEY_NAME_PREFIX_DUP_REGION_24H = 'com.weiqu.video.recall.hot.item.score.dup.region.24h.'
  586. # # 地域分组小时级更新24h视频状态不符合推荐要求的列表 redis key,
  587. # # 完整格式:com.weiqu.video.filter.apptype.region.h.item.24h.{region}.{appType}.{data_key}.{rule_key}
  588. # REGION_H_VIDEO_FILER_24H = 'com.weiqu.video.filter.apptype.region.h.item.24h.'
  589. # app应用 小程序离线ROV模型结果存放 redis key前缀,完整格式:recall:item:score:rov:app:{date}
  590. RECALL_KEY_NAME_PREFIX_APP = 'recall:item:score:rov:app:'
  591. # # app应用 小时级数据更新最终结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}.{h}
  592. # APP_FINAL_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.app.'
  593. # appType:[18, 19]小程序离线ROV模型结果存放 redis key前缀,完整格式:recall:item:score:{appType}:{date}:{h}
  594. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'recall:item:score:'
  595. # # 小程序老视频更新结果存放 redis key 前缀,完整格式:'com.weiqu.video.recall.old.item.{date}'
  596. # RECALL_KEY_NAME_PREFIX_OLD_VIDEOS = 'com.weiqu.video.recall.old.item.'
  597. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.6.{h}
  598. # RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.6.'
  599. # 流量池离线模型结果存放 redis key前缀,完整格式 flow:pool:item:score:{appType}
  600. FLOWPOOL_KEY_NAME_PREFIX = 'flow:pool:item:score:'
  601. # 快速曝光流量池数据存放 redis key前缀,完整格式 flow:pool:quick:item:score:{appType}:{flowPool_id}
  602. QUICK_FLOWPOOL_KEY_NAME_PREFIX = 'flow:pool:quick:item:score:'
  603. # 快速曝光流量池分发概率 redis key前缀,完整格式 flow:pool:quick:distribute:rate:{flowPool_id}
  604. QUICK_FLOWPOOL_DISTRIBUTE_RATE_KEY_NAME_PREFIX = 'flow:pool:quick:distribute:rate:'
  605. # 修改ROV的视频 redis key
  606. UPDATE_ROV_KEY_NAME = 'update:rov:item:score:applet'
  607. UPDATE_ROV_KEY_NAME_APP = 'update:rov:item:score:app'
  608. # 首页推荐预曝光列表redis key 前缀,完整key格式:previewed:videos:{appType}:{mid}
  609. PREVIEW_KEY_PREFIX = 'previewed:videos:'
  610. # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:recall:pool:last:rov:{appType}:{mid}:{date}
  611. LAST_VIDEO_FROM_ROV_POOL_PREFIX = 'recall:last:rov:'
  612. # # 用户上一次在天级规则更新列表中对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.{appType}.{mid}.{date}
  613. # LAST_VIDEO_FROM_RULE_DAY_POOL_PREFIX = 'com.weiqu.video.rule.day.pool.last.'
  614. # # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.pre.{appType}.{mid}.{date}
  615. # LAST_VIDEO_FROM_ROV_POOL_PRE_PREFIX = 'com.weiqu.video.rov.pool.last.pre.'
  616. # # 用户上一次在rov召回池对应的位置 redis key前缀,完整key格式:com.weiqu.video.rov.pool.last.now.{appType}.{mid}.{date}
  617. # LAST_VIDEO_FROM_ROV_POOL_NOW_PREFIX = 'com.weiqu.video.rov.pool.last.now.'
  618. # # 用户上一次在region dup更新列表中对应的位置 redis key前缀,完整key格式:com.weiqu.video.region.dup.last.{dup}.{appType}.{mid}.{date}
  619. # LAST_VIDEO_FROM_REGION_DUP_PREFIX = 'com.weiqu.video.region.dup.last.'
  620. # # 用户上一次在完整影视资源列表对应的位置 redis key前缀,完整key格式:com.weiqu.video.whole.movies.last.{appType}.{mid}.{date}
  621. # LAST_VIDEO_FROM_WHOLE_MOVIES_PREFIX = 'com.weiqu.video.whole.movies.last.'
  622. # 用户上一次在特殊视频列表对应的位置 redis key前缀,完整key格式:recall:pool:last:special:{appType}:{mid}:{date}
  623. LAST_VIDEO_FROM_SPECIAL_POOL_PREFIX = 'recall:last:special:'
  624. # 本地记录视频的可分发数,控制分发,完整key格式:flow:pool:local:distribute:count:{videoId}:{flowPool}
  625. LOCAL_DISTRIBUTE_COUNT_PREFIX = 'flow:pool:local:distribute:count:'
  626. # 从ROV召回池获取视频的最大频次,限制每次请求的获取次数
  627. MAX_FREQ_FROM_ROV_POOL = 2
  628. # 从流量池获取视频的最大频次,限制每次请求的获取次数
  629. MAX_FREQ_FROM_FLOW_POOL = 1
  630. # 从流量池获取视频的最大频次,限制每次请求的获取次数 appType:[18, 19]
  631. MAX_FREQ_FROM_FLOW_POOL_18_19 = 3
  632. # 兜底视频redis存储key
  633. BOTTOM_KEY_NAME = 'bottom:videos'
  634. # 兜底视频redis存储key-方案2:采用流量池视频作为兜底视频
  635. BOTTOM2_KEY_NAME = 'bottom2:videos'
  636. # 生效中的置顶视频列表 redis key
  637. TOP_VIDEO_LIST_KEY_NAME = 'top:item:score:area:applet'
  638. TOP_VIDEO_LIST_KEY_NAME_APP = 'top:item:score:area:app'
  639. # # 按位置排序redis存储key
  640. # RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  641. # RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  642. # # rov召回池更新时间
  643. # ROV_UPDATE_H = 6
  644. # ROV_UPDATE_MINUTE = 30
  645. #
  646. # # 小时级召回池更新时间 每个小时的15分更新成功
  647. # ROV_H_UPDATE_MINUTE = 25
  648. #
  649. # # 地域分组小时级召回池更新时间
  650. # REGION_H_UPDATE_MINUTE = 30
  651. #
  652. # # 天级规则更新列表更新时间 00:30更新成功
  653. # ROV_DAY_UPDATE_MINUTE = 0
  654. # 置顶视频区域 为 全部 的code
  655. ALL_AREA_CODE = '000000'
  656. # # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  657. # W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  658. # 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  659. # 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  660. # }
  661. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  662. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  663. # 最惊奇电影类视频相关推荐列表存放 redis key前缀,完整格式: com.weiqu.movie.relevant.list.item.{videoId}
  664. MOVIE_RELEVANT_LIST_KEY_NAME_PREFIX = 'com.weiqu.movie.relevant.list.item.'
  665. # 完整影视资源更新结果存放 redis key 前缀,完整格式:'com.weiqu.video.recall.whole.movies.item.{date}.{h}'
  666. RECALL_KEY_NAME_PREFIX_WHOLE_MOVIES = 'com.weiqu.video.recall.whole.movies.item.'
  667. # 特殊mid更新结果存放 redis key ,完整格式:'special:mid'
  668. KEY_NAME_SPECIAL_MID = 'special:mid'
  669. # 特殊mid对应指定视频列表更新结果存放 redis key 前缀,完整格式:'special:videos:item:{date}'
  670. KEY_NAME_PREFIX_SPECIAL_VIDEOS = 'special:videos:item:'
  671. # 限流视频集合存放 redis key前缀,完整格式:'limit:videos:{date}'
  672. KEY_NAME_PREFIX_LIMIT_VIDEO_SET = 'limit:videos:'
  673. # 限流视频分发数记录 redis key前缀,完整格式:'limit:video:distribute:count:{videoId}'
  674. KEY_NAME_PREFIX_LIMIT_VIDEO_DISTRIBUTE_COUNT = 'limit:video:distribute:count:'
  675. # 用户近30天是否有回流状态 存放 redis key 前缀,完整格式:'user:has30day:return:{mid}'
  676. KEY_NAME_PREFIX_USER_HAS30DAY_RETURN = 'user:has30day:return:'
  677. # 宗教用户列表更新结果存放 redis key 前缀
  678. KEY_NAME_PREFIX_RELIGION_USER = {
  679. # 天主教,完整格式:'religion:catholicism:users:item:{hash_tag}:{date}'
  680. 'catholicism': 'religion:catholicism:users:item:',
  681. # 基督教,完整格式:'religion:christianity:users:item:{hash_tag}:{date}'
  682. 'christianity': 'religion:christianity:users:item:',
  683. }
  684. # 视频数据表类型 - 管理后台算法视频列表可视化
  685. VIDEO_DATA_LIST_MAPPING = {
  686. 0: {
  687. "dataListDesc": "全部", "dataListCode": 0,
  688. "keyPrefixList": [
  689. {"dataListCode": 1, "keyPrefix": RECALL_KEY_NAME_PREFIX_30DAY},
  690. {"dataListCode": 2, "keyPrefix": RECALL_KEY_NAME_PREFIX_REGION_BY_H},
  691. {"dataListCode": 3, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP1_REGION_24H_H},
  692. {"dataListCode": 4, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP2_REGION_24H_H},
  693. {"dataListCode": 5, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP3_REGION_24H_H},
  694. # {"dataListCode": 5, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP2_REGION_48H_H},
  695. # {"dataListCode": 6, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP3_REGION_48H_H},
  696. # {"dataListCode": 7, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP_REGION_H},
  697. ]
  698. },
  699. 1: {"dataListDesc": "相对30天数据列表", "dataListCode": 1, "keyPrefix": RECALL_KEY_NAME_PREFIX_30DAY},
  700. 2: {"dataListDesc": "地域小时级", "dataListCode": 2, "keyPrefix": RECALL_KEY_NAME_PREFIX_REGION_BY_H},
  701. 3: {"dataListDesc": "地域相对24小时级", "dataListCode": 3, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP1_REGION_24H_H},
  702. 4: {"dataListDesc": "非地域相对24小时级", "dataListCode": 4, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP2_REGION_24H_H},
  703. 5: {"dataListDesc": "非地域相对24小时级列表2", "dataListCode": 5, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP3_REGION_24H_H},
  704. # 5: {"dataListDesc": "非地域相对48小时级", "dataListCode": 5, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP2_REGION_48H_H},
  705. # 6: {"dataListDesc": "非地域相对48小时级列表2", "dataListCode": 6, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP3_REGION_48H_H},
  706. # 7: {"dataListDesc": "大列表", "dataListCode": 7, "keyPrefix": RECALL_KEY_NAME_PREFIX_DUP_REGION_H},
  707. }
  708. # 调用后端接口过滤参数配置 1-已观看 2-视频状态 3-是否进入老年人社区 4-话题状态 5-推荐状态 6-白名单过滤 7-涉政视频过滤
  709. FILTER_VIEWED_TYPES_CONFIG = {
  710. APP_TYPE['VLOG']: (1, 6,), # vlog
  711. APP_TYPE['LOVE_LIVE']: (1, 6,), # 票圈视频
  712. APP_TYPE['APP']: (1,), # 票圈视频APP
  713. 'other': (1, 6, 7,), # 其他
  714. }
  715. # 召回池分发视频在流量池中存在,该视频是否进行本地分发数-1 开关,1-开/0-关
  716. IN_FLOW_POOL_COUNT_SWITCH_KEY_NAME = 'recall:videos:in:flow:pool:count:switch'
  717. # 流量池videoId redis key前缀,完整格式 flow:pool:video:ids:{appType}
  718. FLOWPOOL_VIDEO_ID_KEY_NAME_PREFIX = 'flow:pool:video:ids:'
  719. # 快速曝光流量池videoId redis key前缀,完整格式 flow:pool:quick:video:ids:{appType}:{flowPool_id}
  720. QUICK_FLOWPOOL_VIDEO_ID_KEY_NAME_PREFIX = 'flow:pool:quick:video:ids:'
  721. # 流量池视频标记flowPool redis key前缀,完整格式 flow:pool:video:{appType}:{videoId}
  722. FLOWPOOL_VIDEO_INFO_KEY_NAME_PREFIX = 'flow:pool:video:'
  723. # 快速曝光流量池视频标记flowPool redis key前缀,完整格式 flow:pool:quick:video:{appType}:{flowPool_id}:{videoId}
  724. QUICK_FLOWPOOL_VIDEO_INFO_KEY_NAME_PREFIX = 'flow:pool:quick:video:'
  725. # 免广告用户组列表
  726. NO_AD_MID_GROUP_LIST = {
  727. 'class1': ['return25_nmids'],
  728. 'class2': ['return30_nmids'],
  729. }
  730. # 广告模型abtest配置
  731. AD_ABTEST_CONFIG = {
  732. # 票圈vlog
  733. '173-a': {
  734. 'video': {'data': 'data1'},
  735. 'user': {'data': 'user0', 'rule': 'rule1'},
  736. 'group_class_key': 'class1',
  737. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  738. },
  739. '173-b': {
  740. 'video': {'data': 'data1'},
  741. 'user': {'data': 'user0', 'rule': 'rule2'},
  742. 'group_class_key': 'class1',
  743. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  744. }, # 调整未分组用户的阈值(去除不出广告的用户组)
  745. '173-c': {
  746. 'video': {'data': 'data1'},
  747. 'user': {'data': 'user0', 'rule': 'rule3'},
  748. 'group_class_key': 'class2',
  749. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class2']
  750. }, # 细化分组 return25_29, return30+, 且return30+ 不出广告
  751. '173-d': {
  752. 'video': {'data': 'data1:7days'},
  753. 'user': {'data': 'user0', 'rule': 'rule1'},
  754. 'group_class_key': 'class1',
  755. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  756. }, # 视频使用7天内有曝光的
  757. '173-e': {
  758. 'video': {'data': 'data1'},
  759. 'user': {'data': 'user0', 'rule': 'rule2'},
  760. 'group_class_key': 'class1',
  761. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  762. 'care_model_status_param': 2,
  763. 'care_model_ab_mid_group': 'mean_group',
  764. }, # 开启关怀模式人群多出广告
  765. '173-f': {
  766. 'video': {'data': 'data1'},
  767. 'user': {'data': 'user0', 'rule': 'rule2'},
  768. 'group_class_key': 'class1',
  769. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  770. 'care_model_status_param': 1,
  771. 'care_model_ab_mid_group': 'mean_group',
  772. }, # 未开启关怀模式人群多出广告
  773. '173-g': {
  774. 'video': {'data': 'data1:7days'},
  775. 'user': {'data': 'user0', 'rule': 'rule2'},
  776. 'group_class_key': 'class1',
  777. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  778. }, # 调整未分组用户的阈值(去除不出广告的用户组) + 视频使用7天内有曝光的
  779. '173-h': {
  780. 'video': {'data': 'data1'},
  781. 'user': {'data': 'user0', 'rule': 'rule2'},
  782. 'group_class_key': 'class1',
  783. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  784. }, # else人群多出广告,阈值比例参数:0.8
  785. '173-i': {
  786. 'video': {'data': 'data1'},
  787. 'user': {'data': 'user0', 'rule': 'rule2'},
  788. 'group_class_key': 'class1',
  789. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  790. }, # else人群多出广告,阈值比例参数:0.9
  791. '173-j': {
  792. 'video': {'data': 'videos0'},
  793. 'user': {'data': 'user0', 'rule': 'rule2'},
  794. 'group_class_key': 'class1',
  795. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  796. 'care_model_status_param': 1,
  797. 'care_model_ab_mid_group': 'mean_group',
  798. }, # 未开启关怀模式人群多出广告 + 所有广告类型数据
  799. '173-k': {
  800. 'video': {'data': 'videos0:adtype1'},
  801. 'user': {'data': 'user0', 'rule': 'rule2'},
  802. 'group_class_key': 'class1',
  803. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  804. 'care_model_status_param': 1,
  805. 'care_model_ab_mid_group': 'mean_group',
  806. }, # 未开启关怀模式人群多出广告 + 模板插屏类型广告视频数据
  807. # 票圈视频+
  808. '190-a': {
  809. 'video': {'data': 'data1'},
  810. 'user': {'data': 'user0', 'rule': 'rule1'},
  811. 'group_class_key': 'class1',
  812. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  813. },
  814. '190-b': {
  815. 'video': {'data': 'data1'},
  816. 'user': {'data': 'user0', 'rule': 'rule2'},
  817. 'group_class_key': 'class1',
  818. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  819. },
  820. '190-c': {
  821. 'video': {'data': 'data21'},
  822. 'user': {'data': 'user21', 'rule': 'rule1'},
  823. 'group_class_key': 'class1',
  824. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  825. },
  826. '190-d': {
  827. 'video': {'data': 'data21'},
  828. 'user': {'data': 'user21', 'rule': 'rule2'},
  829. 'group_class_key': 'class1',
  830. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  831. },
  832. '190-e': {
  833. 'video': {'data': 'videos21'},
  834. 'user': {'data': 'user21', 'rule': 'rule2'},
  835. 'group_class_key': 'class1',
  836. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  837. }, # 所有广告类型本端视频数据 + 优化1
  838. # 票圈视频
  839. '194-a': {
  840. 'video': {'data': 'data1'},
  841. 'user': {'data': 'user0', 'rule': 'rule1'},
  842. 'group_class_key': 'class1',
  843. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  844. },
  845. '194-b': {
  846. 'video': {'data': 'data1'},
  847. 'user': {'data': 'user0', 'rule': 'rule2'},
  848. 'group_class_key': 'class1',
  849. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  850. }, # 调整未分组用户的阈值(去除不出广告的用户组)
  851. '194-c': {
  852. 'video': {'data': 'data2'},
  853. 'user': {'data': 'user4', 'rule': 'rule1'},
  854. 'group_class_key': 'class1',
  855. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  856. }, # 本端数据
  857. '194-d': {
  858. 'video': {'data': 'data2'},
  859. 'user': {'data': 'user4', 'rule': 'rule2'},
  860. 'group_class_key': 'class1',
  861. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  862. }, # 本端数据 + 优化1
  863. '194-e': {
  864. 'video': {'data': 'videos4'},
  865. 'user': {'data': 'user4', 'rule': 'rule2'},
  866. 'group_class_key': 'class1',
  867. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  868. }, # 所有广告类型本端数据 + 优化1
  869. '194-f': {
  870. 'video': {'data': 'videos4:adtype1'},
  871. 'user': {'data': 'user4', 'rule': 'rule2'},
  872. 'group_class_key': 'class1',
  873. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  874. }, # 模板插屏广告视频本端数据 + 优化1
  875. # 内容精选
  876. '195-a': {
  877. 'video': {'data': 'data1'},
  878. 'user': {'data': 'user0', 'rule': 'rule1'},
  879. 'group_class_key': 'class1',
  880. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  881. },
  882. '195-b': {
  883. 'video': {'data': 'data1'},
  884. 'user': {'data': 'user0', 'rule': 'rule2'},
  885. 'group_class_key': 'class1',
  886. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  887. }, # 调整未分组用户的阈值(去除不出广告的用户组)
  888. '195-c': {
  889. 'video': {'data': 'data3'},
  890. 'user': {'data': 'user5', 'rule': 'rule1'},
  891. 'group_class_key': 'class1',
  892. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  893. }, # 本端数据
  894. '195-d': {
  895. 'video': {'data': 'data3'},
  896. 'user': {'data': 'user5', 'rule': 'rule2'},
  897. 'group_class_key': 'class1',
  898. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  899. }, # 本端数据 + 优化1
  900. '195-e': {
  901. 'video': {'data': 'videos5'},
  902. 'user': {'data': 'user5', 'rule': 'rule2'},
  903. 'group_class_key': 'class1',
  904. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  905. }, # 所有广告类型本端数据 + 优化1
  906. '195-f': {
  907. 'video': {'data': 'videos5'},
  908. 'user': {'data': 'user5', 'rule': 'rule2'},
  909. 'group_class_key': 'class1',
  910. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  911. 'care_model_status_param': 1,
  912. 'care_model_ab_mid_group': 'mean_group',
  913. }, # 所有广告类型本端数据 + 优化1 + else非关怀模式人群多出广告
  914. # 票圈短视频
  915. '196-a': {
  916. 'video': {'data': 'data1'},
  917. 'user': {'data': 'user0', 'rule': 'rule1'},
  918. 'group_class_key': 'class1',
  919. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  920. },
  921. '196-b': {
  922. 'video': {'data': 'data4'},
  923. 'user': {'data': 'user6', 'rule': 'rule1'},
  924. 'group_class_key': 'class1',
  925. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  926. },
  927. '196-c': {
  928. 'video': {'data': 'data4'},
  929. 'user': {'data': 'user6', 'rule': 'rule3'},
  930. 'group_class_key': 'class2',
  931. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class2']
  932. }, # 本端数据 + 优化1 + 优化2
  933. '196-d': {
  934. 'video': {'data': 'data4:7days'},
  935. 'user': {'data': 'user6', 'rule': 'rule3'},
  936. 'group_class_key': 'class2',
  937. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class2']
  938. }, # 本端数据 + 优化1 + 优化2 + 优化4
  939. '196-e': {
  940. 'video': {'data': 'videos6'},
  941. 'user': {'data': 'user6', 'rule': 'rule1'},
  942. 'group_class_key': 'class1',
  943. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  944. }, # 所有广告类型本端数据
  945. # 老好看视频
  946. '197-a': {
  947. 'video': {'data': 'data1'},
  948. 'user': {'data': 'user0', 'rule': 'rule1'},
  949. 'group_class_key': 'class1',
  950. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  951. },
  952. '197-b': {
  953. 'video': {'data': 'data1'},
  954. 'user': {'data': 'user0', 'rule': 'rule2'},
  955. 'group_class_key': 'class1',
  956. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  957. }, # 优化1 调整未分组用户的阈值(去除不出广告的用户组)
  958. '197-c': {
  959. 'video': {'data': 'data5'},
  960. 'user': {'data': 'user18', 'rule': 'rule2'},
  961. 'group_class_key': 'class1',
  962. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  963. }, # 本端数据 + 优化1
  964. '197-d': {
  965. 'video': {'data': 'data5:7days'},
  966. 'user': {'data': 'user18', 'rule': 'rule2'},
  967. 'group_class_key': 'class1',
  968. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  969. }, # 本端数据 + 优化1 + 优化4
  970. '197-e': {
  971. 'video': {'data': 'videos18'},
  972. 'user': {'data': 'user18', 'rule': 'rule2'},
  973. 'group_class_key': 'class1',
  974. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  975. }, # 所有广告类型本端数据 + 优化阈值计算方式
  976. # 票圈最惊奇
  977. '198-a': {
  978. 'video': {'data': 'data1'},
  979. 'user': {'data': 'user0', 'rule': 'rule1'},
  980. 'group_class_key': 'class1',
  981. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  982. },
  983. '198-b': {
  984. 'video': {'data': 'data6'},
  985. 'user': {'data': 'user19', 'rule': 'rule1'},
  986. 'group_class_key': 'class1',
  987. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  988. }, # 本端数据
  989. '198-c': {
  990. 'video': {'data': 'data1'},
  991. 'user': {'data': 'user0', 'rule': 'rule2'},
  992. 'group_class_key': 'class1',
  993. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  994. }, # 优化1
  995. '198-d': {
  996. 'video': {'data': 'data6'},
  997. 'user': {'data': 'user19', 'rule': 'rule2'},
  998. 'group_class_key': 'class1',
  999. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1000. }, # 本端数据 + 优化1
  1001. '198-e': {
  1002. 'video': {'data': 'videos19'},
  1003. 'user': {'data': 'user19', 'rule': 'rule2'},
  1004. 'group_class_key': 'class1',
  1005. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1006. }, # 所有广告类型本端数据 + 优化阈值计算方式
  1007. # 票圈足迹
  1008. '242-a': {
  1009. 'video': {'data': 'data1'},
  1010. 'user': {'data': 'user0', 'rule': 'rule1'},
  1011. 'group_class_key': 'class1',
  1012. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1013. }, # vlog数据
  1014. '242-b': {
  1015. 'video': {'data': 'data1'},
  1016. 'user': {'data': 'user0', 'rule': 'rule2'},
  1017. 'group_class_key': 'class1',
  1018. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1019. }, # vlog数据 + 优化1
  1020. '242-c': {
  1021. 'video': {'data': 'videos22'},
  1022. 'user': {'data': 'user22', 'rule': 'rule2'},
  1023. 'group_class_key': 'class1',
  1024. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1025. }, # 所有广告类型本端数据 + 优化阈值计算方式
  1026. # 票圈福年
  1027. '243-a': {
  1028. 'video': {'data': 'data1'},
  1029. 'user': {'data': 'user0', 'rule': 'rule1'},
  1030. 'group_class_key': 'class1',
  1031. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1032. }, # vlog数据
  1033. '243-b': {
  1034. 'video': {'data': 'data1'},
  1035. 'user': {'data': 'user0', 'rule': 'rule2'},
  1036. 'group_class_key': 'class1',
  1037. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1038. }, # vlog数据 + 优化1
  1039. '243-c': {
  1040. 'video': {'data': 'videos3'},
  1041. 'user': {'data': 'user3', 'rule': 'rule1'},
  1042. 'group_class_key': 'class1',
  1043. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1']
  1044. }, # 所有广告类型本端数据
  1045. # 票圈|信仰之路
  1046. '324-a': {
  1047. 'video': {'data': 'videos0'},
  1048. 'user': {'data': 'user0', 'rule': 'rule2'},
  1049. 'group_class_key': 'class1',
  1050. 'no_ad_mid_group_list': NO_AD_MID_GROUP_LIST['class1'],
  1051. 'care_model_status_param': 1,
  1052. 'care_model_ab_mid_group': 'mean_group',
  1053. }, # vlog数据 + 未开启关怀模式人群多出广告 + 所有广告类型数据
  1054. }
  1055. # 用户组有广告时的分享率预测结果存放 redis key 前缀,完整格式:ad:users:group:predict:share:rate:{user_data_key}:{date}
  1056. KEY_NAME_PREFIX_AD_GROUP = 'ad:users:group:predict:share:rate:'
  1057. # 视频有广告时的分享率预测结果存放 redis key 前缀,完整格式:ad:video:predict:share:rate:{video_data_key}:{date}
  1058. KEY_NAME_PREFIX_AD_VIDEO = 'ad:video:predict:share:rate:'
  1059. # 用户分组结果存放 redis key 前缀,完整格式:mid:group:{class_key}:{mid}
  1060. KEY_NAME_PREFIX_MID_GROUP = 'mid:group:'
  1061. # 广告推荐阈值结果存放 redis key 前缀,完整格式:ad:threshold:{abtestId}:{abtestConfigTag}:{abtestGroup}:{group}
  1062. KEY_NAME_PREFIX_AD_THRESHOLD = 'ad:threshold:'
  1063. # 广告推荐关怀模式实验阈值结果存放 redis key 前缀,完整格式:ad:threshold:care:{abtestId}:{abtestConfigTag}:{abtestGroup}:{group}
  1064. KEY_NAME_PREFIX_AD_THRESHOLD_CARE_MODEL = 'ad:threshold:care:'
  1065. class DevelopmentConfig(BaseConfig):
  1066. """开发环境配置"""
  1067. # 报警内容 环境区分
  1068. ENV_TEXT = "开发环境"
  1069. # 测试环境redis地址
  1070. REDIS_INFO = {
  1071. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  1072. 'port': 6379,
  1073. 'password': 'Wqsd@2019',
  1074. }
  1075. # Hologres连接参数,本地使用
  1076. HOLOGRES_INFO = {
  1077. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  1078. 'port': 80,
  1079. 'dbname': 'dssm',
  1080. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  1081. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  1082. }
  1083. # 测试环境mysql地址
  1084. MYSQL_INFO = {
  1085. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  1086. 'port': 3306,
  1087. 'user': 'wx2016_longvideo',
  1088. 'password': 'wx2016_longvideoP@assword1234',
  1089. 'db': 'longvideo',
  1090. 'charset': 'utf8'
  1091. }
  1092. # Hologres视频状态存储表名
  1093. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  1094. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  1095. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  1096. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  1097. # 获取视频在流量池中的剩余可分发数接口地址
  1098. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  1099. # 获取用户近30天是否有回流接口地址
  1100. GET_USER_30DayReturnCnt_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/user/has30DayReturnCnt?mid='
  1101. # 日志服务配置
  1102. ALIYUN_LOG = {
  1103. 'ENDPOINT': 'cn-hangzhou-intranet.log.aliyuncs.com',
  1104. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  1105. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  1106. 'PROJECT': 'rov-server-test',
  1107. }
  1108. # 快速曝光流量池ID
  1109. QUICK_FLOW_POOL_ID = 3
  1110. class TestConfig(BaseConfig):
  1111. """测试环境配置"""
  1112. # 报警内容 环境区分
  1113. ENV_TEXT = "测试环境"
  1114. # 测试环境redis地址
  1115. REDIS_INFO = {
  1116. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  1117. 'port': 6379,
  1118. 'password': 'Wqsd@2019',
  1119. }
  1120. # Hologres连接参数,服务器使用
  1121. HOLOGRES_INFO = {
  1122. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  1123. 'port': 80,
  1124. 'dbname': 'dssm',
  1125. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  1126. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  1127. }
  1128. # 测试环境mysql地址
  1129. MYSQL_INFO = {
  1130. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  1131. 'port': 3306,
  1132. 'user': 'wx2016_longvideo',
  1133. 'password': 'wx2016_longvideoP@assword1234',
  1134. 'db': 'longvideo',
  1135. 'charset': 'utf8'
  1136. }
  1137. # Hologres视频状态存储表名
  1138. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  1139. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  1140. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  1141. VIDEO_FILTER_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/filterVideos'
  1142. # 获取视频在流量池中的剩余可分发数接口地址
  1143. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  1144. # 获取用户近30天是否有回流接口地址
  1145. GET_USER_30DayReturnCnt_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/user/has30DayReturnCnt?mid='
  1146. # 日志服务配置
  1147. ALIYUN_LOG = {
  1148. 'ENDPOINT': 'cn-hangzhou-intranet.log.aliyuncs.com',
  1149. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  1150. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  1151. 'PROJECT': 'rov-server-test',
  1152. }
  1153. # 快速曝光流量池ID
  1154. QUICK_FLOW_POOL_ID = 3
  1155. class PreProductionConfig(BaseConfig):
  1156. """预发布环境配置"""
  1157. # 报警内容 环境区分
  1158. ENV_TEXT = "预发布环境"
  1159. # 线上环境redis地址
  1160. REDIS_INFO = {
  1161. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  1162. 'port': 6379,
  1163. 'password': 'Wqsd@2019',
  1164. }
  1165. # Hologres连接参数,服务器使用
  1166. HOLOGRES_INFO = {
  1167. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  1168. 'port': 80,
  1169. 'dbname': 'dssm',
  1170. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  1171. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  1172. }
  1173. # 生产环境mysql地址
  1174. MYSQL_INFO = {
  1175. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  1176. 'port': 3306,
  1177. 'user': 'wx2016_longvideo',
  1178. 'password': 'wx2016_longvideoP@assword1234',
  1179. 'db': 'longvideo',
  1180. 'charset': 'utf8'
  1181. }
  1182. # Hologres视频状态存储表名
  1183. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  1184. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  1185. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  1186. VIDEO_FILTER_URL = 'http://prespeed-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  1187. # 获取视频在流量池中的剩余可分发数接口地址
  1188. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  1189. # 获取用户近30天是否有回流接口地址
  1190. GET_USER_30DayReturnCnt_URL = 'http://videopre-internal.piaoquantv.com/longvideoapi/openapi/user/has30DayReturnCnt?mid='
  1191. # 日志服务配置
  1192. ALIYUN_LOG = {
  1193. 'ENDPOINT': 'cn-hangzhou-intranet.log.aliyuncs.com',
  1194. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  1195. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  1196. 'PROJECT': 'rov-server',
  1197. }
  1198. # 快速曝光流量池ID
  1199. QUICK_FLOW_POOL_ID = 3
  1200. class ProductionConfig(BaseConfig):
  1201. """生产环境配置"""
  1202. # 报警内容 环境区分
  1203. ENV_TEXT = "生产环境"
  1204. # 线上环境redis地址
  1205. REDIS_INFO = {
  1206. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  1207. 'port': 6379,
  1208. 'password': 'Wqsd@2019',
  1209. }
  1210. # Hologres连接参数,服务器使用
  1211. HOLOGRES_INFO = {
  1212. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  1213. 'port': 80,
  1214. 'dbname': 'dssm',
  1215. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  1216. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  1217. }
  1218. # 生产环境mysql地址
  1219. MYSQL_INFO = {
  1220. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  1221. 'port': 3306,
  1222. 'user': 'wx2016_longvideo',
  1223. 'password': 'wx2016_longvideoP@assword1234',
  1224. 'db': 'longvideo',
  1225. 'charset': 'utf8'
  1226. }
  1227. # Hologres视频状态存储表名
  1228. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  1229. # 用户已观看视频过滤 & 视频审核条件过滤 & 是否进入老年人社区过滤 & 话题状态过滤 接口地址
  1230. # 参数types: 1-已观看 2-视频状态 3-是否进入老年人社区过滤 4-话题状态
  1231. VIDEO_FILTER_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/filterVideos'
  1232. # 获取视频在流量池中的剩余可分发数接口地址
  1233. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  1234. # 获取用户近30天是否有回流接口地址
  1235. GET_USER_30DayReturnCnt_URL = 'http://longvideoapi-internal.piaoquantv.com/longvideoapi/openapi/user/has30DayReturnCnt?mid='
  1236. # 日志服务配置
  1237. ALIYUN_LOG = {
  1238. 'ENDPOINT': 'cn-hangzhou-intranet.log.aliyuncs.com',
  1239. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  1240. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  1241. 'PROJECT': 'rov-server',
  1242. }
  1243. # 快速曝光流量池ID
  1244. QUICK_FLOW_POOL_ID = 3
  1245. def set_config():
  1246. # 获取环境变量 ROV_SERVER_ENV
  1247. env = os.environ.get('ROV_SERVER_ENV')
  1248. # env = 'dev'
  1249. if env is None:
  1250. # log_.error('ENV ERROR: is None!')
  1251. return
  1252. if env == 'dev':
  1253. return DevelopmentConfig()
  1254. elif env == 'test':
  1255. return TestConfig()
  1256. elif env == 'pre':
  1257. return PreProductionConfig()
  1258. elif env == 'pro':
  1259. return ProductionConfig()
  1260. else:
  1261. # log_.error('ENV ERROR: is {}'.format(env))
  1262. return