config.py 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576
  1. # coding:utf-8
  2. import os
  3. # from log import Log
  4. # log_ = Log()
  5. class BaseConfig(object):
  6. # 产品标识
  7. APP_TYPE = {
  8. 'VLOG': 0, # vlog
  9. 'LOVE_LIVE': 4, # 票圈视频
  10. 'LONG_VIDEO': 5, # 内容精选
  11. 'SHORT_VIDEO': 6, # 票圈短视频
  12. 'WAN_NENG_VIDEO': 17, # 万能影视屋
  13. 'LAO_HAO_KAN_VIDEO': 18, # 老好看视频
  14. 'ZUI_JING_QI': 19, # 票圈最惊奇
  15. 'APP': 13, # 票圈视频APP
  16. }
  17. # 数据存放路径
  18. DATA_DIR_PATH = './data'
  19. # oss 目标Bucket
  20. BUCKET_NAME = 'ali-recommend'
  21. # ODPS服务配置
  22. ODPS_CONFIG = {
  23. 'ENDPOINT': 'http://service.cn.maxcompute.aliyun.com/api',
  24. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  25. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  26. }
  27. # 飞书机器人配置
  28. FEISHU_ROBOT = {
  29. 'server_robot': {
  30. # webhook地址
  31. 'webhook': 'https://open.feishu.cn/open-apis/bot/v2/hook/8de4de35-30ed-4692-8854-7a154e89b2f2',
  32. # 自定义关键词key_word
  33. 'key_word': '服务报警'
  34. },
  35. 'feature_monitor_robot': {
  36. 'webhook': 'https://open.feishu.cn/open-apis/bot/v2/hook/0ca66b89-5e2b-4e89-a04a-a01fda31cc89',
  37. 'key_word': 'ROV特征监控'
  38. }
  39. }
  40. # 训练数据截止时间距当前日期间隔天数
  41. TRAIN_DIFF = 7
  42. # 训练数据所需数据范围天数
  43. TRAIN_DELTA_DAYS = 30
  44. # 训练数据表名
  45. TRAIN_PROJECT = 'usercdm'
  46. TRAIN_TABLE = 'rov_feature_add_v1'
  47. # 训练数据文件存放路径
  48. TRAIN_DATA_FILENAME = 'train_data.pickle'
  49. # 预测数据截止时间距当前日期间隔天数
  50. PREDICT_DIFF = 1
  51. # 预测数据所需数据范围天数
  52. PREDICT_DELTA_DAYS = 1
  53. # 预测数据表名
  54. PREDICT_PROJECT = 'usercdm'
  55. PREDICT_TABLE = 'rov_predict_table_add_v1'
  56. # 预测数据文件存放路径
  57. PREDICT_DATA_FILENAME = 'predict_data.pickle'
  58. # 模型存放文件
  59. MODEL_FILENAME = 'model.pickle'
  60. # 运营给定App小时级更新数据表名
  61. APP_OP_PROJECT = 'loghubods'
  62. APP_OP_TABLE = 'category_video_list_test1'
  63. # 小程序小时级规则参数
  64. RULE_PARAMS = {
  65. 'rule1': {'return_count': 20, 'score_rule': 0.005, 'platform_return_rate': 0.001},
  66. # 'rule2': {'return_count': 20, 'score_rule': 0.001}, # 下线
  67. 'rule3': {'view_type': 'pre-view', 'return_count': 20, 'score_rule': 0.005, 'platform_return_rate': 0.001},
  68. # 'rule4': {'cal_score_func': 2, 'return_count': 20, 'score_rule': 0}, # 下线
  69. # 'rule5': {'cal_score_func': 3, 'return_count': 20, 'score_rule': 0}, # 下线
  70. 'rule6': {'view_type': 'video-show', 'return_count': 20, 'score_rule': 0.005, 'platform_return_rate': 0.001},
  71. }
  72. # app_type: [18, 19]预测表名
  73. PREDICT_PROJECT_18_19 = {
  74. '18': 'loghubods', # 老好看
  75. '19': 'loghubods', # 最惊奇
  76. }
  77. PREDICT_TABLE_18_19 = {
  78. '18': 'haokan_video_list_each_hour_update', # 老好看
  79. '19': 'amazed_video_list_each_hour_update', # 最惊奇
  80. }
  81. # 预测数据文件存放路径
  82. PREDICT_DATA_FILENAME_18_19 = {
  83. '18': 'predict_data_18.pickle',
  84. '19': 'predict_data_19.pickle'
  85. }
  86. # 天级规则更新使用数据
  87. PROJECT_DAY = 'loghubods'
  88. TABLE_DAY = 'video_data_each_day_dataset'
  89. # 小程序天级规则参数
  90. RULE_PARAMS_DAY = {
  91. # 'rule1': {'return_count': 200},
  92. 'rule2': {'cal_score_func': 2, 'return_count': 100, 'platform_return_rate': 0.001},
  93. }
  94. # 小时级更新过去24h数据
  95. PROJECT_24H = 'loghubods'
  96. TABLE_24H = 'video_data_each_hour_dataset_24h_total'
  97. # 小时级更新过去24h数据规则参数
  98. RULE_PARAMS_24H = {
  99. 'rule1': {'cal_score_func': 2, 'return_count': 100, 'platform_return_rate': 0.001},
  100. 'rule2': {'cal_score_func': 2, 'return_count': 100, 'platform_return_rate': 0.001, 'view_type': 'preview'},
  101. }
  102. # 地域分组小时级规则更新使用数据
  103. PROJECT_REGION = 'loghubods'
  104. TABLE_REGION = 'video_each_hour_update_province'
  105. # 地域分组小时级规则参数
  106. RULE_PARAMS_REGION = {
  107. 'rule1': {'view_type': 'pre-view', 'platform_return_rate': 0.001, 'region_24h_rule_key': 'rule1'},
  108. 'rule2': {'view_type': 'video-show', 'platform_return_rate': 0.001, 'region_24h_rule_key': 'rule2'},
  109. }
  110. # 地域分组天级规则更新使用数据
  111. PROJECT_REGION_DAY = 'loghubods'
  112. TABLE_REGION_DAY = 'video_each_day_update_province'
  113. # 地域分组天级规则参数
  114. RULE_PARAMS_REGION_DAY = {
  115. 'rule1': {'view_type': 'pre-view', 'return_count': 21, 'score_rule': 0},
  116. }
  117. # 地域分组小时级更新24h使用数据
  118. PROJECT_REGION_24H = 'loghubods'
  119. TABLE_REGION_24H = 'video_each_day_update_province_24h_total'
  120. # 地域分组小时级更新24h规则参数
  121. RULE_PARAMS_REGION_24H = {
  122. 'rule1': {'view_type': 'pre-view', 'return_count': 21, 'score_rule': 0, 'platform_return_rate': 0.001},
  123. 'rule2': {'view_type': 'video-show', 'return_count': 21, 'score_rule': 0, 'platform_return_rate': 0.001},
  124. }
  125. # 老视频更新使用数据
  126. OLD_VIDEOS_PROJECT = 'loghubods'
  127. OLD_VIDEOS_TABLE = 'xcx_test_video'
  128. # 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  129. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  130. # 小程序小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.h.{rule_key}.{date}.{h}
  131. RECALL_KEY_NAME_PREFIX_BY_H = 'com.weiqu.video.recall.item.score.h.'
  132. # 小程序相对24h数据更新结果与 小程序小时级更新结果 去重后 存放 redis key前缀,
  133. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.24h.h.{rule_key}.{date}.{h}
  134. RECALL_KEY_NAME_PREFIX_DUP_24H_H = 'com.weiqu.video.recall.hot.item.score.dup.24h.h.'
  135. # 小程序离线ROV模型结果与 小程序小时级更新结果/小程序相对24h数据更新结果 去重后 存放 redis key前缀,
  136. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.h.{rule_key}.{date}.{h}
  137. RECALL_KEY_NAME_PREFIX_DUP_H = 'com.weiqu.video.recall.hot.item.score.dup.h.'
  138. # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.{rule_key}
  139. H_VIDEO_FILER = 'com.weiqu.video.filter.h.item.'
  140. # 小程序天级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.day.{rule_key}.{date}
  141. RECALL_KEY_NAME_PREFIX_BY_DAY = 'com.weiqu.video.recall.item.score.day.'
  142. # 小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  143. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.now.{rule_key}.{date}
  144. RECALL_KEY_NAME_PREFIX_DUP_DAY_NOW = 'com.weiqu.video.recall.hot.item.score.dup.day.now.'
  145. # 使用前一天小程序离线ROV模型结果与小程序天级更新结果去重后 存放 redis key前缀,
  146. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.day.pre.{rule_key}.{date}
  147. RECALL_KEY_NAME_PREFIX_DUP_DAY_PRE = 'com.weiqu.video.recall.hot.item.score.dup.day.pre.'
  148. # 小程序小时级24h数据更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.day.{rule_key}.{date}.{h}
  149. RECALL_KEY_NAME_PREFIX_BY_24H = 'com.weiqu.video.recall.item.score.24h.'
  150. # 小程序离线ROV模型结果与小程序小时级24h更新结果去重后 存放 redis key前缀,
  151. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.24h.{rule_key}.{date}.{h}
  152. RECALL_KEY_NAME_PREFIX_DUP_24H = 'com.weiqu.video.recall.hot.item.score.dup.24h.'
  153. # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.24h.{rule_key}
  154. H_VIDEO_FILER_24H = 'com.weiqu.video.filter.h.item.24h.'
  155. # 小程序地域分组小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.region.h.{region}.{rule_key}.{date}.{h}
  156. RECALL_KEY_NAME_PREFIX_REGION_BY_H = 'com.weiqu.video.recall.item.score.region.h.'
  157. # 小程序地域分组天级更新结果与小程序地域分组小时级更新结果去重后 存放 redis key前缀,
  158. # 完整格式:com.weiqu.video.recall.hot.item.score.dup1.region.day.h.{region}.{rule_key}.{date}.{h}
  159. RECALL_KEY_NAME_PREFIX_DUP1_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup1.region.day.h.'
  160. # 小程序地域分组小时级更新24h结果与小程序地域分组小时级更新结果去重后 存放 redis key前缀,
  161. # 完整格式:com.weiqu.video.recall.hot.item.score.dup1.region.24h.h.{region}.{rule_key}.{date}.{h}
  162. RECALL_KEY_NAME_PREFIX_DUP1_REGION_24H_H = 'com.weiqu.video.recall.hot.item.score.dup1.region.24h.h.'
  163. # 小程序天级更新结果与 小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  164. # 完整格式:com.weiqu.video.recall.hot.item.score.dup2.region.day.h.{region}.{rule_key}.{date}.{h}
  165. RECALL_KEY_NAME_PREFIX_DUP2_REGION_DAY_H = 'com.weiqu.video.recall.hot.item.score.dup2.region.day.h.'
  166. # 小程序24h更新结果与 小程序地域分组24h更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  167. # 完整格式:com.weiqu.video.recall.hot.item.score.dup2.region.24h.h.{region}.{rule_key}.{date}.{h}
  168. RECALL_KEY_NAME_PREFIX_DUP2_REGION_24H_H = 'com.weiqu.video.recall.hot.item.score.dup2.region.24h.h.'
  169. # 小程序离线ROV模型结果与 小程序天级更新结果/小程序地域分组天级更新结果/小程序地域分组小时级更新结果 去重后 存放 redis key前缀,
  170. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.h.{region}.{rule_key}.{date}.{h}
  171. RECALL_KEY_NAME_PREFIX_DUP_REGION_H = 'com.weiqu.video.recall.hot.item.score.dup.region.h.'
  172. # 地域分组小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.region.h.item.{region}.{rule_key}
  173. REGION_H_VIDEO_FILER = 'com.weiqu.video.filter.region.h.item.'
  174. # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.24h.{region}.{rule_key}
  175. # H_VIDEO_FILER_24H = 'com.weiqu.video.filter.h.item.24h.'
  176. # 小程序地域分组天级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.region.day.{region}.{rule_key}.{date}
  177. RECALL_KEY_NAME_PREFIX_REGION_BY_DAY = 'com.weiqu.video.recall.item.score.region.day.'
  178. # 小程序地域分组小时级更新24h结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.region.24h.{region}.{rule_key}.{date}.{h}
  179. RECALL_KEY_NAME_PREFIX_REGION_BY_24H = 'com.weiqu.video.recall.item.score.region.24h.'
  180. # 小程序天级更新结果与 小程序地域分组小时级更新24h结果 去重后 存放 redis key前缀,
  181. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.day.24h.{region}.{rule_key}.{date}.{h}
  182. RECALL_KEY_NAME_PREFIX_DUP_REGION_DAY_24H = 'com.weiqu.video.recall.hot.item.score.dup.region.day.24h.'
  183. # 小程序离线ROV模型结果与 小程序天级更新结果/小程序地域分组小时级更新24h结果 去重后 存放 redis key前缀,
  184. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.region.24h.{region}.{rule_key}.{date}.{h}
  185. RECALL_KEY_NAME_PREFIX_DUP_REGION_24H = 'com.weiqu.video.recall.hot.item.score.dup.region.24h.'
  186. # 地域分组小时级更新24h视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.region.h.item.24h.{region}.{rule_key}
  187. REGION_H_VIDEO_FILER_24H = 'com.weiqu.video.filter.region.h.item.24h.'
  188. # 小程序老视频更新结果存放 redis key 前缀,完整格式:'com.weiqu.video.recall.old.item.{date}'
  189. RECALL_KEY_NAME_PREFIX_OLD_VIDEOS = 'com.weiqu.video.recall.old.item.'
  190. # app应用 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}
  191. RECALL_KEY_NAME_PREFIX_APP = 'com.weiqu.video.recall.hot.item.score.app.'
  192. # app应用 运营提供的小时级数据存放 redis key前缀,完整格式:com.weiqu.video.app.op.item.score.{date}.{h}
  193. APP_OP_VIDEOS_KEY_NAME_PREFIX = 'com.weiqu.video.app.op.item.score.'
  194. # app应用 小时级数据更新最终结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}.{h}
  195. APP_FINAL_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.app.'
  196. # appType:[18, 19]小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{appType}.{date}.{h}
  197. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.item.score.'
  198. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.{appType}.{h}
  199. # RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.'
  200. # 流量池离线模型结果存放 redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  201. FLOWPOOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  202. # 兜底视频redis存储key
  203. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  204. # 兜底视频数量
  205. BOTTOM_NUM = 1000
  206. # 首页兜底视频json存储 redis-key
  207. BOTTOM_JSON_KEY_NAME = 'com.weiqu.video.homepage.bottom.info.json.item'
  208. # 修改ROV的视频 redis key
  209. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  210. UPDATE_ROV_KEY_NAME_APP = 'com.weiqu.video.update.rov.item.score.app'
  211. # 生效中的置顶视频列表 redis key
  212. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  213. TOP_VIDEO_LIST_KEY_NAME_APP = 'com.weiqu.video.top.item.score.area.app'
  214. # rovScore公差
  215. ROV_SCORE_D = 0.001
  216. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  217. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  218. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  219. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  220. }
  221. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  222. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  223. # 有设置运营强插相关视频的头部视频id redis存储key
  224. RELEVANT_TOP_VIDEOS_KEY_NAME = 'com.weiqu.video.relevant.top.video_ids'
  225. # 按位置排序redis存储key
  226. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  227. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  228. SIM_N_19 = 4
  229. # 最惊奇电影类视频相关推荐列表存放 redis key前缀,完整格式: com.weiqu.movie.relevant.list.item.{videoId}
  230. MOVIE_RELEVANT_LIST_KEY_NAME_PREFIX = 'com.weiqu.movie.relevant.list.item.'
  231. class DevelopmentConfig(BaseConfig):
  232. """开发环境配置"""
  233. # 报警内容 环境区分
  234. ENV_TEXT = "开发环境"
  235. # 项目存放目录
  236. PROJECT_PATH = '/data2/rov-offline'
  237. # 测试环境redis地址
  238. REDIS_INFO = {
  239. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  240. 'port': 6379,
  241. 'password': 'Wqsd@2019',
  242. }
  243. # Hologres连接参数,本地使用
  244. HOLOGRES_INFO = {
  245. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  246. 'port': 80,
  247. 'dbname': 'dssm',
  248. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  249. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  250. }
  251. # 测试环境mysql地址
  252. MYSQL_INFO = {
  253. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  254. 'port': 3306,
  255. 'user': 'wx2016_longvideo',
  256. 'password': 'wx2016_longvideoP@assword1234',
  257. 'db': 'longvideo',
  258. 'charset': 'utf8'
  259. }
  260. # 测试环境 过滤用mysql地址
  261. FILTER_MYSQL_INFO = {
  262. 'host': 'am-bp1g3ys9u00u483uc131930.ads.aliyuncs.com',
  263. 'port': 3306,
  264. 'user': 'lv_manager',
  265. 'password': 'lv_manager@2020',
  266. 'db': 'longvideo',
  267. 'charset': 'utf8'
  268. }
  269. # 日志服务配置
  270. ALIYUN_LOG = {
  271. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  272. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  273. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  274. 'PROJECT': 'rov-server-test',
  275. }
  276. # Hologres视频状态存储表名
  277. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  278. # 从流量池获取视频接口地址
  279. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  280. # 获取视频在流量池中的剩余可分发数接口地址
  281. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  282. # 计算完ROV通知后端接口地址
  283. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  284. # 获取置顶视频列表接口地址
  285. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  286. # 获取首页兜底视频json接口地址
  287. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  288. # logs 上传oss 目标Bucket指定目录
  289. OSS_FOLDER_LOGS = 'rov-offline/dev/logs/'
  290. # data 上传oss 目标Bucket指定目录
  291. OSS_FOLDER_DATA = 'rov-offline/dev/data/'
  292. class TestConfig(BaseConfig):
  293. """测试环境配置"""
  294. # 报警内容 环境区分
  295. ENV_TEXT = "测试环境"
  296. # 项目存放目录
  297. PROJECT_PATH = '/data2/rov-offline'
  298. # 测试环境redis地址
  299. REDIS_INFO = {
  300. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  301. 'port': 6379,
  302. 'password': 'Wqsd@2019',
  303. }
  304. # Hologres连接参数,服务器使用
  305. HOLOGRES_INFO = {
  306. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  307. 'port': 80,
  308. 'dbname': 'dssm',
  309. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  310. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  311. }
  312. # 测试环境mysql地址
  313. MYSQL_INFO = {
  314. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  315. 'port': 3306,
  316. 'user': 'wx2016_longvideo',
  317. 'password': 'wx2016_longvideoP@assword1234',
  318. 'db': 'longvideo',
  319. 'charset': 'utf8'
  320. }
  321. # 测试环境 过滤用mysql地址
  322. FILTER_MYSQL_INFO = {
  323. 'host': 'am-bp1g3ys9u00u483uc131930.ads.aliyuncs.com',
  324. 'port': 3306,
  325. 'user': 'lv_manager',
  326. 'password': 'lv_manager@2020',
  327. 'db': 'longvideo',
  328. 'charset': 'utf8'
  329. }
  330. # 日志服务配置
  331. ALIYUN_LOG = {
  332. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  333. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  334. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  335. 'PROJECT': 'rov-server-test',
  336. }
  337. # Hologres视频状态存储表名
  338. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  339. # 从流量池获取视频接口地址
  340. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  341. # 获取视频在流量池中的剩余可分发数接口地址
  342. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  343. # 计算完ROV通知后端接口地址
  344. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  345. # 获取置顶视频列表接口地址
  346. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  347. # 获取首页兜底视频json接口地址
  348. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  349. # logs 上传oss 目标Bucket指定目录
  350. OSS_FOLDER_LOGS = 'rov-offline/test/logs/'
  351. # data 上传oss 目标Bucket指定目录
  352. OSS_FOLDER_DATA = 'rov-offline/test/data/'
  353. class PreProductionConfig(BaseConfig):
  354. """预发布环境配置"""
  355. # 报警内容 环境区分
  356. ENV_TEXT = "预发布环境"
  357. # 项目存放目录
  358. PROJECT_PATH = '/data/rov-offline'
  359. # redis地址
  360. REDIS_INFO = {
  361. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  362. 'port': 6379,
  363. 'password': 'Wqsd@2019',
  364. }
  365. # Hologres连接参数,服务器使用
  366. HOLOGRES_INFO = {
  367. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  368. 'port': 80,
  369. 'dbname': 'dssm',
  370. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  371. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  372. }
  373. # 生产环境mysql地址
  374. MYSQL_INFO = {
  375. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  376. 'port': 3306,
  377. 'user': 'wx2016_longvideo',
  378. 'password': 'wx2016_longvideoP@assword1234',
  379. 'db': 'longvideo',
  380. 'charset': 'utf8'
  381. }
  382. # 生产环境 过滤用mysql地址
  383. FILTER_MYSQL_INFO = {
  384. 'host': 'am-bp15tqt957i3b3sgi131950.ads.aliyuncs.com',
  385. 'port': 3306,
  386. 'user': 'lv_manager',
  387. 'password': 'lv_manager@2020',
  388. 'db': 'longvideo',
  389. 'charset': 'utf8'
  390. }
  391. # 日志服务配置
  392. ALIYUN_LOG = {
  393. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  394. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  395. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  396. 'PROJECT': 'rov-server',
  397. }
  398. # Hologres视频状态存储表名
  399. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  400. # 从流量池获取视频接口地址
  401. GET_VIDEOS_FROM_POOL_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  402. # 获取视频在流量池中的剩余可分发数接口地址
  403. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  404. # 计算完ROV通知后端接口地址
  405. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videopre-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  406. # 获取置顶视频列表接口地址
  407. TOP_VIDEO_LIST_URL = 'http://speedpre.wx.com/longvideoapi/openapi/recommend/topVideoList'
  408. # 获取首页兜底视频json接口地址
  409. BOTTOM_JSON_URL = 'http://speedpre.wx.com/longvideoapi/openapi/video/distribute/structure/video/list'
  410. # logs 上传oss 目标Bucket指定目录
  411. OSS_FOLDER_LOGS = 'rov-offline/pre/logs/'
  412. # data 上传oss 目标Bucket指定目录
  413. OSS_FOLDER_DATA = 'rov-offline/pre/data/'
  414. class ProductionConfig(BaseConfig):
  415. """生产环境配置"""
  416. # 报警内容 环境区分
  417. ENV_TEXT = "生产环境"
  418. # 项目存放目录
  419. PROJECT_PATH = '/data/rov-offline'
  420. # 线上环境redis地址
  421. REDIS_INFO = {
  422. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  423. 'port': 6379,
  424. 'password': 'Wqsd@2019',
  425. }
  426. # Hologres连接参数,服务器使用
  427. HOLOGRES_INFO = {
  428. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  429. 'port': 80,
  430. 'dbname': 'dssm',
  431. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  432. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  433. }
  434. # 生产环境mysql地址
  435. MYSQL_INFO = {
  436. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  437. 'port': 3306,
  438. 'user': 'wx2016_longvideo',
  439. 'password': 'wx2016_longvideoP@assword1234',
  440. 'db': 'longvideo',
  441. 'charset': 'utf8'
  442. }
  443. # 生产环境 过滤用mysql地址
  444. FILTER_MYSQL_INFO = {
  445. 'host': 'am-bp15tqt957i3b3sgi131950.ads.aliyuncs.com',
  446. 'port': 3306,
  447. 'user': 'lv_manager',
  448. 'password': 'lv_manager@2020',
  449. 'db': 'longvideo',
  450. 'charset': 'utf8'
  451. }
  452. # 日志服务配置
  453. ALIYUN_LOG = {
  454. 'ENDPOINT': 'cn-hangzhou.log.aliyuncs.com',
  455. 'ACCESSID': 'LTAIWYUujJAm7CbH',
  456. 'ACCESSKEY': 'RfSjdiWwED1sGFlsjXv0DlfTnZTG1P',
  457. 'PROJECT': 'rov-server',
  458. }
  459. # Hologres视频状态存储表名
  460. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  461. # 从流量池获取视频接口地址
  462. GET_VIDEOS_FROM_POOL_URL = 'http://api-internal.piaoquantv.com/flowpool/video/getAllVideo'
  463. # 获取视频在流量池中的剩余可分发数接口地址
  464. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  465. # 计算完ROV通知后端接口地址
  466. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  467. # 获取置顶视频列表接口地址
  468. TOP_VIDEO_LIST_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/topVideoList'
  469. # 获取首页兜底视频json接口地址
  470. BOTTOM_JSON_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/video/distribute/structure/video/list'
  471. # logs 上传oss 目标Bucket指定目录
  472. OSS_FOLDER_LOGS = 'rov-offline/pro/logs/'
  473. # data 上传oss 目标Bucket指定目录
  474. OSS_FOLDER_DATA = 'rov-offline/pro/data/'
  475. def set_config():
  476. # 获取环境变量 ROV_OFFLINE_ENV
  477. env = os.environ.get('ROV_OFFLINE_ENV')
  478. # env = 'dev'
  479. if env is None:
  480. # log_.error('ENV ERROR: is None!')
  481. return
  482. if env == 'dev':
  483. return DevelopmentConfig(), env
  484. elif env == 'test':
  485. return TestConfig(), env
  486. elif env == 'pre':
  487. return PreProductionConfig(), env
  488. elif env == 'pro':
  489. return ProductionConfig(), env
  490. else:
  491. # log_.error('ENV ERROR: is {}'.format(env))
  492. return