From 8cbe96fccfd77719d580458e062c431659996564 Mon Sep 17 00:00:00 2001 From: xuyan wang <35394786+wayyoungboy@users.noreply.github.com> Date: Thu, 19 Dec 2024 16:03:50 +0800 Subject: [PATCH 1/2] 3.0 fix some bugs (#641) * fix: conf path * fix: conf path * remote_client support strict_host_key_checking * Clean rca old *scene.py files * fix some bugs --- rpm/init.sh | 2 +- src/common/core.py | 4 ---- src/common/diag_cmd.py | 6 ------ src/handler/gather/gather_component_log.py | 6 ++---- 4 files changed, 3 insertions(+), 15 deletions(-) diff --git a/rpm/init.sh b/rpm/init.sh index 16f993a9..451a0548 100755 --- a/rpm/init.sh +++ b/rpm/init.sh @@ -20,7 +20,7 @@ mkdir -p ${OBDIAG_HOME}/log mkdir -p ${OBDIAG_HOME}/display # Clean rca old *scene.py files -find "$SOURCE_DIR/rca" -maxdepth 1 -name "*_scene.py" -type f -exec rm -f {} \; +find ${OBDIAG_HOME}/rca -maxdepth 1 -name "*_scene.py" -type f -exec rm -f {} \; cp -rf ${WORK_DIR}/plugins/* ${OBDIAG_HOME}/ diff --git a/src/common/core.py b/src/common/core.py index 805b6af9..8b1726f8 100644 --- a/src/common/core.py +++ b/src/common/core.py @@ -262,7 +262,6 @@ def gather_function(self, function_type, opt): since=Util.get_option(options, 'since'), scope=Util.get_option(options, 'scope'), grep=Util.get_option(options, 'grep'), - encrypt=Util.get_option(options, 'encrypt'), store_dir=Util.get_option(options, 'store_dir'), temp_dir=Util.get_option(options, 'temp_dir'), redact=Util.get_option(options, 'redact'), @@ -304,7 +303,6 @@ def gather_function(self, function_type, opt): since=Util.get_option(options, 'since'), scope=Util.get_option(options, 'scope'), grep=Util.get_option(options, 'grep'), - encrypt=Util.get_option(options, 'encrypt'), store_dir=Util.get_option(options, 'store_dir'), temp_dir=Util.get_option(options, 'temp_dir'), redact=Util.get_option(options, 'redact'), @@ -319,7 +317,6 @@ def gather_function(self, function_type, opt): since=Util.get_option(options, 'since'), scope=Util.get_option(options, 'scope'), grep=Util.get_option(options, 'grep'), - encrypt=Util.get_option(options, 'encrypt'), store_dir=Util.get_option(options, 'store_dir'), temp_dir=Util.get_option(options, 'temp_dir'), redact=Util.get_option(options, 'redact'), @@ -364,7 +361,6 @@ def gather_obproxy_log(self, opt): since=Util.get_option(options, 'since'), scope=Util.get_option(options, 'scope'), grep=Util.get_option(options, 'grep'), - encrypt=Util.get_option(options, 'encrypt'), store_dir=Util.get_option(options, 'store_dir'), temp_dir=Util.get_option(options, 'temp_dir'), redact=Util.get_option(options, 'redact'), diff --git a/src/common/diag_cmd.py b/src/common/diag_cmd.py index 64d96d22..0df94684 100644 --- a/src/common/diag_cmd.py +++ b/src/common/diag_cmd.py @@ -433,9 +433,7 @@ def __init__(self): self.parser.add_option('--from', type='string', help="specify the start of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--to', type='string', help="specify the end of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--since', type='string', help="Specify time range that from 'n' [d]ays, 'n' [h]ours or 'n' [m]inutes. before to now. format: . example: 1h.", default='30m') - self.parser.add_option('--scope', type='string', help="log type constrains, choices=[observer, election, rootservice, all]", default='all') self.parser.add_option('--grep', action="append", type='string', help="specify keywords constrain") - self.parser.add_option('--encrypt', type='string', help="Whether the returned results need to be encrypted, choices=[true, false]", default="false") self.parser.add_option('--store_dir', type='string', help='the dir to store gather result, current dir by default.', default='./') self.parser.add_option('--temp_dir', type='string', help='the dir for temporarily storing files on nodes', default='/tmp') self.parser.add_option('-c', type='string', help='obdiag custom config', default=os.path.expanduser('~/.obdiag/config.yml')) @@ -459,7 +457,6 @@ def __init__(self): self.parser.add_option('--since', type='string', help="Specify time range that from 'n' [d]ays, 'n' [h]ours or 'n' [m]inutes. before to now. format: . example: 1h.", default='30m') self.parser.add_option('--scope', type='string', help="log type constrains, choices=[observer, election, rootservice, all]", default='all') self.parser.add_option('--grep', action="append", type='string', help="specify keywords constrain") - self.parser.add_option('--encrypt', type='string', help="Whether the returned results need to be encrypted, choices=[true, false]", default="false") self.parser.add_option('--store_dir', type='string', help='the dir to store gather result, current dir by default.', default='./') self.parser.add_option('--temp_dir', type='string', help='the dir for temporarily storing files on nodes', default='/tmp') self.parser.add_option('-c', type='string', help='obdiag custom config', default=os.path.expanduser('~/.obdiag/config.yml')) @@ -570,7 +567,6 @@ def __init__(self): self.parser.add_option('--from', type='string', help="specify the start of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--to', type='string', help="specify the end of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--since', type='string', help="Specify time range that from 'n' [d]ays, 'n' [h]ours or 'n' [m]inutes. before to now. format: . example: 1h.", default='30m') - self.parser.add_option('--encrypt', type='string', help="Whether the returned results need to be encrypted, choices=[true, false]", default="false") self.parser.add_option('--store_dir', type='string', help='the dir to store gather result, current dir by default.', default='./') self.parser.add_option('-c', type='string', help='obdiag custom config', default=os.path.expanduser('~/.obdiag/config.yml')) self.parser.add_option('--config', action="append", type="string", help='config options Format: --config key=value') @@ -591,7 +587,6 @@ def __init__(self): self.parser.add_option('--from', type='string', help="specify the start of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--to', type='string', help="specify the end of the time range. format: 'yyyy-mm-dd hh:mm:ss'") self.parser.add_option('--since', type='string', help="Specify time range that from 'n' [d]ays, 'n' [h]ours or 'n' [m]inutes. before to now. format: . example: 1h.", default='30m') - self.parser.add_option('--encrypt', type='string', help="Whether the returned results need to be encrypted, choices=[true, false]", default="false") self.parser.add_option('--store_dir', type='string', help='the dir to store gather result, current dir by default.', default='./') self.parser.add_option('-c', type='string', help='obdiag custom config', default=os.path.expanduser('~/.obdiag/config.yml')) self.parser.add_option('--config', action="append", type="string", help='config options Format: --config key=value') @@ -655,7 +650,6 @@ def __init__(self): self.parser.add_option('--since', type='string', help="Specify time range that from 'n' [d]ays, 'n' [h]ours or 'n' [m]inutes. before to now. format: . example: 1h.", default='30m') self.parser.add_option('--scope', type='string', help="log type constrains, choices=[obproxy, obproxy_limit, obproxy_stat, obproxy_digest, obproxy_slow, obproxy_diagnosis, obproxy_error, all]", default='all') self.parser.add_option('--grep', action="append", type='string', help="specify keywords constrain") - self.parser.add_option('--encrypt', type='string', help="Whether the returned results need to be encrypted, choices=[true, false]", default="false") self.parser.add_option('--store_dir', type='string', help='the dir to store gather result, current dir by default.', default='./') self.parser.add_option('-c', type='string', help='obdiag custom config', default=os.path.expanduser('~/.obdiag/config.yml')) self.parser.add_option('--config', action="append", type="string", help='config options Format: --config key=value') diff --git a/src/handler/gather/gather_component_log.py b/src/handler/gather/gather_component_log.py index 7e08f102..edd1e5ce 100644 --- a/src/handler/gather/gather_component_log.py +++ b/src/handler/gather/gather_component_log.py @@ -61,7 +61,6 @@ def __init__(self, *args, **kwargs): self.since_option = None self.scope = None self.grep = None - self.encrypt = None self.store_dir = None self.temp_dir = None self.redact = None @@ -83,7 +82,6 @@ def init(self, context, *args, **kwargs): self.since_option = kwargs.get('since', None) self.scope = kwargs.get('scope', None) self.grep = kwargs.get('grep', None) - self.encrypt = kwargs.get('encrypt', None) self.store_dir = kwargs.get('store_dir', None) self.temp_dir = kwargs.get('temp_dir', None) self.redact = kwargs.get('redact', None) @@ -99,7 +97,6 @@ def init(self, context, *args, **kwargs): "tmp_dir": const.GATHER_LOG_TEMPORARY_DIR_DEFAULT, "scope": self.scope, "grep": self.grep, - "encrypt": self.encrypt, "store_dir": self.store_dir, "from_time": self.from_time_str, "to_time": self.to_time_str, @@ -126,7 +123,8 @@ def __check_option(self): # check store_dir if not os.path.exists(self.store_dir): - raise Exception("store_dir: {0} is not exist".format(self.store_dir)) + self.stdio.warn('args --store_dir [{0}] incorrect: No such directory, Now create it'.format(os.path.abspath(self.store_dir))) + os.makedirs(os.path.abspath(self.store_dir)) if self.is_scene is False: target_dir = os.path.join("obdiag_gather_pack_{0}".format(TimeUtils.timestamp_to_filename_time(TimeUtils.get_current_us_timestamp()))) self.store_dir = os.path.join(self.store_dir or "./", target_dir) From 8fef75c5b5f13e70e5200c234af16917d525ecb4 Mon Sep 17 00:00:00 2001 From: "jingshun.tq" <35712518+Teingi@users.noreply.github.com> Date: Thu, 19 Dec 2024 16:07:53 +0800 Subject: [PATCH 2/2] fixed: analyze memory (#642) * Rename Dockerfile to DockerFile * fixed: analyze memory --- src/handler/analyzer/analyze_memory.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/handler/analyzer/analyze_memory.py b/src/handler/analyzer/analyze_memory.py index 931b41ef..363795f4 100644 --- a/src/handler/analyzer/analyze_memory.py +++ b/src/handler/analyzer/analyze_memory.py @@ -23,13 +23,13 @@ import tabulate import threading import uuid -from src import common as ssh_client_local_client from src.common.command import get_observer_version_by_sql from src.common.tool import DirectoryUtil, TimeUtils, Util, NetUtils, FileUtil from src.common.obdiag_exception import OBDIAGFormatException from src.common.constant import const from src.common.command import download_file, get_logfile_name_list, mkdir, delete_file from src.common.command import SshClient +from src.common.ssh_client.local_client import LocalClient from src.common.result_type import ObdiagResult @@ -537,7 +537,7 @@ def __pharse_offline_log_file(self, ssh_client, log_name, local_store_dir): :return: """ - ssh_client = ssh_client_local_client.LocalClient(context=self.context, node={"ssh_type": "local"}) + ssh_client = LocalClient(context=self.context, node={"ssh_type": "local"}) local_store_path = "{0}/{1}".format(local_store_dir, str(log_name).strip(".").replace("/", "_")) if self.grep_args is not None: grep_cmd = "grep -e '{grep_args}' {log_name} >> {local_store_path} ".format(grep_args=self.grep_args, log_name=log_name, local_store_path=local_store_path) @@ -547,7 +547,7 @@ def __pharse_offline_log_file(self, ssh_client, log_name, local_store_dir): download_file(ssh_client, log_name, local_store_path, self.stdio) def __parse_memory_label(self, file_full_path): - ssh_client = ssh_client_local_client.LocalClient(context=self.context, node={"ssh_type": "local"}) + ssh_client = LocalClient(context=self.context, node={"ssh_type": "local"}) if self.version >= '4.3': grep_cmd = 'grep -n "memory_dump.*statistics" ' + file_full_path elif self.version >= '4.0' and self.version < '4.3':