app_run.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. # -*- coding: utf-8 -*-
  2. # @Time : 2024/6/11
  3. # @Author : 魏志亮
  4. import sys
  5. from os import *
  6. from utils.conf.read_conf import yaml_conf, read_conf
  7. def get_exec_data(batch_no=None, read_type=None, run_count=1):
  8. if batch_no and read_type:
  9. data = get_data_by_batch_no_and_type(batch_no, read_type)
  10. if data is None:
  11. raise ValueError(f"未找到批次号:{batch_no},类型:{read_type}")
  12. else:
  13. data = get_batch_exec_data(run_count)
  14. if data is None:
  15. trans_print("当前有任务在执行")
  16. sys.exit(0)
  17. elif len(data.keys()) == 0:
  18. trans_print("当前无任务")
  19. sys.exit(0)
  20. return data
  21. def run(batch_no=None, read_type=None, save_db=True, run_count=1):
  22. update_timeout_trans_data()
  23. data = get_exec_data(batch_no, read_type, run_count)
  24. exec_process = None
  25. if data['transfer_type'] in ['second', 'minute']:
  26. exec_process = MinSecTrans(data=data, save_db=save_db)
  27. if data['transfer_type'] in ['fault', 'warn']:
  28. exec_process = FaultWarnTrans(data=data, save_db=save_db)
  29. if exec_process is None:
  30. raise Exception("No exec process")
  31. exec_process.run()
  32. if __name__ == '__main__':
  33. env = 'dev'
  34. if len(sys.argv) >= 2:
  35. env = sys.argv[1]
  36. conf_path = path.abspath(f"./conf/etl_config_{env}.yaml")
  37. environ['ETL_CONF'] = conf_path
  38. yaml_config = yaml_conf(conf_path)
  39. environ['env'] = env
  40. run_count = int(read_conf(yaml_config, "run_batch_count", 1))
  41. from utils.log.trans_log import trans_print
  42. from service.plt_service import get_batch_exec_data, get_data_by_batch_no_and_type, update_timeout_trans_data
  43. from etl.wind_power.fault_warn.FaultWarnTrans import FaultWarnTrans
  44. from etl.wind_power.min_sec.MinSecTrans import MinSecTrans
  45. trans_print("所有请求参数:", sys.argv, "env:", env, "最大可执行个数:", run_count)
  46. trans_print("配置文件路径:", environ.get("ETL_CONF"))
  47. run(run_count=run_count)