__init__.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #!/usr/bin/env /usr/bin/python3
  2. # -*- coding:utf-8 -*-
  3. import os
  4. import socket
  5. import sys
  6. import time
  7. from dw_base.utils.env_loader import bootstrap_env
  8. bootstrap_env()
  9. # HADOOP_CONF_DIR:spark-submit 启动 YARN 校验需要;DataX JVM 不读 classpath conf,HA 由 ini [hadoop_config] 节显式注入
  10. os.environ['HADOOP_CONF_DIR'] = '/etc/hadoop/conf'
  11. # SPARK_CONF_DIR:pip pyspark 默认指向自身空 conf/,显式指到集群配置才能加载 hive-site.xml,否则 enableHiveSupport 回落 in-memory metastore
  12. os.environ.setdefault('SPARK_CONF_DIR', '/etc/spark/conf')
  13. os.environ["PYSPARK_DRIVER_PYTHON"] = "/usr/bin/python3"
  14. os.environ["PYSPARK_PYTHON"] = "/usr/bin/python3"
  15. os.environ['PYTHONUNBUFFERED'] = 'x'
  16. PROJECT_ROOT_PATH = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
  17. PROJECT_NAME = os.path.basename(PROJECT_ROOT_PATH)
  18. sys.path.append(PROJECT_ROOT_PATH)
  19. # 公用的Spark UDF文件
  20. COMMON_SPARK_UDF_FILE = 'dw_base/udf/common/spark_common_udf.py'
  21. BANNED_USER = 'root'
  22. RELEASE_USER = os.environ['RELEASE_USER']
  23. USER = os.environ['USER']
  24. HOME = os.environ['HOME']
  25. if USER == BANNED_USER and HOME.startswith('/home'):
  26. USER = os.path.basename(HOME)
  27. HOST = socket.gethostname()
  28. RELEASE_ROOT_DIR = os.environ['RELEASE_ROOT_DIR']
  29. if not PROJECT_ROOT_PATH.startswith(RELEASE_ROOT_DIR) or USER != RELEASE_USER:
  30. DO_RESET: str = '\033[0m'
  31. NORM_RED: str = '\033[0;31m'
  32. NORM_GRN: str = '\033[0;32m'
  33. NORM_YEL: str = '\033[0;33m'
  34. NORM_MGT: str = '\033[0;35m'
  35. NORM_CYN: str = '\033[0;36m'
  36. else:
  37. DO_RESET: str = ''
  38. NORM_RED: str = ''
  39. NORM_GRN: str = ''
  40. NORM_YEL: str = ''
  41. NORM_MGT: str = ''
  42. NORM_CYN: str = ''
  43. IS_RUN_BY_RELEASE_USER = False
  44. LOG_ROOT_DIR = os.environ['LOG_ROOT_DIR']
  45. if USER == RELEASE_USER:
  46. IS_RUN_BY_RELEASE_USER = True
  47. elif USER == BANNED_USER:
  48. ERROR_CODE = 18
  49. print(f'{NORM_MGT}{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())} '
  50. f'{NORM_RED}Project {NORM_GRN}{PROJECT_NAME} '
  51. f'{NORM_RED}is running by banned user {NORM_GRN}{BANNED_USER}'
  52. f'{NORM_RED}, exit with error code {NORM_GRN}{ERROR_CODE}'
  53. f'{DO_RESET}')
  54. exit(ERROR_CODE)
  55. else:
  56. print(f'{NORM_CYN}{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())} '
  57. f'{NORM_MGT}Project {NORM_GRN}{PROJECT_NAME} '
  58. f'{NORM_MGT}is running in normal user {NORM_GRN}{USER}')
  59. if PROJECT_ROOT_PATH.startswith(f'{RELEASE_ROOT_DIR}/{PROJECT_NAME}'):
  60. IS_RUN_IN_RELEASE_DIR = True
  61. print(f'{NORM_CYN}{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())} '
  62. f'{NORM_MGT}Project {NORM_GRN}{PROJECT_NAME} '
  63. f'{NORM_MGT}is running in release dir {NORM_GRN}{RELEASE_ROOT_DIR}/{PROJECT_NAME}')
  64. else:
  65. IS_RUN_IN_RELEASE_DIR = False
  66. print(f'{NORM_CYN}{time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())} '
  67. f'{NORM_MGT}Project {NORM_GRN}{PROJECT_NAME} '
  68. f'{NORM_MGT}is running in normal user dir {NORM_GRN}{PROJECT_ROOT_PATH}')
  69. if not IS_RUN_IN_RELEASE_DIR or USER != RELEASE_USER:
  70. os.system(f'echo -en "{NORM_GRN}"')
  71. os.system(f'echo -en "{DO_RESET}"')