config.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  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. # app_type: [18, 19]预测表名
  64. PREDICT_PROJECT_18_19 = {
  65. '18': '',
  66. '19': ''
  67. }
  68. PREDICT_TABLE_18_19 = {
  69. '18': '',
  70. '19': ''
  71. }
  72. # 预测数据文件存放路径
  73. PREDICT_DATA_FILENAME_18_19 = {
  74. '18': 'predict_data_18.pickle',
  75. '19': 'predict_data_19.pickle'
  76. }
  77. # 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  78. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  79. # 小程序小时级更新结果存放 redis key前缀,完整格式:com.weiqu.video.recall.item.score.h.{return_count}.{date}.{h}
  80. RECALL_KEY_NAME_PREFIX_BY_H = 'com.weiqu.video.recall.item.score.h.'
  81. # 小程序离线ROV模型结果与小程序小时级更新结果去重后 存放 redis key前缀,
  82. # 完整格式:com.weiqu.video.recall.hot.item.score.dup.h.{return_count}{date}.{h}
  83. RECALL_KEY_NAME_PREFIX_DUP_H = 'com.weiqu.video.recall.hot.item.score.dup.h.'
  84. # 小时级视频状态不符合推荐要求的列表 redis key,完整格式:com.weiqu.video.filter.h.item.{return_count}
  85. H_VIDEO_FILER = 'com.weiqu.video.filter.h.item.'
  86. # app应用 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}
  87. RECALL_KEY_NAME_PREFIX_APP = 'com.weiqu.video.recall.hot.item.score.app.'
  88. # app应用 运营提供的小时级数据存放 redis key前缀,完整格式:com.weiqu.video.app.op.item.score.{date}.{h}
  89. APP_OP_VIDEOS_KEY_NAME_PREFIX = 'com.weiqu.video.app.op.item.score.'
  90. # app应用 小时级数据更新最终结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.app.{date}.{h}
  91. APP_FINAL_RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.app.'
  92. # appType:[18, 19]小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{appType}.{date}.{h}
  93. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.item.score.'
  94. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.{appType}.{h}
  95. # RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.'
  96. # 流量池离线模型结果存放 redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  97. FLOWPOOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  98. # 兜底视频redis存储key
  99. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  100. # 兜底视频数量
  101. BOTTOM_NUM = 1000
  102. # 首页兜底视频json存储 redis-key
  103. BOTTOM_JSON_KEY_NAME = 'com.weiqu.video.homepage.bottom.info.json.item'
  104. # 修改ROV的视频 redis key
  105. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  106. UPDATE_ROV_KEY_NAME_APP = 'com.weiqu.video.update.rov.item.score.app'
  107. # 生效中的置顶视频列表 redis key
  108. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  109. TOP_VIDEO_LIST_KEY_NAME_APP = 'com.weiqu.video.top.item.score.area.app'
  110. # rovScore公差
  111. ROV_SCORE_D = 0.001
  112. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  113. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  114. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  115. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  116. }
  117. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  118. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  119. # 有设置运营强插相关视频的头部视频id redis存储key
  120. RELEVANT_TOP_VIDEOS_KEY_NAME = 'com.weiqu.video.relevant.top.video_ids'
  121. # 按位置排序redis存储key
  122. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  123. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  124. class DevelopmentConfig(BaseConfig):
  125. """开发环境配置"""
  126. # 报警内容 环境区分
  127. ENV_TEXT = "开发环境"
  128. # 项目存放目录
  129. PROJECT_PATH = '/data2/rov-offline'
  130. # 测试环境redis地址
  131. REDIS_INFO = {
  132. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  133. 'port': 6379,
  134. 'password': 'Wqsd@2019',
  135. }
  136. # Hologres连接参数,本地使用
  137. HOLOGRES_INFO = {
  138. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  139. 'port': 80,
  140. 'dbname': 'dssm',
  141. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  142. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  143. }
  144. # 测试环境mysql地址
  145. MYSQL_INFO = {
  146. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  147. 'port': 3306,
  148. 'user': 'wx2016_longvideo',
  149. 'password': 'wx2016_longvideoP@assword1234',
  150. 'db': 'longvideo',
  151. 'charset': 'utf8'
  152. }
  153. # 测试环境 过滤用mysql地址
  154. FILTER_MYSQL_INFO = {
  155. 'host': 'am-bp1g3ys9u00u483uc131930.ads.aliyuncs.com',
  156. 'port': 3306,
  157. 'user': 'lv_manager',
  158. 'password': 'lv_manager@2020',
  159. 'db': 'longvideo',
  160. 'charset': 'utf8'
  161. }
  162. # Hologres视频状态存储表名
  163. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  164. # 从流量池获取视频接口地址
  165. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  166. # 获取视频在流量池中的剩余可分发数接口地址
  167. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  168. # 计算完ROV通知后端接口地址
  169. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  170. # 获取置顶视频列表接口地址
  171. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  172. # 获取首页兜底视频json接口地址
  173. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  174. # logs 上传oss 目标Bucket指定目录
  175. OSS_FOLDER_LOGS = 'rov-offline/dev/logs/'
  176. # data 上传oss 目标Bucket指定目录
  177. OSS_FOLDER_DATA = 'rov-offline/dev/data/'
  178. class TestConfig(BaseConfig):
  179. """测试环境配置"""
  180. # 报警内容 环境区分
  181. ENV_TEXT = "测试环境"
  182. # 项目存放目录
  183. PROJECT_PATH = '/data2/rov-offline'
  184. # 测试环境redis地址
  185. REDIS_INFO = {
  186. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  187. 'port': 6379,
  188. 'password': 'Wqsd@2019',
  189. }
  190. # Hologres连接参数,服务器使用
  191. HOLOGRES_INFO = {
  192. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  193. 'port': 80,
  194. 'dbname': 'dssm',
  195. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  196. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  197. }
  198. # 测试环境mysql地址
  199. MYSQL_INFO = {
  200. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  201. 'port': 3306,
  202. 'user': 'wx2016_longvideo',
  203. 'password': 'wx2016_longvideoP@assword1234',
  204. 'db': 'longvideo',
  205. 'charset': 'utf8'
  206. }
  207. # 测试环境 过滤用mysql地址
  208. FILTER_MYSQL_INFO = {
  209. 'host': 'am-bp1g3ys9u00u483uc131930.ads.aliyuncs.com',
  210. 'port': 3306,
  211. 'user': 'lv_manager',
  212. 'password': 'lv_manager@2020',
  213. 'db': 'longvideo',
  214. 'charset': 'utf8'
  215. }
  216. # Hologres视频状态存储表名
  217. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  218. # 从流量池获取视频接口地址
  219. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  220. # 获取视频在流量池中的剩余可分发数接口地址
  221. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  222. # 计算完ROV通知后端接口地址
  223. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  224. # 获取置顶视频列表接口地址
  225. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  226. # 获取首页兜底视频json接口地址
  227. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  228. # logs 上传oss 目标Bucket指定目录
  229. OSS_FOLDER_LOGS = 'rov-offline/test/logs/'
  230. # data 上传oss 目标Bucket指定目录
  231. OSS_FOLDER_DATA = 'rov-offline/test/data/'
  232. class PreProductionConfig(BaseConfig):
  233. """预发布环境配置"""
  234. # 报警内容 环境区分
  235. ENV_TEXT = "预发布环境"
  236. # 项目存放目录
  237. PROJECT_PATH = '/data/rov-offline'
  238. # redis地址
  239. REDIS_INFO = {
  240. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  241. 'port': 6379,
  242. 'password': 'Wqsd@2019',
  243. }
  244. # Hologres连接参数,服务器使用
  245. HOLOGRES_INFO = {
  246. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  247. 'port': 80,
  248. 'dbname': 'dssm',
  249. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  250. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  251. }
  252. # 生产环境mysql地址
  253. MYSQL_INFO = {
  254. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  255. 'port': 3306,
  256. 'user': 'wx2016_longvideo',
  257. 'password': 'wx2016_longvideoP@assword1234',
  258. 'db': 'longvideo',
  259. 'charset': 'utf8'
  260. }
  261. # 生产环境 过滤用mysql地址
  262. FILTER_MYSQL_INFO = {
  263. 'host': 'am-bp15tqt957i3b3sgi131950.ads.aliyuncs.com',
  264. 'port': 3306,
  265. 'user': 'lv_manager',
  266. 'password': 'lv_manager@2020',
  267. 'db': 'longvideo',
  268. 'charset': 'utf8'
  269. }
  270. # Hologres视频状态存储表名
  271. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  272. # 从流量池获取视频接口地址
  273. GET_VIDEOS_FROM_POOL_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  274. # 获取视频在流量池中的剩余可分发数接口地址
  275. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  276. # 计算完ROV通知后端接口地址
  277. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videopre-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  278. # 获取置顶视频列表接口地址
  279. TOP_VIDEO_LIST_URL = 'http://speedpre.wx.com/longvideoapi/openapi/recommend/topVideoList'
  280. # 获取首页兜底视频json接口地址
  281. BOTTOM_JSON_URL = 'http://speedpre.wx.com/longvideoapi/openapi/video/distribute/structure/video/list'
  282. # logs 上传oss 目标Bucket指定目录
  283. OSS_FOLDER_LOGS = 'rov-offline/pre/logs/'
  284. # data 上传oss 目标Bucket指定目录
  285. OSS_FOLDER_DATA = 'rov-offline/pre/data/'
  286. class ProductionConfig(BaseConfig):
  287. """生产环境配置"""
  288. # 报警内容 环境区分
  289. ENV_TEXT = "生产环境"
  290. # 项目存放目录
  291. PROJECT_PATH = '/data/rov-offline'
  292. # 线上环境redis地址
  293. REDIS_INFO = {
  294. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  295. 'port': 6379,
  296. 'password': 'Wqsd@2019',
  297. }
  298. # Hologres连接参数,服务器使用
  299. HOLOGRES_INFO = {
  300. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  301. 'port': 80,
  302. 'dbname': 'dssm',
  303. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  304. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  305. }
  306. # 生产环境mysql地址
  307. MYSQL_INFO = {
  308. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  309. 'port': 3306,
  310. 'user': 'wx2016_longvideo',
  311. 'password': 'wx2016_longvideoP@assword1234',
  312. 'db': 'longvideo',
  313. 'charset': 'utf8'
  314. }
  315. # 生产环境 过滤用mysql地址
  316. FILTER_MYSQL_INFO = {
  317. 'host': 'am-bp15tqt957i3b3sgi131950.ads.aliyuncs.com',
  318. 'port': 3306,
  319. 'user': 'lv_manager',
  320. 'password': 'lv_manager@2020',
  321. 'db': 'longvideo',
  322. 'charset': 'utf8'
  323. }
  324. # Hologres视频状态存储表名
  325. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  326. # 从流量池获取视频接口地址
  327. GET_VIDEOS_FROM_POOL_URL = 'http://api-internal.piaoquantv.com/flowpool/video/getAllVideo'
  328. # 获取视频在流量池中的剩余可分发数接口地址
  329. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  330. # 计算完ROV通知后端接口地址
  331. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  332. # 获取置顶视频列表接口地址
  333. TOP_VIDEO_LIST_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/topVideoList'
  334. # 获取首页兜底视频json接口地址
  335. BOTTOM_JSON_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/video/distribute/structure/video/list'
  336. # logs 上传oss 目标Bucket指定目录
  337. OSS_FOLDER_LOGS = 'rov-offline/pro/logs/'
  338. # data 上传oss 目标Bucket指定目录
  339. OSS_FOLDER_DATA = 'rov-offline/pro/data/'
  340. def set_config():
  341. # 获取环境变量 ROV_OFFLINE_ENV
  342. env = os.environ.get('ROV_OFFLINE_ENV')
  343. # env = 'dev'
  344. if env is None:
  345. log_.error('ENV ERROR: is None!')
  346. return
  347. if env == 'dev':
  348. return DevelopmentConfig(), env
  349. elif env == 'test':
  350. return TestConfig(), env
  351. elif env == 'pre':
  352. return PreProductionConfig(), env
  353. elif env == 'pro':
  354. return ProductionConfig(), env
  355. else:
  356. log_.error('ENV ERROR: is {}'.format(env))
  357. return