From 0971035a8f87e42bf8d0c0cdc2ab16fad70255a9 Mon Sep 17 00:00:00 2001 From: Junchao-Mellanox Date: Mon, 25 Dec 2023 10:20:40 +0200 Subject: [PATCH] [xcvrd] enable setting log level at real time --- sonic-xcvrd/tests/test_xcvrd.py | 4 ++-- sonic-xcvrd/xcvrd/xcvrd.py | 6 +----- sonic-xcvrd/xcvrd/xcvrd_utilities/logger.py | 12 ++++++++++++ .../xcvrd/xcvrd_utilities/media_settings_parser.py | 5 ++--- .../xcvrd/xcvrd_utilities/optics_si_parser.py | 5 ++--- 5 files changed, 19 insertions(+), 13 deletions(-) create mode 100644 sonic-xcvrd/xcvrd/xcvrd_utilities/logger.py diff --git a/sonic-xcvrd/tests/test_xcvrd.py b/sonic-xcvrd/tests/test_xcvrd.py index d79747710..558f2e661 100644 --- a/sonic-xcvrd/tests/test_xcvrd.py +++ b/sonic-xcvrd/tests/test_xcvrd.py @@ -1,4 +1,6 @@ #from unittest.mock import DEFAULT +import os +os.environ["XCVRD_UNIT_TESTING"] = "1" from xcvrd.xcvrd_utilities.port_mapping import * from xcvrd.xcvrd_utilities.sfp_status_helper import * from xcvrd.xcvrd_utilities.media_settings_parser import * @@ -34,8 +36,6 @@ sys.path.insert(0, modules_path) DEFAULT_NAMESPACE = [''] -os.environ["XCVRD_UNIT_TESTING"] = "1" - with open(os.path.join(test_path, 'media_settings.json'), 'r') as f: media_settings_dict = json.load(f) diff --git a/sonic-xcvrd/xcvrd/xcvrd.py b/sonic-xcvrd/xcvrd/xcvrd.py index 60b9d8d09..db63c5b3a 100644 --- a/sonic-xcvrd/xcvrd/xcvrd.py +++ b/sonic-xcvrd/xcvrd/xcvrd.py @@ -29,6 +29,7 @@ from .xcvrd_utilities import port_mapping from .xcvrd_utilities import media_settings_parser from .xcvrd_utilities import optics_si_parser + from .xcvrd_utilities.logger import logger as helper_logger from sonic_platform_base.sonic_xcvr.api.public.c_cmis import CmisApi @@ -98,11 +99,6 @@ # Global chassis object based on new platform api platform_chassis = None -# Global logger instance for helper functions and classes -# TODO: Refactor so that we only need the logger inherited -# by DaemonXcvrd -helper_logger = logger.Logger(SYSLOG_IDENTIFIER) - # # Helper functions ============================================================= # diff --git a/sonic-xcvrd/xcvrd/xcvrd_utilities/logger.py b/sonic-xcvrd/xcvrd/xcvrd_utilities/logger.py new file mode 100644 index 000000000..1a058cab5 --- /dev/null +++ b/sonic-xcvrd/xcvrd/xcvrd_utilities/logger.py @@ -0,0 +1,12 @@ +import os +from sonic_py_common.logger import Logger + +# Global logger instance for xcvrd, the argument "enable_set_log_level_on_fly" +# will start a thread to detect CONFIG DB LOGGER table change. The logger instance +# allow user to set log level via swssloglevel command at real time. This instance +# should be shared by all modules of xcvrd to avoid starting too many logger thread. +if os.environ.get("XCVRD_UNIT_TESTING") != "1": + logger = Logger(log_identifier='xcvrd', enable_set_log_level_on_fly=True) +else: + # for unit test, there is no redis, don't set enable_set_log_level_on_fly=True + logger = Logger(log_identifier='xcvrd') diff --git a/sonic-xcvrd/xcvrd/xcvrd_utilities/media_settings_parser.py b/sonic-xcvrd/xcvrd/xcvrd_utilities/media_settings_parser.py index 2a27422dc..594a05847 100644 --- a/sonic-xcvrd/xcvrd/xcvrd_utilities/media_settings_parser.py +++ b/sonic-xcvrd/xcvrd/xcvrd_utilities/media_settings_parser.py @@ -6,9 +6,10 @@ import os import ast -from sonic_py_common import device_info, logger +from sonic_py_common import device_info from swsscommon import swsscommon from xcvrd import xcvrd +from .logger import logger as helper_logger g_dict = {} @@ -16,8 +17,6 @@ VENDOR_KEY = 'vendor_key' MEDIA_KEY = 'media_key' LANE_SPEED_KEY = 'lane_speed_key' -SYSLOG_IDENTIFIER = "xcvrd" -helper_logger = logger.Logger(SYSLOG_IDENTIFIER) def load_media_settings(): diff --git a/sonic-xcvrd/xcvrd/xcvrd_utilities/optics_si_parser.py b/sonic-xcvrd/xcvrd/xcvrd_utilities/optics_si_parser.py index fff418563..57f5e1aa7 100644 --- a/sonic-xcvrd/xcvrd/xcvrd_utilities/optics_si_parser.py +++ b/sonic-xcvrd/xcvrd/xcvrd_utilities/optics_si_parser.py @@ -1,13 +1,12 @@ import json import os -from sonic_py_common import device_info, logger +from sonic_py_common import device_info from xcvrd import xcvrd +from .logger import logger as helper_logger g_optics_si_dict = {} -SYSLOG_IDENTIFIER = "xcvrd" -helper_logger = logger.Logger(SYSLOG_IDENTIFIER) def get_optics_si_settings_value(physical_port, lane_speed, key, vendor_name_str): GLOBAL_MEDIA_SETTINGS_KEY = 'GLOBAL_MEDIA_SETTINGS'