config.py 11 KB

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