config.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  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. }
  16. # 数据存放路径
  17. DATA_DIR_PATH = './data'
  18. # oss 目标Bucket
  19. BUCKET_NAME = 'ali-recommend'
  20. # 训练数据截止时间距当前日期间隔天数
  21. TRAIN_DIFF = 7
  22. # 训练数据所需数据范围天数
  23. TRAIN_DELTA_DAYS = 30
  24. # 训练数据表名
  25. TRAIN_PROJECT = 'usercdm'
  26. TRAIN_TABLE = 'rov_feature_add_v1'
  27. # 训练数据文件存放路径
  28. TRAIN_DATA_FILENAME = 'train_data.pickle'
  29. # 预测数据截止时间距当前日期间隔天数
  30. PREDICT_DIFF = 1
  31. # 预测数据所需数据范围天数
  32. PREDICT_DELTA_DAYS = 1
  33. # 预测数据表名
  34. PREDICT_PROJECT = 'usercdm'
  35. PREDICT_TABLE = 'rov_predict_table_add_v1'
  36. # 预测数据文件存放路径
  37. PREDICT_DATA_FILENAME = 'predict_data.pickle'
  38. # 模型存放文件
  39. MODEL_FILENAME = 'model.pickle'
  40. # 小程序离线ROV模型结果存放 redis key前缀,完整格式:com.weiqu.video.recall.hot.item.score.{date}
  41. RECALL_KEY_NAME_PREFIX = 'com.weiqu.video.recall.hot.item.score.'
  42. # appType = 6, ROV召回池redis key前缀,完整格式:com.weiqu.video.recall.hot.apptype.h.item.score.{appType}.{h}
  43. RECALL_KEY_NAME_PREFIX_APP_TYPE = 'com.weiqu.video.recall.hot.apptype.h.item.score.'
  44. # 流量池离线模型结果存放 redis key前缀,完整格式 com.weiqu.video.flowpool.hot.item.score.{appType}
  45. FLOWPOOL_KEY_NAME_PREFIX = 'com.weiqu.video.flowpool.hot.item.score.'
  46. # 兜底视频redis存储key
  47. BOTTOM_KEY_NAME = 'com.weiqu.video.bottom'
  48. # 兜底视频数量
  49. BOTTOM_NUM = 1000
  50. # 首页兜底视频json存储 redis-key
  51. BOTTOM_JSON_KEY_NAME = 'com.weiqu.video.homepage.bottom.info.json.item'
  52. # 修改ROV的视频 redis key
  53. UPDATE_ROV_KEY_NAME = 'com.weiqu.video.update.rov.item.score'
  54. # 生效中的置顶视频列表 redis key
  55. TOP_VIDEO_LIST_KEY_NAME = 'com.weiqu.video.top.item.score.area'
  56. # rovScore公差
  57. ROV_SCORE_D = 0.001
  58. # width : height > 1 的视频列表 redis key, zset存储,value为videoId,score为w_h_rate
  59. W_H_RATE_UP_1_VIDEO_LIST_KEY_NAME = {
  60. 'rov_recall': 'com.weiqu.video.rov.w.h.rate.1.item', # rov召回池视频
  61. 'bottom_last': 'com.weiqu.video.bottom.last.w.h.rate.1.item' # 二次兜底视频
  62. }
  63. # 头部视频对应运营强插的相关视频 redis 存储 key 前缀, 完整key格式:com.weiqu.video.relevant.videos.item.{videoId}
  64. RELEVANT_VIDEOS_WITH_OP_KEY_NAME = 'com.weiqu.video.relevant.videos.item.'
  65. # 有设置运营强插相关视频的头部视频id redis存储key
  66. RELEVANT_TOP_VIDEOS_KEY_NAME = 'com.weiqu.video.relevant.top.video_ids'
  67. # 按位置排序redis存储key
  68. RECALL_POSITION1_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.1'
  69. RECALL_POSITION2_KEY_NAME = 'com.weiqu.video.recall.hot.apptype.h.item.score.position.2'
  70. class DevelopmentConfig(BaseConfig):
  71. """开发环境配置"""
  72. # 报警内容 环境区分
  73. ENV_TEXT = "开发环境"
  74. # 项目存放目录
  75. PROJECT_PATH = '/data2/rov-offline'
  76. # 测试环境redis地址
  77. REDIS_INFO = {
  78. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  79. 'port': 6379,
  80. 'password': 'Wqsd@2019',
  81. }
  82. # Hologres连接参数,本地使用
  83. HOLOGRES_INFO = {
  84. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou.hologres.aliyuncs.com',
  85. 'port': 80,
  86. 'dbname': 'dssm',
  87. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  88. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  89. }
  90. # 测试环境mysql地址
  91. MYSQL_INFO = {
  92. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  93. 'port': 3306,
  94. 'user': 'wx2016_longvideo',
  95. 'password': 'wx2016_longvideoP@assword1234',
  96. 'db': 'longvideo',
  97. 'charset': 'utf8'
  98. }
  99. # Hologres视频状态存储表名
  100. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  101. # 从流量池获取视频接口地址
  102. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  103. # 获取视频在流量池中的剩余可分发数接口地址
  104. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  105. # 计算完ROV通知后端接口地址
  106. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  107. # 获取置顶视频列表接口地址
  108. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  109. # 获取首页兜底视频json接口地址
  110. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  111. # logs 上传oss 目标Bucket指定目录
  112. OSS_FOLDER_LOGS = 'rov-offline/dev/logs/'
  113. # data 上传oss 目标Bucket指定目录
  114. OSS_FOLDER_DATA = 'rov-offline/dev/data/'
  115. class TestConfig(BaseConfig):
  116. """测试环境配置"""
  117. # 报警内容 环境区分
  118. ENV_TEXT = "测试环境"
  119. # 项目存放目录
  120. PROJECT_PATH = '/data2/rov-offline'
  121. # 测试环境redis地址
  122. REDIS_INFO = {
  123. 'host': 'r-bp1ps6my7lzg8rdhwx682.redis.rds.aliyuncs.com',
  124. 'port': 6379,
  125. 'password': 'Wqsd@2019',
  126. }
  127. # Hologres连接参数,服务器使用
  128. HOLOGRES_INFO = {
  129. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  130. 'port': 80,
  131. 'dbname': 'dssm',
  132. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  133. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  134. }
  135. # 测试环境mysql地址
  136. MYSQL_INFO = {
  137. 'host': 'rm-bp1k5853td1r25g3n690.mysql.rds.aliyuncs.com',
  138. 'port': 3306,
  139. 'user': 'wx2016_longvideo',
  140. 'password': 'wx2016_longvideoP@assword1234',
  141. 'db': 'longvideo',
  142. 'charset': 'utf8'
  143. }
  144. # Hologres视频状态存储表名
  145. VIDEO_STATUS = 'longvideo_test.dwd_mdm_item_video_stat'
  146. # 从流量池获取视频接口地址
  147. GET_VIDEOS_FROM_POOL_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  148. # 获取视频在流量池中的剩余可分发数接口地址
  149. GET_REMAIN_VIEW_COUNT_URL = 'http://testapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  150. # 计算完ROV通知后端接口地址
  151. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/updateRovScore'
  152. # 获取置顶视频列表接口地址
  153. TOP_VIDEO_LIST_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/recommend/topVideoList'
  154. # 获取首页兜底视频json接口地址
  155. BOTTOM_JSON_URL = 'http://videotest-internal.yishihui.com/longvideoapi/openapi/video/distribute/structure/video/list'
  156. # logs 上传oss 目标Bucket指定目录
  157. OSS_FOLDER_LOGS = 'rov-offline/test/logs/'
  158. # data 上传oss 目标Bucket指定目录
  159. OSS_FOLDER_DATA = 'rov-offline/test/data/'
  160. class PreProductionConfig(BaseConfig):
  161. """预发布环境配置"""
  162. # 报警内容 环境区分
  163. ENV_TEXT = "预发布环境"
  164. # 项目存放目录
  165. PROJECT_PATH = '/data/rov-offline'
  166. # redis地址
  167. REDIS_INFO = {
  168. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  169. 'port': 6379,
  170. 'password': 'Wqsd@2019',
  171. }
  172. # Hologres连接参数,服务器使用
  173. HOLOGRES_INFO = {
  174. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  175. 'port': 80,
  176. 'dbname': 'dssm',
  177. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  178. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  179. }
  180. # 生产环境mysql地址
  181. MYSQL_INFO = {
  182. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  183. 'port': 3306,
  184. 'user': 'wx2016_longvideo',
  185. 'password': 'wx2016_longvideoP@assword1234',
  186. 'db': 'longvideo',
  187. 'charset': 'utf8'
  188. }
  189. # Hologres视频状态存储表名
  190. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  191. # 从流量池获取视频接口地址
  192. GET_VIDEOS_FROM_POOL_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/getAllVideo'
  193. # 获取视频在流量池中的剩余可分发数接口地址
  194. GET_REMAIN_VIEW_COUNT_URL = 'http://preapi-internal.piaoquantv.com/flowpool/video/remainViewCount'
  195. # 计算完ROV通知后端接口地址
  196. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://videopre-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  197. # 获取置顶视频列表接口地址
  198. TOP_VIDEO_LIST_URL = 'http://speedpre.wx.com/longvideoapi/openapi/recommend/topVideoList'
  199. # 获取首页兜底视频json接口地址
  200. BOTTOM_JSON_URL = 'http://speedpre.wx.com/longvideoapi/openapi/video/distribute/structure/video/list'
  201. # logs 上传oss 目标Bucket指定目录
  202. OSS_FOLDER_LOGS = 'rov-offline/pre/logs/'
  203. # data 上传oss 目标Bucket指定目录
  204. OSS_FOLDER_DATA = 'rov-offline/pre/data/'
  205. class ProductionConfig(BaseConfig):
  206. """生产环境配置"""
  207. # 报警内容 环境区分
  208. ENV_TEXT = "生产环境"
  209. # 项目存放目录
  210. PROJECT_PATH = '/data/rov-offline'
  211. # 线上环境redis地址
  212. REDIS_INFO = {
  213. 'host': 'r-bp1fogs2mflr1ybfot.redis.rds.aliyuncs.com',
  214. 'port': 6379,
  215. 'password': 'Wqsd@2019',
  216. }
  217. # Hologres连接参数,服务器使用
  218. HOLOGRES_INFO = {
  219. 'host': 'hgprecn-cn-7pp28y18c00c-cn-hangzhou-vpc.hologres.aliyuncs.com',
  220. 'port': 80,
  221. 'dbname': 'dssm',
  222. 'user': 'LTAI5tMPqPy9yboQAf1mBCCN',
  223. 'password': '4BEcOgxREOPq7t3A7EWkjciVULeQGj'
  224. }
  225. # 生产环境mysql地址
  226. MYSQL_INFO = {
  227. 'host': 'rr-bp1x9785e8h5452bi157.mysql.rds.aliyuncs.com',
  228. 'port': 3306,
  229. 'user': 'wx2016_longvideo',
  230. 'password': 'wx2016_longvideoP@assword1234',
  231. 'db': 'longvideo',
  232. 'charset': 'utf8'
  233. }
  234. # Hologres视频状态存储表名
  235. VIDEO_STATUS = 'longvideo.dwd_mdm_item_video_stat'
  236. # 从流量池获取视频接口地址
  237. GET_VIDEOS_FROM_POOL_URL = 'http://api-internal.piaoquantv.com/flowpool/video/getAllVideo'
  238. # 获取视频在流量池中的剩余可分发数接口地址
  239. GET_REMAIN_VIEW_COUNT_URL = 'http://api-internal.piaoquantv.com/flowpool/video/remainViewCount'
  240. # 计算完ROV通知后端接口地址
  241. NOTIFY_BACKEND_UPDATE_ROV_SCORE_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/updateRovScore'
  242. # 获取置顶视频列表接口地址
  243. TOP_VIDEO_LIST_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/recommend/topVideoList'
  244. # 获取首页兜底视频json接口地址
  245. BOTTOM_JSON_URL = 'http://recommend-common-internal.piaoquantv.com/longvideoapi/openapi/video/distribute/structure/video/list'
  246. # logs 上传oss 目标Bucket指定目录
  247. OSS_FOLDER_LOGS = 'rov-offline/pro/logs/'
  248. # data 上传oss 目标Bucket指定目录
  249. OSS_FOLDER_DATA = 'rov-offline/pro/data/'
  250. def set_config():
  251. # 获取环境变量 ROV_OFFLINE_ENV
  252. env = os.environ.get('ROV_OFFLINE_ENV')
  253. # env = 'dev'
  254. if env is None:
  255. log_.error('ENV ERROR: is None!')
  256. return
  257. if env == 'dev':
  258. return DevelopmentConfig(), env
  259. elif env == 'test':
  260. return TestConfig(), env
  261. elif env == 'pre':
  262. return PreProductionConfig(), env
  263. elif env == 'pro':
  264. return ProductionConfig(), env
  265. else:
  266. log_.error('ENV ERROR: is {}'.format(env))
  267. return