forked from mindspore-Ecosystem/mindspore
!23663 add exception level to python error report
Merge pull request !23663 from huangbingjian/py_log
This commit is contained in:
commit
632e3b8dcd
|
@ -196,8 +196,11 @@ class TbeTuner:
|
|||
te_log_level = os.environ.get("TE_LOGLEVEL")
|
||||
glog_level = os.environ.get("GLOG_v")
|
||||
if glog_level is not None and te_log_level is None:
|
||||
os.environ["TE_LOGLEVEL"] = TE_LOG_LEVEL[int(glog_level)]
|
||||
global_loglevel = int(glog_level)
|
||||
level = int(glog_level)
|
||||
if level >= len(TE_LOG_LEVEL):
|
||||
level = len(TE_LOG_LEVEL) - 1
|
||||
os.environ["TE_LOGLEVEL"] = TE_LOG_LEVEL[level]
|
||||
global_loglevel = level
|
||||
elif glog_level is None and te_log_level is None:
|
||||
os.environ["TE_LOGLEVEL"] = TE_LOG_LEVEL[2]
|
||||
global_loglevel = 3
|
||||
|
|
|
@ -117,7 +117,7 @@ class TrtLogger : public nvinfer1::ILogger {
|
|||
if (str_level.size() == 1) {
|
||||
int ch = str_level.c_str()[0];
|
||||
ch = ch - '0'; // subtract ASCII code of '0', which is 48
|
||||
if (ch >= mindspore::DEBUG && ch <= mindspore::ERROR) {
|
||||
if (ch >= mindspore::DEBUG && ch <= mindspore::EXCEPTION) {
|
||||
log_level_ = static_cast<MsLogLevel>(ch);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -202,6 +202,8 @@ int StrToInt(const std::string &env) {
|
|||
return INFO;
|
||||
} else if (env == "3") {
|
||||
return ERROR;
|
||||
} else if (env == "4") {
|
||||
return EXCEPTION;
|
||||
}
|
||||
return WARNING;
|
||||
}
|
||||
|
|
|
@ -62,7 +62,7 @@ def _make_directory(path):
|
|||
os.makedirs(path)
|
||||
real_path = path
|
||||
except PermissionError as e:
|
||||
logger.error(f"No write permission on the directory `{path}, error = {e}")
|
||||
logger.error(f"No write permission on the directory `{path}`, error = {e}")
|
||||
raise ValueError(f"No write permission on the directory `{path}`.")
|
||||
return real_path
|
||||
|
||||
|
|
|
@ -2457,8 +2457,8 @@ def _watch_dog(eot, pids):
|
|||
wait_pid()
|
||||
## multiprocessing.queue may hang in .get() forever when put() process was killed.
|
||||
## We have to exit main process otherwise main process will hang.
|
||||
logger.error("The subprocess of dataset may exit unexpected or be killed, "
|
||||
"main process will exit.")
|
||||
logger.exception("The subprocess of dataset may exit unexpected or be killed, "
|
||||
"main process will exit.")
|
||||
os.kill(os.getpid(), signal.SIGTERM)
|
||||
|
||||
|
||||
|
@ -2608,7 +2608,7 @@ class _ExceptHookHandler:
|
|||
sys.excepthook = self.__handler_exception
|
||||
|
||||
def __handler_exception(self, ex_type, value, tb):
|
||||
logger.error("Uncaught exception: ", exc_info=(ex_type, value, tb))
|
||||
logger.exception("Uncaught exception: ", exc_info=(ex_type, value, tb))
|
||||
_mp_pool_exit_preprocess()
|
||||
|
||||
|
||||
|
|
|
@ -180,7 +180,7 @@ class DictIterator(Iterator):
|
|||
## maybe "Out of memory" / "MemoryError" error
|
||||
err_info = str(err)
|
||||
if err_info.find("Out of memory") >= 0 or err_info.find("MemoryError") >= 0:
|
||||
logger.error("Memory error occurred, process will exit.")
|
||||
logger.exception("Memory error occurred, process will exit.")
|
||||
os.kill(os.getpid(), signal.SIGKILL)
|
||||
raise err
|
||||
|
||||
|
|
|
@ -54,6 +54,7 @@ _name_to_level = {
|
|||
'INFO': 20,
|
||||
'WARNING': 30,
|
||||
'ERROR': 40,
|
||||
'EXCEPTION': 50,
|
||||
}
|
||||
|
||||
# GLog level and level name
|
||||
|
@ -62,7 +63,7 @@ _gloglevel_to_name = {
|
|||
'1': 'INFO',
|
||||
'2': 'WARNING',
|
||||
'3': 'ERROR',
|
||||
'4': 'ERROR',
|
||||
'4': 'EXCEPTION',
|
||||
}
|
||||
|
||||
# The mapping of logger configurations to glog configurations
|
||||
|
@ -212,16 +213,16 @@ def error(msg, *args, **kwargs):
|
|||
_get_logger().error(msg, *args, **kwargs)
|
||||
|
||||
|
||||
def exception(msg, *args, **kwargs):
|
||||
"""Log a message with severity 'EXCEPTION' on the MindSpore logger."""
|
||||
_get_logger().exception(msg, *args, **kwargs)
|
||||
|
||||
|
||||
def warning(msg, *args, **kwargs):
|
||||
"""Log a message with severity 'WARNING' on the MindSpore logger."""
|
||||
_get_logger().warning(msg, *args, **kwargs)
|
||||
|
||||
|
||||
def exception(msg, *args, **kwargs):
|
||||
"""Use logging.critical to log a message with severity 'EXCEPTION' on the MindSpore logger."""
|
||||
_get_logger().critical(msg, *args, **kwargs)
|
||||
|
||||
|
||||
def get_level():
|
||||
"""
|
||||
Get the logger level.
|
||||
|
@ -510,6 +511,8 @@ def _setup_logger(kwargs):
|
|||
if _global_logger:
|
||||
return _global_logger
|
||||
|
||||
# Set the level name of logging.CRITICAL to EXCEPTION
|
||||
logging.addLevelName(logging.CRITICAL, 'EXCEPTION')
|
||||
logger = logging.getLogger(name=f'{sub_module}.{log_name}')
|
||||
# Override findCaller on the logger, Support for getting log record
|
||||
logger.findCaller = _find_caller
|
||||
|
|
|
@ -33,6 +33,7 @@ def test_log_stdout():
|
|||
logger.info("2 test log message info :%s", log_str)
|
||||
logger.warning("3 test log message warning :%s", log_str)
|
||||
logger.debug("4 test log message debug:%s", log_str)
|
||||
logger.exception("5 test log message exception :{}".format(log_str))
|
||||
# Clean up _global_logger to avoid affecting for next usecase
|
||||
_clear_logger(logger)
|
||||
|
||||
|
|
Loading…
Reference in New Issue