Rebase on upstream 3.3
- Rebased on upstream 3.3 - Resolves: BZ#1411314 Signed-off-by: Sandro Bonazzola <sbonazzo@fedoraproject.org>
This commit is contained in:
parent
902c095b8d
commit
6b6e4c7552
1
.gitignore
vendored
1
.gitignore
vendored
@ -3,3 +3,4 @@ sos-2.2.tar.gz
|
||||
/sos-3.1.tar.gz
|
||||
/sos-55c89eb6810e7060845082845653b059aab90e3d.tar.gz
|
||||
/sos-3.2.tar.gz
|
||||
/3.3.tar.gz
|
||||
|
@ -1,77 +0,0 @@
|
||||
From e2a94de2e574b61d1da071f961863d2490c90bc0 Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?Pep=20Turr=C3=B3=20Mauri?= <pep@redhat.com>
|
||||
Date: Tue, 23 Dec 2014 19:36:29 +0100
|
||||
Subject: [PATCH] [activemq] Honour all_logs and get config on RHEL
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
Get only current log file by default, allowing full dir
|
||||
collection via the all_logs option.
|
||||
|
||||
Add a Red Hat version of the plugin that collects the two
|
||||
main configuration files for activemq. Also enable that plugin
|
||||
in the OpenShift profile.
|
||||
|
||||
Related: RHBZ#1165878
|
||||
Fixes: #457.
|
||||
|
||||
Signed-off-by: Pep Turró Mauri <pep@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/activemq.py | 31 ++++++++++++++++++++++++++++---
|
||||
1 file changed, 28 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/activemq.py b/sos/plugins/activemq.py
|
||||
index 291fcd9..1594229 100644
|
||||
--- a/sos/plugins/activemq.py
|
||||
+++ b/sos/plugins/activemq.py
|
||||
@@ -16,17 +16,42 @@
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
|
||||
|
||||
-class ActiveMq(Plugin, RedHatPlugin, DebianPlugin):
|
||||
+class ActiveMq(Plugin, DebianPlugin):
|
||||
"""ActiveMQ message broker
|
||||
"""
|
||||
|
||||
plugin_name = 'activemq'
|
||||
- profiles = ()
|
||||
+ profiles = ('openshift',)
|
||||
packages = ('activemq', 'activemq-core')
|
||||
files = ('/var/log/activemq',)
|
||||
|
||||
def setup(self):
|
||||
- self.add_copy_spec(list(self.files))
|
||||
+ if self.get_option("all_logs"):
|
||||
+ self.add_copy_spec(list(self.files))
|
||||
+ else:
|
||||
+ self.add_copy_spec([
|
||||
+ "/var/log/activemq/activemq.log",
|
||||
+ "/var/log/activemq/wrapper.log"
|
||||
+ ])
|
||||
+
|
||||
+ def postproc(self):
|
||||
+ # activemq.xml contains credentials in this form:
|
||||
+ # <authenticationUser ... password="changeme" ... />
|
||||
+ self.do_file_sub(
|
||||
+ '/etc/activemq/activemq.xml',
|
||||
+ r'(\s*password=")[^"]*(".*)',
|
||||
+ r"\1******\2"
|
||||
+ )
|
||||
+
|
||||
+
|
||||
+class RedHatActiveMq(ActiveMq, RedHatPlugin):
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(RedHatActiveMq, self).setup()
|
||||
+ self.add_copy_spec([
|
||||
+ '/etc/sysconfig/activemq',
|
||||
+ '/etc/activemq/activemq.xml'
|
||||
+ ])
|
||||
|
||||
|
||||
class UbuntuActiveMq(ActiveMq, UbuntuPlugin):
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,48 +0,0 @@
|
||||
From 874cc7d0889adf32b8c36bb218212d3304d43d5b Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 20 Oct 2014 09:13:07 +0100
|
||||
Subject: [PATCH] [tomcat] add support for tomcat7 and log size limits
|
||||
|
||||
Based on a patch from Pavel Moravec in Issue #412.
|
||||
|
||||
Fixes #412.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/tomcat.py | 14 +++++++++-----
|
||||
1 file changed, 9 insertions(+), 5 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/tomcat.py b/sos/plugins/tomcat.py
|
||||
index b7aea2c..4f78c1d 100644
|
||||
--- a/sos/plugins/tomcat.py
|
||||
+++ b/sos/plugins/tomcat.py
|
||||
@@ -22,17 +22,21 @@ class Tomcat(Plugin, RedHatPlugin):
|
||||
plugin_name = 'tomcat'
|
||||
profiles = ('webserver', 'java', 'services')
|
||||
|
||||
- packages = ('tomcat6',)
|
||||
+ packages = ('tomcat6', 'tomcat')
|
||||
|
||||
def setup(self):
|
||||
self.add_copy_spec([
|
||||
- "/etc/tomcat6",
|
||||
- "/var/log/tomcat6/catalina.out"
|
||||
+ "/etc/tomcat",
|
||||
+ "/etc/tomcat6"
|
||||
])
|
||||
|
||||
+ limit = self.get_option("log_size")
|
||||
+ log_glob = "/var/log/tomcat*/catalina.out"
|
||||
+ self.add_copy_spec_limit(log_glob, sizelimit=limit)
|
||||
+
|
||||
def postproc(self):
|
||||
- self.do_file_sub(
|
||||
- "/etc/tomcat6/tomcat-users.xml",
|
||||
+ self.do_path_regex_sub(
|
||||
+ r"\/etc\/tomcat.*\/tomcat-users.xml",
|
||||
r"password=(\S*)",
|
||||
r'password="********"'
|
||||
)
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,26 +0,0 @@
|
||||
From 5a97e0e2571b948f1f7bc602e6f190976de99eee Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 13 Jan 2015 16:31:58 +0000
|
||||
Subject: [PATCH] [anaconda] make useradd password regex tolerant of whitespace
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/anaconda.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/anaconda.py b/sos/plugins/anaconda.py
|
||||
index 08d300b..aea3300 100644
|
||||
--- a/sos/plugins/anaconda.py
|
||||
+++ b/sos/plugins/anaconda.py
|
||||
@@ -54,7 +54,7 @@ class Anaconda(Plugin, RedHatPlugin):
|
||||
)
|
||||
self.do_file_sub(
|
||||
"/root/anaconda-ks.cfg",
|
||||
- r"(user.*--password=*)(\S*)",
|
||||
+ r"(user.*--password=*\s*)\s*(\S*)",
|
||||
r"\1********"
|
||||
)
|
||||
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,26 +0,0 @@
|
||||
From e8428d458cfd65bdc34d69f32db0bf4f5aca7540 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 2 Oct 2014 17:16:55 +0100
|
||||
Subject: [PATCH] [yum] call rhsm-debug with --no-subscriptions
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/yum.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/yum.py b/sos/plugins/yum.py
|
||||
index 7dac5e4..816e2b0 100644
|
||||
--- a/sos/plugins/yum.py
|
||||
+++ b/sos/plugins/yum.py
|
||||
@@ -54,7 +54,7 @@ class Yum(Plugin, RedHatPlugin):
|
||||
"subscription-manager list --consumed"
|
||||
])
|
||||
self.add_cmd_output("rhsm-debug system --sos --no-archive "
|
||||
- "--destination %s"
|
||||
+ "--no-subscriptions --destination %s"
|
||||
% self.get_cmd_output_path())
|
||||
|
||||
if self.get_option("yumlist"):
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,93 +0,0 @@
|
||||
From 24ecc933d109c0eba120b434d08aa560e9a56869 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Wed, 1 Jul 2015 12:15:41 +0200
|
||||
Subject: [PATCH 1/2] [ceph] add logs, report and calamari conf
|
||||
|
||||
Update ceph commands and add log and configuration file
|
||||
collection for calamari and radosgw.
|
||||
|
||||
Resolves: #496
|
||||
Resolves: rhbz#1210527
|
||||
|
||||
Signed-off-by: Brad Hubbard <bhubbard@redhat.com>
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/ceph.py | 11 ++++++++---
|
||||
1 file changed, 8 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/ceph.py b/sos/plugins/ceph.py
|
||||
index 52b8fff..0bfdbe0 100644
|
||||
--- a/sos/plugins/ceph.py
|
||||
+++ b/sos/plugins/ceph.py
|
||||
@@ -37,17 +37,22 @@ class Ceph(Plugin, RedHatPlugin, UbuntuPlugin):
|
||||
def setup(self):
|
||||
self.add_copy_spec([
|
||||
"/etc/ceph/",
|
||||
- "/var/log/ceph/"
|
||||
+ "/var/log/ceph/",
|
||||
+ "/etc/calamari/",
|
||||
+ "/var/log/calamari",
|
||||
+ "/var/log/radosgw"
|
||||
])
|
||||
|
||||
self.add_cmd_output([
|
||||
"ceph status",
|
||||
- "ceph health",
|
||||
+ "ceph health detail",
|
||||
"ceph osd tree",
|
||||
"ceph osd stat",
|
||||
"ceph osd dump",
|
||||
"ceph mon stat",
|
||||
- "ceph mon dump"
|
||||
+ "ceph mon dump",
|
||||
+ "ceph df",
|
||||
+ "ceph report"
|
||||
])
|
||||
|
||||
self.add_forbidden_path("/etc/ceph/*keyring")
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 696f3c605c5d6b0cb8c0703635401991bc7af934 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Thu, 2 Jul 2015 13:10:31 +0200
|
||||
Subject: [PATCH 2/2] [ceph] add calamari-server and librados2 to the package
|
||||
list
|
||||
|
||||
Enable ceph plugin also by either calamari-server or librados2
|
||||
package.
|
||||
|
||||
This ensures Calamari and Rados log collection is effective
|
||||
regardless of which packages are installed on a given system.
|
||||
|
||||
This is a temporary solution until rados is split from the ceph
|
||||
package.
|
||||
|
||||
Resolves: #496
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/ceph.py | 4 +++-
|
||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/ceph.py b/sos/plugins/ceph.py
|
||||
index 0bfdbe0..e9db4c6 100644
|
||||
--- a/sos/plugins/ceph.py
|
||||
+++ b/sos/plugins/ceph.py
|
||||
@@ -31,7 +31,9 @@ class Ceph(Plugin, RedHatPlugin, UbuntuPlugin):
|
||||
'ceph-mds',
|
||||
'ceph-common',
|
||||
'libcephfs1',
|
||||
- 'ceph-fs-common'
|
||||
+ 'ceph-fs-common',
|
||||
+ 'calamari-server',
|
||||
+ 'librados2'
|
||||
)
|
||||
|
||||
def setup(self):
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,44 +0,0 @@
|
||||
From 6b4b361c8b4814160d6fab2fb447f28957977e95 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Fri, 27 Nov 2015 12:43:33 +0100
|
||||
Subject: [PATCH] [ceph] Collect (parts of) /var/lib/ceph and /var/run/ceph
|
||||
|
||||
Collect the two directories without some forbidden paths.
|
||||
|
||||
Reorder self.add_forbidden_path(..) to have some logical ordering there.
|
||||
|
||||
Resolves: #693
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/ceph.py | 7 ++++++-
|
||||
1 file changed, 6 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/ceph.py b/sos/plugins/ceph.py
|
||||
index 6ccb930..10fee88 100644
|
||||
--- a/sos/plugins/ceph.py
|
||||
+++ b/sos/plugins/ceph.py
|
||||
@@ -40,6 +40,8 @@ class Ceph(Plugin, RedHatPlugin, UbuntuPlugin):
|
||||
self.add_copy_spec([
|
||||
"/etc/ceph/",
|
||||
"/var/log/ceph/",
|
||||
+ "/var/lib/ceph/",
|
||||
+ "/var/run/ceph/",
|
||||
"/etc/calamari/",
|
||||
"/var/log/calamari",
|
||||
"/var/log/radosgw"
|
||||
@@ -58,7 +60,10 @@ class Ceph(Plugin, RedHatPlugin, UbuntuPlugin):
|
||||
])
|
||||
|
||||
self.add_forbidden_path("/etc/ceph/*keyring")
|
||||
- self.add_forbidden_path("/var/lib/ceph/*/*keyring")
|
||||
self.add_forbidden_path("/var/lib/ceph/*keyring")
|
||||
+ self.add_forbidden_path("/var/lib/ceph/*/*keyring")
|
||||
+ self.add_forbidden_path("/var/lib/ceph/*/*/*keyring")
|
||||
+ self.add_forbidden_path("/var/lib/ceph/osd/*")
|
||||
+ self.add_forbidden_path("/var/lib/ceph/osd/mon/*")
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
2.4.3
|
||||
|
@ -1,64 +0,0 @@
|
||||
From b6e6a4d1ce4beae74cb0123bd7c48d0828d120ec Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Sun, 29 Mar 2015 22:58:42 +0200
|
||||
Subject: [PATCH] [chrony] add chrony plugin
|
||||
|
||||
Resolves #539
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/chrony.py | 40 ++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 40 insertions(+)
|
||||
create mode 100644 sos/plugins/chrony.py
|
||||
|
||||
diff --git a/sos/plugins/chrony.py b/sos/plugins/chrony.py
|
||||
new file mode 100644
|
||||
index 0000000..d2404d4
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/chrony.py
|
||||
@@ -0,0 +1,40 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin
|
||||
+
|
||||
+
|
||||
+class Chrony(Plugin, RedHatPlugin):
|
||||
+ """Chrony clock (for Network time protocol)
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = "chrony"
|
||||
+ profiles = ('system', 'services')
|
||||
+
|
||||
+ packages = ('chrony',)
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec([
|
||||
+ "/etc/chrony.conf",
|
||||
+ "/var/lib/chrony/drift"
|
||||
+ ])
|
||||
+ self.add_cmd_output([
|
||||
+ "chronyc tracking",
|
||||
+ "chronyc sources",
|
||||
+ "chronyc sourcestats",
|
||||
+ "chronyc clients",
|
||||
+ "journalctl -u chronyd"
|
||||
+ ])
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,26 +0,0 @@
|
||||
commit 08121d877741e33333a1ae01280f6898d7d4ca15
|
||||
Author: Bryn M. Reeves <bmr@redhat.com>
|
||||
Date: Thu Dec 10 11:50:49 2015 +0000
|
||||
|
||||
[sosreport] clean up private temporary directory
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index fe251ed..bc7792a 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -1544,7 +1544,12 @@ class SoSReport(object):
|
||||
|
||||
self.policy.display_results(archive, directory, checksum)
|
||||
|
||||
- self.tempfile_util.clean()
|
||||
+ # clean up
|
||||
+ if self.tempfile_util:
|
||||
+ self.tempfile_util.clean()
|
||||
+ if self.tmpdir:
|
||||
+ rmtree(self.tmpdir)
|
||||
+
|
||||
return True
|
||||
|
||||
def verify_plugins(self):
|
@ -1,62 +0,0 @@
|
||||
From 0d2dd0d9ccc3242dd2dd4513924c8f308000242e Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Wed, 6 May 2015 15:47:07 -0400
|
||||
Subject: [PATCH] [cluster] enable crm_report password scrubbing
|
||||
|
||||
Default to specifying a password pattern of 'passw.*' when calling
|
||||
the crm_report script. This causes matching strings to be elided
|
||||
from the report data.
|
||||
|
||||
Since this scrubbing can affect the use of pacemaker state machine
|
||||
snapshots for debugging the behaviour is controlled by a new option
|
||||
that defaults to enabled: cluster.crm_scrub
|
||||
|
||||
This can be used to obtain an sosreport containing virgin crm_report
|
||||
data with no password scrubbing:
|
||||
|
||||
# sosreport -k cluster.crm_scrub=False
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/cluster.py | 14 +++++++++++---
|
||||
1 file changed, 11 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/cluster.py b/sos/plugins/cluster.py
|
||||
index 8dd9a4d..084c030 100644
|
||||
--- a/sos/plugins/cluster.py
|
||||
+++ b/sos/plugins/cluster.py
|
||||
@@ -25,10 +25,12 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
|
||||
plugin_name = 'cluster'
|
||||
profiles = ('cluster',)
|
||||
+
|
||||
option_list = [
|
||||
("gfs2lockdump", 'gather output of gfs2 lockdumps', 'slow', False),
|
||||
("crm_from", 'specify the start time for crm_report', 'fast', False),
|
||||
- ('lockdump', 'gather dlm lockdumps', 'slow', False)
|
||||
+ ('lockdump', 'gather dlm lockdumps', 'slow', False),
|
||||
+ ('crm_scrub', 'enable password scrubbing for crm_report', '', True),
|
||||
]
|
||||
|
||||
packages = [
|
||||
@@ -112,8 +114,14 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
"default" % self.get_option('crm_from'))
|
||||
|
||||
crm_dest = self.get_cmd_output_path(name='crm_report', make=False)
|
||||
- self.add_cmd_output('crm_report -S -d --dest %s --from "%s"'
|
||||
- % (crm_dest, crm_from))
|
||||
+ crm_scrub = '-p "passw.*"'
|
||||
+ if not self.get_option("crm_scrub"):
|
||||
+ crm_scrub = ''
|
||||
+ self._log_warn("scrubbing of crm passwords has been disabled:")
|
||||
+ self._log_warn("data collected by crm_report may contain"
|
||||
+ " sensitive values.")
|
||||
+ self.add_cmd_output('crm_report %s -S -d --dest %s --from "%s"'
|
||||
+ % (crm_scrub, crm_dest, crm_from))
|
||||
|
||||
def do_lockdump(self):
|
||||
if self._mount_debug():
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,31 +0,0 @@
|
||||
From 147c496d5b2a33b7534ac66dbfb7705ae7ccb7bd Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Wed, 11 Mar 2015 09:55:06 -0400
|
||||
Subject: [PATCH] [cluster] crm_report fails to run because dir already exists
|
||||
|
||||
Do not create directory for the destination path used by crm_report.
|
||||
|
||||
Resolves: rhbz#1200526
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/cluster.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/cluster.py b/sos/plugins/cluster.py
|
||||
index bd2cf8a..8dd9a4d 100644
|
||||
--- a/sos/plugins/cluster.py
|
||||
+++ b/sos/plugins/cluster.py
|
||||
@@ -111,7 +111,7 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
"crm_from parameter '%s' is not a valid date: using "
|
||||
"default" % self.get_option('crm_from'))
|
||||
|
||||
- crm_dest = self.get_cmd_output_path(name='crm_report')
|
||||
+ crm_dest = self.get_cmd_output_path(name='crm_report', make=False)
|
||||
self.add_cmd_output('crm_report -S -d --dest %s --from "%s"'
|
||||
% (crm_dest, crm_from))
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,188 +0,0 @@
|
||||
From bb1e81e0d3d738f2f333175fc32987ed473edd8d Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Fri, 6 Feb 2015 11:24:26 -0500
|
||||
Subject: [PATCH] [cluster] remove some files and commands that are no longer
|
||||
needed
|
||||
|
||||
Removed some of the files and commands that are no longer needed on
|
||||
RHEL6+. In addition, the gfs_lockdump option did not capture gfs2 lock
|
||||
dumps. The option is now called gfs2_lockdump and will mount the
|
||||
/sys/kernel/debug directory and the gfs2 lockdumps will be copied from
|
||||
that mount point.
|
||||
|
||||
In addition added a couple files that are needed for pacemaker/dlm.
|
||||
|
||||
Resolves: rhbz#1083656
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/cluster.py | 66 +++++++++++++++++++++++++++++---------------------
|
||||
1 file changed, 39 insertions(+), 27 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/cluster.py b/sos/plugins/cluster.py
|
||||
index 9b5eb22..a84d3e2 100644
|
||||
--- a/sos/plugins/cluster.py
|
||||
+++ b/sos/plugins/cluster.py
|
||||
@@ -14,18 +14,19 @@
|
||||
|
||||
from sos.plugins import Plugin, RedHatPlugin
|
||||
import re
|
||||
+import os.path
|
||||
from glob import glob
|
||||
from datetime import datetime, timedelta
|
||||
|
||||
|
||||
class Cluster(Plugin, RedHatPlugin):
|
||||
- """Red Hat Cluster Suite and GFS
|
||||
+ """Red Hat Cluster High Availability and GFS2
|
||||
"""
|
||||
|
||||
plugin_name = 'cluster'
|
||||
profiles = ('cluster',)
|
||||
option_list = [
|
||||
- ("gfslockdump", 'gather output of gfs lockdumps', 'slow', False),
|
||||
+ ("gfs2lockdump", 'gather output of gfs2 lockdumps', 'slow', False),
|
||||
("crm_from", 'specify the start time for crm_report', 'fast', False),
|
||||
('lockdump', 'gather dlm lockdumps', 'slow', False)
|
||||
]
|
||||
@@ -42,12 +43,16 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
|
||||
files = ["/etc/cluster/cluster.conf"]
|
||||
|
||||
+ debugfs_path = "/sys/kernel/debug"
|
||||
+ _debugfs_cleanup = False
|
||||
+
|
||||
def setup(self):
|
||||
|
||||
self.add_copy_spec([
|
||||
"/etc/cluster.conf",
|
||||
- "/etc/cluster.xml",
|
||||
"/etc/cluster",
|
||||
+ "/etc/sysconfig/dlm",
|
||||
+ "/etc/sysconfig/pacemaker",
|
||||
"/etc/sysconfig/cluster",
|
||||
"/etc/sysconfig/cman",
|
||||
"/etc/fence_virt.conf",
|
||||
@@ -56,12 +61,12 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
"/var/lib/luci/etc",
|
||||
"/var/log/cluster",
|
||||
"/var/log/luci",
|
||||
- "/etc/fence_virt.conf",
|
||||
"/sys/fs/gfs2/*/withdraw"
|
||||
])
|
||||
|
||||
- if self.get_option('gfslockdump'):
|
||||
- self.do_gfslockdump()
|
||||
+ if self.get_option('gfs2lockdump'):
|
||||
+ if self._mount_debug():
|
||||
+ self.add_copy_spec(["/sys/kernel/debug/gfs2/*"])
|
||||
|
||||
if self.get_option('lockdump'):
|
||||
self.do_lockdump()
|
||||
@@ -81,7 +86,6 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
"corosync-quorumtool -s",
|
||||
"corosync-cpgtool",
|
||||
"corosync-objctl",
|
||||
- "group_tool ls -g1",
|
||||
"gfs_control ls -n",
|
||||
"gfs_control dump",
|
||||
"fence_tool dump",
|
||||
@@ -108,26 +112,29 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
% (crm_dest, crm_from))
|
||||
|
||||
def do_lockdump(self):
|
||||
- dlm_tool = "dlm_tool ls"
|
||||
- result = self.call_ext_prog(dlm_tool)
|
||||
- if result['status'] != 0:
|
||||
- return
|
||||
-
|
||||
- lock_exp = r'^name\s+([^\s]+)$'
|
||||
- lock_re = re.compile(lock_exp, re.MULTILINE)
|
||||
- for lockspace in lock_re.findall(result['output']):
|
||||
- self.add_cmd_output(
|
||||
- "dlm_tool lockdebug -svw '%s'" % lockspace,
|
||||
- suggest_filename="dlm_locks_%s" % lockspace
|
||||
- )
|
||||
-
|
||||
- def do_gfslockdump(self):
|
||||
- mnt_exp = r'^\S+\s+([^\s]+)\s+gfs\s+.*$'
|
||||
- for mnt in self.do_regex_find_all(mnt_exp, "/proc/mounts"):
|
||||
- self.add_cmd_output(
|
||||
- "gfs_tool lockdump %s" % mnt,
|
||||
- suggest_filename="gfs_lockdump_" + self.mangle_command(mnt)
|
||||
- )
|
||||
+ if self._mount_debug():
|
||||
+ dlm_tool = "dlm_tool ls"
|
||||
+ result = self.call_ext_prog(dlm_tool)
|
||||
+ if result['status'] != 0:
|
||||
+ return
|
||||
+
|
||||
+ lock_exp = r'^name\s+([^\s]+)$'
|
||||
+ lock_re = re.compile(lock_exp, re.MULTILINE)
|
||||
+ for lockspace in lock_re.findall(result['output']):
|
||||
+ self.add_cmd_output(
|
||||
+ "dlm_tool lockdebug -svw '%s'" % lockspace,
|
||||
+ suggest_filename="dlm_locks_%s" % lockspace
|
||||
+ )
|
||||
+
|
||||
+ def _mount_debug(self):
|
||||
+ if not os.path.ismount(self.debugfs_path):
|
||||
+ self._debugfs_cleanup = True
|
||||
+ r = self.call_ext_prog("mount -t debugfs debugfs %s"
|
||||
+ % self.debugfs_path)
|
||||
+ if r['status'] != 0:
|
||||
+ self._log_error("debugfs not mounted and mount attempt failed")
|
||||
+ self._debugfs_cleanup = False
|
||||
+ return os.path.ismount(self.debugfs_path)
|
||||
|
||||
def postproc(self):
|
||||
for cluster_conf in glob("/etc/cluster/cluster.conf*"):
|
||||
@@ -148,6 +155,11 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
r"(.*fence.*\.passwd=)(.*)",
|
||||
r"\1******"
|
||||
)
|
||||
+ if self._debugfs_cleanup and os.path.ismount(self.debugfs_path):
|
||||
+ r = self.call_ext_prog("umount %s" % self.debugfs_path)
|
||||
+ if r['status'] != 0:
|
||||
+ self._log_error("could not unmount %s" % self.debugfs_path)
|
||||
+
|
||||
return
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 55aebeabb2d2c87c695041cff426afaa6bd2808a Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Tue, 17 Feb 2015 13:54:01 -0500
|
||||
Subject: [PATCH] [cluster] add a couple pcs commands to the cluster plugin
|
||||
|
||||
There are 3 pcs commands added to cluster plugin to get
|
||||
information about the status of pacemaker cluster.
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/cluster.py | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/cluster.py b/sos/plugins/cluster.py
|
||||
index 7aeed44..bd2cf8a 100644
|
||||
--- a/sos/plugins/cluster.py
|
||||
+++ b/sos/plugins/cluster.py
|
||||
@@ -92,7 +92,10 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
"fence_tool dump",
|
||||
"dlm_tool dump",
|
||||
"dlm_tool ls -n",
|
||||
- "mkqdisk -L"
|
||||
+ "mkqdisk -L",
|
||||
+ "pcs config",
|
||||
+ "pcs status",
|
||||
+ "pcs property list --all"
|
||||
])
|
||||
|
||||
# crm_report needs to be given a --from "YYYY-MM-DD HH:MM:SS" start
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,33 +0,0 @@
|
||||
From f5211fd8725629e23a3a0f802bd6e635290dab36 Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 10:42:39 -0500
|
||||
Subject: [PATCH] [cluster] add luci to packages for standalone luci servers
|
||||
|
||||
A host with only luci package installed would not collect luci logs
|
||||
because the cluster plugin would not run since none of the packages
|
||||
were found. This patch adds luci to the package set required for the
|
||||
plugin to run.
|
||||
|
||||
Resolves: rhbz#1171186
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/cluster.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/cluster.py b/sos/plugins/cluster.py
|
||||
index a84d3e2..7aeed44 100644
|
||||
--- a/sos/plugins/cluster.py
|
||||
+++ b/sos/plugins/cluster.py
|
||||
@@ -32,6 +32,7 @@ class Cluster(Plugin, RedHatPlugin):
|
||||
]
|
||||
|
||||
packages = [
|
||||
+ "luci",
|
||||
"ricci",
|
||||
"corosync",
|
||||
"openais",
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,65 +0,0 @@
|
||||
From 4edd40d584879ebd81bce88f04bc294789175eb0 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 7 Oct 2015 12:56:55 +0100
|
||||
Subject: [PATCH 1/2] [kubernetes] do not reverse-sort journald logs
|
||||
|
||||
Drop the '-r' when obtaining logs from journald to be consistent
|
||||
with other plugins: users can sort log entries in whatever order
|
||||
they prefer on the analysis system.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kubernetes.py | 10 +++++-----
|
||||
1 file changed, 5 insertions(+), 5 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/kubernetes.py b/sos/plugins/kubernetes.py
|
||||
index 59b6b53..3399b2e 100644
|
||||
--- a/sos/plugins/kubernetes.py
|
||||
+++ b/sos/plugins/kubernetes.py
|
||||
@@ -35,11 +35,11 @@ class kubernetes(Plugin, RedHatPlugin):
|
||||
self.add_cmd_output("kubectl get -o json services")
|
||||
self.add_cmd_output("kubectl get -o json replicationController")
|
||||
self.add_cmd_output("kubectl get -o json events")
|
||||
- self.add_cmd_output("journalctl -r -u kubelet")
|
||||
- self.add_cmd_output("journalctl -r -u kube-apiserver")
|
||||
- self.add_cmd_output("journalctl -r -u kube-controller-manager")
|
||||
- self.add_cmd_output("journalctl -r -u kube-scheduler")
|
||||
- self.add_cmd_output("journalctl -r -u kube-proxy")
|
||||
+ self.add_cmd_output("journalctl -u kubelet")
|
||||
+ self.add_cmd_output("journalctl -u kube-apiserver")
|
||||
+ self.add_cmd_output("journalctl -u kube-controller-manager")
|
||||
+ self.add_cmd_output("journalctl -u kube-scheduler")
|
||||
+ self.add_cmd_output("journalctl -u kube-proxy")
|
||||
|
||||
if self.get_option('podslog'):
|
||||
result = self.get_command_output("kubectl get pods")
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 3ce984a7d220669eaf2e6c08d983679183fb55fe Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 7 Oct 2015 13:03:45 +0100
|
||||
Subject: [PATCH 2/2] [docker] collect journald logs for docker unit
|
||||
|
||||
Fixes: #609.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/docker.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/docker.py b/sos/plugins/docker.py
|
||||
index c5ea8a0..aab558d 100644
|
||||
--- a/sos/plugins/docker.py
|
||||
+++ b/sos/plugins/docker.py
|
||||
@@ -34,6 +34,7 @@ class Docker(Plugin):
|
||||
])
|
||||
|
||||
self.add_cmd_output([
|
||||
+ "journalctl -u docker",
|
||||
"{0} info".format(self.docker_bin),
|
||||
"{0} ps".format(self.docker_bin),
|
||||
"{0} images".format(self.docker_bin)
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,35 +0,0 @@
|
||||
From 77ea53cf7c13c59c2a1f4608d59e1b9e8f4da835 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 15 Oct 2014 15:57:47 +0100
|
||||
Subject: [PATCH] [corosync] add postprocessing for corosync-objctl output
|
||||
|
||||
The corosync-objctl command may include fence device passwords in
|
||||
its output. Remove them with the same postprocessing regex as the
|
||||
cluster plugin uses.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/corosync.py | 7 +++++++
|
||||
1 file changed, 7 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/corosync.py b/sos/plugins/corosync.py
|
||||
index 2cd22c3..db9b547 100644
|
||||
--- a/sos/plugins/corosync.py
|
||||
+++ b/sos/plugins/corosync.py
|
||||
@@ -40,6 +40,13 @@ class Corosync(Plugin):
|
||||
])
|
||||
self.call_ext_prog("killall -USR2 corosync")
|
||||
|
||||
+ def postproc(self):
|
||||
+ self.do_cmd_output_sub(
|
||||
+ "corosync-objctl",
|
||||
+ r"(.*fence.*\.passwd=)(.*)",
|
||||
+ r"\1******"
|
||||
+ )
|
||||
+
|
||||
|
||||
class RedHatCorosync(Corosync, RedHatPlugin):
|
||||
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,42 +0,0 @@
|
||||
From 12ec2a4643c844a7a9bf46f3d9557e38f0ae7403 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 19 Jan 2015 18:47:03 +0000
|
||||
Subject: [PATCH] [ctdb] fix RedHatPlugin tagging use
|
||||
|
||||
The generic Ctdb class is tagged with RedHatPlugin. This causes
|
||||
the RedHatCtdb to not execute (since only the first matching class
|
||||
is instantiated).
|
||||
|
||||
Remove the RedHatPlugin tag from the Ctdb class and fix the
|
||||
former's call to Ctdb.setup().
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/ctdb.py | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/ctdb.py b/sos/plugins/ctdb.py
|
||||
index 443181c..e1bd78e 100644
|
||||
--- a/sos/plugins/ctdb.py
|
||||
+++ b/sos/plugins/ctdb.py
|
||||
@@ -16,7 +16,7 @@
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
|
||||
|
||||
-class Ctdb(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+class Ctdb(Plugin, DebianPlugin, UbuntuPlugin):
|
||||
"""Samba Clustered TDB
|
||||
"""
|
||||
packages = ('ctdb',)
|
||||
@@ -45,7 +45,7 @@ class Ctdb(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
|
||||
class RedHatCtdb(Ctdb, RedHatPlugin):
|
||||
def setup(self):
|
||||
- super(RedHatCtdb, self).super()
|
||||
+ super(RedHatCtdb, self).setup()
|
||||
self.add_copy_spec("/etc/sysconfig/ctdb")
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,60 +0,0 @@
|
||||
From 081e1ce9f9ad7570d057babd81b474fd407149d7 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 9 Dec 2014 17:32:45 +0000
|
||||
Subject: [PATCH] [sosreport] disable the 'zip' compression type
|
||||
|
||||
The Zip archive format is little used and has been broken for
|
||||
some time:
|
||||
|
||||
Unexpected exception setting up archive:
|
||||
Traceback (most recent call last):
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1092, in prework
|
||||
self._set_archive()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 679, in _set_archive
|
||||
self.archive = ZipFileArchive(archive_name, self.tmpdir)
|
||||
TypeError: __init__() takes exactly 2 arguments (3 given)
|
||||
__init__() takes exactly 2 arguments (3 given)
|
||||
|
||||
Remove it from the allowed options list for --compression-type.
|
||||
|
||||
The supporting Archive classes can be removed in a separate commit.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 6 ++----
|
||||
1 file changed, 2 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 99b5f47..a697380 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -599,7 +599,7 @@ class SoSOptions(object):
|
||||
dest="report",
|
||||
help="Disable HTML/XML reporting", default=False)
|
||||
parser.add_option("-z", "--compression-type", dest="compression_type",
|
||||
- help="compression technology to use [auto, zip, "
|
||||
+ help="compression technology to use [auto, "
|
||||
"gzip, bzip2, xz] (default=auto)",
|
||||
default="auto")
|
||||
|
||||
@@ -675,8 +675,6 @@ class SoSReport(object):
|
||||
if self.opts.compression_type == 'auto':
|
||||
auto_archive = self.policy.get_preferred_archive()
|
||||
self.archive = auto_archive(archive_name, self.tmpdir)
|
||||
- elif self.opts.compression_type == 'zip':
|
||||
- self.archive = ZipFileArchive(archive_name, self.tmpdir)
|
||||
else:
|
||||
self.archive = TarFileArchive(archive_name, self.tmpdir)
|
||||
self.archive.set_debug(True if self.opts.debug else False)
|
||||
@@ -1080,7 +1078,7 @@ class SoSReport(object):
|
||||
self.policy.pre_work()
|
||||
try:
|
||||
self.ui_log.info(_(" Setting up archive ..."))
|
||||
- compression_methods = ('auto', 'zip', 'bzip2', 'gzip', 'xz')
|
||||
+ compression_methods = ('auto', 'bzip2', 'gzip', 'xz')
|
||||
method = self.opts.compression_type
|
||||
if method not in compression_methods:
|
||||
compression_list = ', '.join(compression_methods)
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,91 +0,0 @@
|
||||
From 0be76caf77b53ce2726cb419262ceb8f52081c9e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 17 Dec 2014 13:01:03 +0000
|
||||
Subject: [PATCH] [docs] update man page for new options
|
||||
|
||||
The man page was missing:
|
||||
|
||||
--verify
|
||||
--all-logs
|
||||
--log-size
|
||||
--plugin-option
|
||||
|
||||
And listed the old '--ticket' (now --ticket-number).
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
man/en/sosreport.1 | 29 +++++++++++++++++++++++++----
|
||||
1 file changed, 25 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/man/en/sosreport.1 b/man/en/sosreport.1
|
||||
index 88589cf..1066b1d 100644
|
||||
--- a/man/en/sosreport.1
|
||||
+++ b/man/en/sosreport.1
|
||||
@@ -8,14 +8,19 @@ sosreport \- Collect and package diagnostic and support data
|
||||
[-e|--enable-plugins plugin-names]\fR
|
||||
[-o|--only-plugins plugin-names]\fR
|
||||
[-a|--alloptions] [-v|--verbose]\fR
|
||||
+ [-k plug.opt|--plugin-option plug.opt]\fR
|
||||
[--no-report] [--config-file conf]\fR
|
||||
[--batch] [--build] [--debug]\fR
|
||||
[--name name] [--case-id id] [--ticket-number nr]
|
||||
[--tmp-dir directory]\fR
|
||||
[-p|--profile profile-name]\fR
|
||||
[--list-profiles]\fR
|
||||
+ [--verify]\fR
|
||||
+ [--log-size]\fR
|
||||
+ [--all-logs]\fR
|
||||
[-z|--compression-type method]\fR
|
||||
- [--help]\fR
|
||||
+ [-h|--help]\fR
|
||||
+
|
||||
.SH DESCRIPTION
|
||||
\fBsosreport\fR generates an archive of configuration and diagnostic
|
||||
information from the running system. The archive may be stored locally
|
||||
@@ -46,7 +51,7 @@ Enable the specified plugin(s) only (all other plugins should be
|
||||
disabled). Multiple plugins may be specified by repeating the option
|
||||
or as a comma-separated list.
|
||||
.TP
|
||||
-.B \-k PLUGNAME.PLUGOPT[=VALUE]
|
||||
+.B \-k PLUGNAME.PLUGOPT[=VALUE], \--plugin-option=PLUGNAME.PLUGOPT[=VALUE]
|
||||
Specify plug-in options. The option PLUGOPT is enabled, or set to the
|
||||
specified value in the plug-in PLUGNAME.
|
||||
.TP
|
||||
@@ -81,6 +86,22 @@ profiles include: boot, cluster, desktop, debug, hardware, identity,
|
||||
network, openstack, packagemanager, security, services, storage,
|
||||
sysmgmt, system, performance, virt, and webserver.
|
||||
.TP
|
||||
+.B \--verify
|
||||
+Instructs plugins to perform plugin-specific verification during data
|
||||
+collection. This may include package manager verification, log integrity
|
||||
+testing or other plugin defined behaviour. Use of \--verify may cause
|
||||
+the time taken to generate a report to be considerably longer.
|
||||
+.TP
|
||||
+.B \--log-size
|
||||
+Places a global limit on the size of any collected set of logs. The
|
||||
+limit is applied separately for each set of logs collected by any
|
||||
+plugin.
|
||||
+.TP
|
||||
+.B \--all-logs
|
||||
+Tell plugins to collect all possible log data ignoring any size limits
|
||||
+and including logs in non-default locations. This option may significantly
|
||||
+increase the size of reports.
|
||||
+.TP
|
||||
.B \-z, \--compression-type METHOD
|
||||
Override the default compression type specified by the active policy.
|
||||
.TP
|
||||
@@ -94,9 +115,9 @@ Specify a name to be used for the archive.
|
||||
.B \--case-id NUMBER
|
||||
Specify a case identifier to associate with the archive.
|
||||
Identifiers may include alphanumeric characters, commas and periods ('.').
|
||||
-Synonymous with \--ticket, \--ticket-number.
|
||||
+Synonymous with \--ticket-number.
|
||||
.TP
|
||||
-.B \--ticket, \--ticket-number NUMBER
|
||||
+.B \--ticket-number NUMBER
|
||||
Specify a ticket number or other identifier to associate with the archive.
|
||||
Identifiers may include alphanumeric characters, commas and periods ('.').
|
||||
Synonymous with \--case-id.
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,46 +0,0 @@
|
||||
From d19bc046d549aaf634314a257dd22623df731648 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 3 Mar 2015 14:54:48 +0000
|
||||
Subject: [PATCH] [networking] test nmcli status before using output
|
||||
|
||||
The networking module assumes that nmcli commands succeed if the
|
||||
results object is not None; this is not valid and will lead to
|
||||
errors in subsequent commands if the call returned an error
|
||||
message instead of the expected content:
|
||||
|
||||
[plugin:networking] collecting output of 'nmcli con show conf 'Error: nmcli (0.9.10.0) and NetworkManager (unknown) versions don't match. Force execution using --nocheck, but the results are unpredictable.''
|
||||
Traceback (most recent call last):
|
||||
File "/usr/sbin/sosreport", line 25, in <module>
|
||||
main(sys.argv[1:])
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1459, in main
|
||||
sos.execute()
|
||||
ValueError: No closing quotation
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/networking.py | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/networking.py b/sos/plugins/networking.py
|
||||
index 9f6ece0..ae6cb1b 100644
|
||||
--- a/sos/plugins/networking.py
|
||||
+++ b/sos/plugins/networking.py
|
||||
@@ -142,13 +142,13 @@ class Networking(Plugin):
|
||||
|
||||
nmcli_con_show_result = self.call_ext_prog(
|
||||
"nmcli --terse --fields NAME con show")
|
||||
- if nmcli_con_show_result:
|
||||
+ if nmcli_con_show_result['status'] == 0:
|
||||
for con in nmcli_con_show_result['output'].splitlines():
|
||||
self.add_cmd_output("nmcli con show conf '%s'" % con)
|
||||
|
||||
nmcli_dev_status_result = self.call_ext_prog(
|
||||
"nmcli --terse --fields DEVICE dev status")
|
||||
- if nmcli_dev_status_result:
|
||||
+ if nmcli_dev_status_result['status'] == 0:
|
||||
for dev in nmcli_dev_status_result['output'].splitlines():
|
||||
self.add_cmd_output("nmcli device show "+dev)
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,33 +0,0 @@
|
||||
From 6b43c42078604b0551923c2801108848e97ba3b9 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 14 Oct 2014 15:43:20 +0100
|
||||
Subject: [PATCH] [kpatch] do not try to read kpatch data if it could not be
|
||||
run
|
||||
|
||||
Everything the kpatch plugin does requires the list of available
|
||||
kpatch patches obtained from 'kpatch list'. If this fails return
|
||||
immediately from the setup method.
|
||||
|
||||
Fixes #417.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kpatch.py | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/kpatch.py b/sos/plugins/kpatch.py
|
||||
index 7909926..6ef557e 100644
|
||||
--- a/sos/plugins/kpatch.py
|
||||
+++ b/sos/plugins/kpatch.py
|
||||
@@ -27,6 +27,8 @@ class Kpatch(Plugin, RedHatPlugin):
|
||||
|
||||
def setup(self):
|
||||
kpatch_list = self.get_cmd_output_now("kpatch list")
|
||||
+ if not kpatch_list:
|
||||
+ return
|
||||
kpatches = open(kpatch_list, "r").read().splitlines()
|
||||
for patch in kpatches:
|
||||
if not re.match("^kpatch-.*\(.*\)", patch):
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,35 +0,0 @@
|
||||
From 61a5b47d4fe4fd47e759b9acc19483491ec17005 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Tue, 5 May 2015 13:50:55 +0200
|
||||
Subject: [PATCH] [hpasm] hpasmcli commands hang under timeout
|
||||
|
||||
When hpasmcli is run in a python Popen or system pipeline via the
|
||||
timeout command it hangs indefinitely.
|
||||
|
||||
Work around this temporarily by disabling the use of the timeout
|
||||
program (by passing a zero timeout value) when running this
|
||||
command.
|
||||
|
||||
Fixes: #559
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/hpasm.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/hpasm.py b/sos/plugins/hpasm.py
|
||||
index 4d5d158..4d70887 100644
|
||||
--- a/sos/plugins/hpasm.py
|
||||
+++ b/sos/plugins/hpasm.py
|
||||
@@ -30,6 +30,6 @@ class Hpasm(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
self.add_cmd_output([
|
||||
"hpasmcli -s 'show asr'",
|
||||
"hpasmcli -s 'show server'"
|
||||
- ])
|
||||
+ ], timeout=0)
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,84 +0,0 @@
|
||||
From c607cac7256ced5d1396ae61591f9eae4a9d385f Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Fri, 18 Sep 2015 09:25:39 +0200
|
||||
Subject: [PATCH] [sosreport] fix command-line report defaults
|
||||
|
||||
opts.report is True regardless of using --no-report option or not. That
|
||||
means the test "if not self.opts.report:" to decide generation of
|
||||
reports is evaluated to False every time and no report is generated any
|
||||
time.
|
||||
|
||||
This commit renames opts.report and SoSOptions._report to noreport (to
|
||||
get rid of the variable name confusion) and updates default value
|
||||
accordingly.
|
||||
|
||||
Resolves #625
|
||||
Closes #644
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Adam Stokes <adam.stokes@ubuntu.com>
|
||||
---
|
||||
sos/sosreport.py | 22 +++++++++++-----------
|
||||
1 file changed, 11 insertions(+), 11 deletions(-)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 02d8a32..a1f1b96 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -250,7 +250,7 @@ class SoSOptions(object):
|
||||
_list_profiles = False
|
||||
_config_file = ""
|
||||
_tmp_dir = ""
|
||||
- _report = True
|
||||
+ _noreport = False
|
||||
_sysroot = None
|
||||
_chroot = 'auto'
|
||||
_compression_type = 'auto'
|
||||
@@ -522,17 +522,17 @@ class SoSOptions(object):
|
||||
self._tmp_dir = value
|
||||
|
||||
@property
|
||||
- def report(self):
|
||||
+ def noreport(self):
|
||||
if self._options is not None:
|
||||
- return self._options.report
|
||||
- return self._report
|
||||
+ return self._options.noreport
|
||||
+ return self._noreport
|
||||
|
||||
- @report.setter
|
||||
- def report(self, value):
|
||||
+ @noreport.setter
|
||||
+ def noreport(self, value):
|
||||
self._check_options_initialized()
|
||||
if not isinstance(value, bool):
|
||||
- raise TypeError("SoSOptions.report expects a boolean")
|
||||
- self._report = value
|
||||
+ raise TypeError("SoSOptions.noreport expects a boolean")
|
||||
+ self._noreport = value
|
||||
|
||||
@property
|
||||
def sysroot(self):
|
||||
@@ -646,8 +646,8 @@ class SoSOptions(object):
|
||||
help="specify alternate temporary directory",
|
||||
default=None)
|
||||
parser.add_option("--no-report", action="store_true",
|
||||
- dest="report",
|
||||
- help="Disable HTML/XML reporting", default=False)
|
||||
+ dest="noreport",
|
||||
+ help="Disable HTML/XML reporting", default=False)
|
||||
parser.add_option("-s", "--sysroot", action="store", dest="sysroot",
|
||||
help="system root directory path (default='/')",
|
||||
default=None)
|
||||
@@ -1499,7 +1499,7 @@ class SoSReport(object):
|
||||
self.prework()
|
||||
self.setup()
|
||||
self.collect()
|
||||
- if not self.opts.report:
|
||||
+ if not self.opts.noreport:
|
||||
self.report()
|
||||
self.html_report()
|
||||
self.plain_report()
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,28 +0,0 @@
|
||||
From b43460ecaeb7e332a993fb6ea19f4808d759711f Mon Sep 17 00:00:00 2001
|
||||
From: Coty Sutherland <sutherland.coty@gmail.com>
|
||||
Date: Thu, 28 May 2015 10:22:39 -0400
|
||||
Subject: [PATCH] [apache] Added collection of conf.modules.d dir for httpd 2.4
|
||||
|
||||
Signed-off-by: Coty Sutherland <sutherland.coty@gmail.com>
|
||||
Signed-off-by: Adam Stokes <adam.stokes@ubuntu.com>
|
||||
---
|
||||
sos/plugins/apache.py | 3 ++-
|
||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/apache.py b/sos/plugins/apache.py
|
||||
index dc700cb..551b062 100644
|
||||
--- a/sos/plugins/apache.py
|
||||
+++ b/sos/plugins/apache.py
|
||||
@@ -34,7 +34,8 @@ class RedHatApache(Apache, RedHatPlugin):
|
||||
|
||||
self.add_copy_spec([
|
||||
"/etc/httpd/conf/httpd.conf",
|
||||
- "/etc/httpd/conf.d/*.conf"
|
||||
+ "/etc/httpd/conf.d/*.conf",
|
||||
+ "/etc/httpd/conf.modules.d/*.conf"
|
||||
])
|
||||
|
||||
self.add_forbidden_path("/etc/httpd/conf/password.conf")
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,53 +0,0 @@
|
||||
From 8eed8e33d1de2cd56a26fc7cc8a3ee25e8921319 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:24:39 +0000
|
||||
Subject: [PATCH] [infiniband] add opensm and infiniband-diags support
|
||||
|
||||
Collect opensm and rdma configuration and logs and output from
|
||||
the infiniband-diags commands.
|
||||
|
||||
Fixes #492.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/infiniband.py | 13 ++++++++++---
|
||||
1 file changed, 10 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/infiniband.py b/sos/plugins/infiniband.py
|
||||
index b0437d7..687b8d6 100644
|
||||
--- a/sos/plugins/infiniband.py
|
||||
+++ b/sos/plugins/infiniband.py
|
||||
@@ -23,20 +23,27 @@ class Infiniband(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
|
||||
plugin_name = 'infiniband'
|
||||
profiles = ('hardware',)
|
||||
- packages = ('libibverbs-utils',)
|
||||
+ packages = ('libibverbs-utils', 'opensm', 'rdma', 'infiniband-diags')
|
||||
|
||||
def setup(self):
|
||||
self.add_copy_spec([
|
||||
"/etc/ofed/openib.conf",
|
||||
- "/etc/ofed/opensm.conf"
|
||||
+ "/etc/ofed/opensm.conf",
|
||||
+ "/etc/rdma"
|
||||
])
|
||||
|
||||
+ self.add_copy_spec_limit("/var/log/opensm*",
|
||||
+ sizelimit=self.get_option("log_size"))
|
||||
+
|
||||
self.add_cmd_output([
|
||||
"ibv_devices",
|
||||
"ibv_devinfo",
|
||||
"ibstat",
|
||||
"ibstatus",
|
||||
- "ibhosts"
|
||||
+ "ibhosts",
|
||||
+ "iblinkinfo",
|
||||
+ "sminfo",
|
||||
+ "perfquery"
|
||||
])
|
||||
|
||||
return
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,35 +0,0 @@
|
||||
From f2d9cc519ac549b9e68e1301b67f1e9b789e2fd3 Mon Sep 17 00:00:00 2001
|
||||
From: Kamalesh Babulal <kamalesh@linux.vnet.ibm.com>
|
||||
Date: Fri, 3 Jul 2015 12:16:25 +0100
|
||||
Subject: [PATCH] iprconfig collects information, only if the underlying
|
||||
platform is 'ppc64'. Modify check_enabled() to regex match on arch(), instead
|
||||
of exact match of string.
|
||||
|
||||
This enables iprconfig to collect information on ppc64*
|
||||
platforms.
|
||||
|
||||
Signed-off-by: Kamalesh Babulal <kamalesh@linux.vnet.ibm.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/iprconfig.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
---
|
||||
sos/plugins/iprconfig.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/iprconfig.py b/sos/plugins/iprconfig.py
|
||||
index b77c192..687d8d5 100644
|
||||
--- a/sos/plugins/iprconfig.py
|
||||
+++ b/sos/plugins/iprconfig.py
|
||||
@@ -28,7 +28,7 @@ class IprConfig(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
|
||||
def check_enabled(self):
|
||||
arch = self.policy().get_arch()
|
||||
- return arch == "ppc64" and is_executable("iprconfig")
|
||||
+ return "ppc64" in arch and is_executable("iprconfig")
|
||||
|
||||
def setup(self):
|
||||
self.add_cmd_output([
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,135 +0,0 @@
|
||||
From ad464fcc0882f8764e8bbb091a91eeeb4a804ff3 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 15 Dec 2014 17:30:24 +0000
|
||||
Subject: [PATCH] [iprconfig] add plugin for IBM Power RAID adapters
|
||||
|
||||
Capture information which helps in better understanding of
|
||||
IBM Power RAID storage adapter configuration. Since iprconfig
|
||||
is specific to power adding the relevant commands in powerpc plugin.
|
||||
|
||||
Signed-off-by: Aruna Balakrishnaiah <aruna@linux.vnet.ibm.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/iprconfig.py | 110 +++++++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 110 insertions(+)
|
||||
create mode 100644 sos/plugins/iprconfig.py
|
||||
|
||||
diff --git a/sos/plugins/iprconfig.py b/sos/plugins/iprconfig.py
|
||||
new file mode 100644
|
||||
index 0000000..b77c192
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/iprconfig.py
|
||||
@@ -0,0 +1,110 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+# This plugin enables collection of logs for Power systems
|
||||
+
|
||||
+import os
|
||||
+import re
|
||||
+from sos.plugins import Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin
|
||||
+from sos.utilities import is_executable
|
||||
+
|
||||
+
|
||||
+class IprConfig(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
+ """IBM Power RAID storage adapter configuration information
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'iprconfig'
|
||||
+
|
||||
+ def check_enabled(self):
|
||||
+ arch = self.policy().get_arch()
|
||||
+ return arch == "ppc64" and is_executable("iprconfig")
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_cmd_output([
|
||||
+ "iprconfig -c show-config",
|
||||
+ "iprconfig -c show-alt-config",
|
||||
+ "iprconfig -c show-arrays",
|
||||
+ "iprconfig -c show-jbod-disks",
|
||||
+ "iprconfig -c show-ioas",
|
||||
+ ])
|
||||
+
|
||||
+ show_ioas = self.call_ext_prog("iprconfig -c show-ioas")
|
||||
+ if not show_ioas['status'] == 0:
|
||||
+ return
|
||||
+
|
||||
+ devices = []
|
||||
+ if show_ioas['output']:
|
||||
+ p = re.compile('sg')
|
||||
+ for line in show_ioas['output'].splitlines():
|
||||
+ temp = line.split(' ')
|
||||
+ # temp[0] holds the device name
|
||||
+ if p.search(temp[0]):
|
||||
+ devices.append(temp[0])
|
||||
+
|
||||
+ for device in devices:
|
||||
+ self.add_cmd_output("iprconfig -c show-details %s" % (device,))
|
||||
+
|
||||
+ # Look for IBM Power RAID enclosures (iprconfig lists them)
|
||||
+ show_config = self.call_ext_prog("iprconfig -c show-config")
|
||||
+ if not show_config['status'] == 0:
|
||||
+ return
|
||||
+
|
||||
+ if not show_config['output']:
|
||||
+ return
|
||||
+
|
||||
+# iprconfig -c show-config
|
||||
+# Name PCI/SCSI Location Description Status
|
||||
+# ------ ------------------------- ------------------------- -----------------
|
||||
+# 0005:60:00.0/0: PCI-E SAS RAID Adapter Operational
|
||||
+# sda 0005:60:00.0/0:0:0:0 Physical Disk Active
|
||||
+# sdb 0005:60:00.0/0:1:0:0 Physical Disk Active
|
||||
+# sdc 0005:60:00.0/0:2:0:0 Physical Disk Active
|
||||
+# sdd 0005:60:00.0/0:3:0:0 Physical Disk Active
|
||||
+# sde 0005:60:00.0/0:4:0:0 Physical Disk Active
|
||||
+# sdf 0005:60:00.0/0:5:0:0 Physical Disk Active
|
||||
+# 0005:60:00.0/0:8:0:0 Enclosure Active
|
||||
+# 0005:60:00.0/0:8:1:0 Enclosure Active
|
||||
+
|
||||
+ show_alt_config = "iprconfig -c show-alt-config"
|
||||
+ altconfig = self.call_ext_prog(show_alt_config)
|
||||
+ if not (altconfig['status'] == 0):
|
||||
+ return
|
||||
+
|
||||
+ if not altconfig['output']:
|
||||
+ return
|
||||
+
|
||||
+# iprconfig -c show-alt-config
|
||||
+# Name Resource Path/Address Vendor Product ID Status
|
||||
+# ------ -------------------------- -------- ---------------- -----------------
|
||||
+# sg9 0: IBM 57C7001SISIOA Operational
|
||||
+# sg0 0:0:0:0 IBM MBF2300RC Active
|
||||
+# sg1 0:1:0:0 IBM MBF2300RC Active
|
||||
+# sg2 0:2:0:0 IBM HUC106030CSS600 Active
|
||||
+# sg3 0:3:0:0 IBM HUC106030CSS600 Active
|
||||
+# sg4 0:4:0:0 IBM HUC106030CSS600 Active
|
||||
+# sg5 0:5:0:0 IBM HUC106030CSS600 Active
|
||||
+# sg7 0:8:0:0 IBM VSBPD6E4A 3GSAS Active
|
||||
+# sg8 0:8:1:0 IBM VSBPD6E4B 3GSAS Active
|
||||
+
|
||||
+ for line in show_config['output'].splitlines():
|
||||
+ if "Enclosure" in line:
|
||||
+ temp = re.split('\s+', line)
|
||||
+ # temp[1] holds the PCI/SCSI location
|
||||
+ pci, scsi = temp[1].split('/')
|
||||
+ for line in altconfig['output'].splitlines():
|
||||
+ if scsi in line:
|
||||
+ temp = line.split(' ')
|
||||
+ # temp[0] holds device name
|
||||
+ self.add_cmd_output("iprconfig -c "
|
||||
+ "query-ses-mode %s" % (temp[0],))
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,276 +0,0 @@
|
||||
From 9c1e646da727817de23c0b46a16885c03c7d4af1 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:34:50 +0000
|
||||
Subject: [PATCH] [kernel] collect /sys/firmware/acpi/*
|
||||
|
||||
Collect ACPI firmware tables and state from /sys.
|
||||
|
||||
Related: #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kernel.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/kernel.py b/sos/plugins/kernel.py
|
||||
index 877b2bb..6b93ab7 100644
|
||||
--- a/sos/plugins/kernel.py
|
||||
+++ b/sos/plugins/kernel.py
|
||||
@@ -49,6 +49,7 @@ class Kernel(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
"/sys/module/*/initstate",
|
||||
"/sys/module/*/refcnt",
|
||||
"/sys/module/*/taint",
|
||||
+ "/sys/firmware/acpi/*",
|
||||
"/proc/kallsyms",
|
||||
"/proc/buddyinfo",
|
||||
"/proc/slabinfo",
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 14686f55bd5bc7169eb06a871ada7bc3461b306b Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:43:08 +0000
|
||||
Subject: [PATCH] [memory] add ksm, swap and vmallocinfo data to plugin
|
||||
|
||||
Related: #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/memory.py | 11 +++++++++--
|
||||
1 file changed, 9 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/memory.py b/sos/plugins/memory.py
|
||||
index 0f20e99..1b27eba 100644
|
||||
--- a/sos/plugins/memory.py
|
||||
+++ b/sos/plugins/memory.py
|
||||
@@ -27,9 +27,16 @@ class Memory(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
"/proc/pci",
|
||||
"/proc/meminfo",
|
||||
"/proc/vmstat",
|
||||
+ "/proc/swaps",
|
||||
"/proc/slabinfo",
|
||||
- "/proc/pagetypeinfo"])
|
||||
+ "/proc/pagetypeinfo",
|
||||
+ "/proc/vmallocinfo",
|
||||
+ "/sys/kernel/mm/ksm"
|
||||
+ ])
|
||||
self.add_cmd_output("free", root_symlink="free")
|
||||
- self.add_cmd_output("free -m")
|
||||
+ self.add_cmd_output([
|
||||
+ "free -m",
|
||||
+ "swapon --show"
|
||||
+ ])
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 58a6d777d7b5fc4ef72e185ccd916110a73f48d2 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:47:14 +0000
|
||||
Subject: [PATCH] [block] collect /proc/diskstats
|
||||
|
||||
Related: #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/block.py | 6 +++---
|
||||
1 file changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/block.py b/sos/plugins/block.py
|
||||
index 8c73ef6..7984f0d 100644
|
||||
--- a/sos/plugins/block.py
|
||||
+++ b/sos/plugins/block.py
|
||||
@@ -24,8 +24,6 @@ class Block(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
profiles = ('storage', 'hardware')
|
||||
|
||||
def setup(self):
|
||||
- self.add_copy_spec("/proc/partitions")
|
||||
-
|
||||
self.add_cmd_output([
|
||||
"lsblk",
|
||||
"blkid -c /dev/null",
|
||||
@@ -36,7 +34,9 @@ class Block(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
# legacy location for non-/run distributions
|
||||
self.add_copy_spec([
|
||||
"/etc/blkid.tab",
|
||||
- "/run/blkid/blkid.tab"
|
||||
+ "/run/blkid/blkid.tab",
|
||||
+ "/proc/partitions",
|
||||
+ "/proc/diskstats"
|
||||
])
|
||||
|
||||
if os.path.isdir("/sys/block"):
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 4cc076409f65792c071e4cf027a78c847f7b5ff8 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:48:59 +0000
|
||||
Subject: [PATCH] [process] collect /proc/sched_debug
|
||||
|
||||
Related: #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/process.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/process.py b/sos/plugins/process.py
|
||||
index ab66322..cae8443 100644
|
||||
--- a/sos/plugins/process.py
|
||||
+++ b/sos/plugins/process.py
|
||||
@@ -23,6 +23,7 @@ class Process(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
profiles = ('system',)
|
||||
|
||||
def setup(self):
|
||||
+ self.add_copy_spec("/proc/sched_debug")
|
||||
self.add_cmd_output("ps auxwww", root_symlink="ps")
|
||||
self.add_cmd_output("pstree", root_symlink="pstree")
|
||||
self.add_cmd_output("lsof -b +M -n -l", root_symlink="lsof")
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From f3ec78df7060c4ac3cead99775f162a9b5d604f7 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 11 Feb 2015 20:06:59 +0000
|
||||
Subject: [PATCH] [kernel] collect directory listings for module updates
|
||||
|
||||
Related #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kernel.py | 14 +++++++++++++-
|
||||
1 file changed, 13 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/kernel.py b/sos/plugins/kernel.py
|
||||
index 6b93ab7..97300e2 100644
|
||||
--- a/sos/plugins/kernel.py
|
||||
+++ b/sos/plugins/kernel.py
|
||||
@@ -14,6 +14,7 @@
|
||||
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
import os
|
||||
+import glob
|
||||
|
||||
|
||||
class Kernel(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
@@ -36,10 +37,21 @@ class Kernel(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
except OSError:
|
||||
self._log_warn("could not list %s" % self.sys_module)
|
||||
|
||||
+ # find /lib/modules/*/{extras,updates,weak-updates} -ls
|
||||
+ extra_mod_patterns = [
|
||||
+ "/lib/modules/*/extra",
|
||||
+ "/lib/modules/*/updates",
|
||||
+ "/lib/modules/*/weak-updates",
|
||||
+ ]
|
||||
+ extra_mod_paths = []
|
||||
+ for pattern in extra_mod_patterns:
|
||||
+ extra_mod_paths.extend(glob.glob(pattern))
|
||||
+
|
||||
self.add_cmd_output([
|
||||
"dmesg",
|
||||
"sysctl -a",
|
||||
- "dkms status"
|
||||
+ "dkms status",
|
||||
+ "find %s -ls" % " ".join(extra_mod_paths)
|
||||
])
|
||||
|
||||
self.add_copy_spec([
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 895803a4c7d014b231cfe9804bd1c04fe37b5f5e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 11 Feb 2015 20:15:37 +0000
|
||||
Subject: [PATCH] [mpt] add plugin
|
||||
|
||||
Add a plugin to collect LSI Message Passing Technology driver
|
||||
status from /proc.
|
||||
|
||||
Related: #490.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mpt.py | 30 ++++++++++++++++++++++++++++++
|
||||
1 file changed, 30 insertions(+)
|
||||
create mode 100644 sos/plugins/mpt.py
|
||||
|
||||
diff --git a/sos/plugins/mpt.py b/sos/plugins/mpt.py
|
||||
new file mode 100644
|
||||
index 0000000..bb158cc
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/mpt.py
|
||||
@@ -0,0 +1,30 @@
|
||||
+# Copyright (C) 2015 Red Hat, Inc., Bryn M. Reeves <bmr@redhat.com>
|
||||
+
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class Mpt(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+ """ LSI Message Passing Technology
|
||||
+ """
|
||||
+ files = ('/proc/mpt',)
|
||||
+ profiles = ('storage', )
|
||||
+ plugin_name = 'mpt'
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec("/proc/mpt")
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From fc4e2be53eeeaa9ab0d4d089335bbeb007c1817e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 27 Aug 2015 18:07:46 +0100
|
||||
Subject: [PATCH] [memory] collect swapon --show output in bytes
|
||||
|
||||
Default is human readable:
|
||||
|
||||
$ swapon --show
|
||||
NAME TYPE SIZE USED PRIO
|
||||
/dev/dm-0 partition 1.5G 0B -1
|
||||
|
||||
Should be:
|
||||
|
||||
$ swapon --show --bytes
|
||||
NAME TYPE SIZE USED PRIO
|
||||
/dev/dm-0 partition 1610608640 0 -1
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/memory.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/memory.py b/sos/plugins/memory.py
|
||||
index 4c41896..710f73f 100644
|
||||
--- a/sos/plugins/memory.py
|
||||
+++ b/sos/plugins/memory.py
|
||||
@@ -36,7 +36,7 @@ class Memory(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
self.add_cmd_output("free", root_symlink="free")
|
||||
self.add_cmd_output([
|
||||
"free -m",
|
||||
- "swapon --show"
|
||||
+ "swapon --bytes --show"
|
||||
])
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,99 +0,0 @@
|
||||
From 3aabd18b2666dbbeb86871ac4b9f025e468d5818 Mon Sep 17 00:00:00 2001
|
||||
From: Christy Perez <christy@linux.vnet.ibm.com>
|
||||
Date: Tue, 16 Dec 2014 12:46:27 +0000
|
||||
Subject: [PATCH] [kimchi] add new plugin
|
||||
|
||||
This plugin gathers kimchi logs and configuration files.
|
||||
|
||||
Kimchi is an HTML5-based virtualization-management platform
|
||||
For more information, please visit:
|
||||
https://github.com/kimchi-project/kimchi/wiki
|
||||
|
||||
Signed-off-by: Christy Perez <christy@linux.vnet.ibm.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kimchi.py | 40 ++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 40 insertions(+)
|
||||
create mode 100644 sos/plugins/kimchi.py
|
||||
|
||||
diff --git a/sos/plugins/kimchi.py b/sos/plugins/kimchi.py
|
||||
new file mode 100644
|
||||
index 0000000..613b2c9
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/kimchi.py
|
||||
@@ -0,0 +1,40 @@
|
||||
+# Copyright IBM, Corp. 2014, Christy Perez <christy@linux.vnet.ibm.com>
|
||||
+
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin
|
||||
+
|
||||
+
|
||||
+class Kimchi(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
+ """kimchi-related information
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'kimchi'
|
||||
+ packages = ('kimchi',)
|
||||
+
|
||||
+ def setup(self):
|
||||
+ log_limit = self.get_option('log_size')
|
||||
+ if not self.get_option('all_logs'):
|
||||
+ self.add_copy_spec_limit('/var/log/kimchi/*.log',
|
||||
+ sizelimit=log_limit)
|
||||
+ self.add_copy_spec_limit('/etc/kimchi/kimchi*',
|
||||
+ sizelimit=log_limit)
|
||||
+ self.add_copy_spec_limit('/etc/kimchi/distros.d/*.json',
|
||||
+ sizelimit=log_limit)
|
||||
+ else:
|
||||
+ self.add_copy_spec('/var/log/kimchi/')
|
||||
+ self.add_copy_spec('/etc/kimchi/')
|
||||
+
|
||||
+# vim: expandtab tabstop=4 shiftwidth=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From cb9805d129827178df5b32fc681f629d4f40ac6e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:09:26 +0000
|
||||
Subject: [PATCH] [kimchi] fix collection of /etc/kimchi
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/kimchi.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/kimchi.py b/sos/plugins/kimchi.py
|
||||
index 613b2c9..efb469e 100644
|
||||
--- a/sos/plugins/kimchi.py
|
||||
+++ b/sos/plugins/kimchi.py
|
||||
@@ -26,6 +26,7 @@ class Kimchi(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
|
||||
def setup(self):
|
||||
log_limit = self.get_option('log_size')
|
||||
+ self.add_copy_spec('/etc/kimchi/')
|
||||
if not self.get_option('all_logs'):
|
||||
self.add_copy_spec_limit('/var/log/kimchi/*.log',
|
||||
sizelimit=log_limit)
|
||||
@@ -35,6 +36,5 @@ class Kimchi(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
sizelimit=log_limit)
|
||||
else:
|
||||
self.add_copy_spec('/var/log/kimchi/')
|
||||
- self.add_copy_spec('/etc/kimchi/')
|
||||
|
||||
# vim: expandtab tabstop=4 shiftwidth=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,25 +0,0 @@
|
||||
From b3faad3f82ee1f735e2221bb2f39b8b8aeaf0e86 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 3 Aug 2015 16:39:53 +0100
|
||||
Subject: [PATCH] [logs] fix reference to missing 'rsyslog_conf' variable
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/logs.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/logs.py b/sos/plugins/logs.py
|
||||
index 7957898..70ef537 100644
|
||||
--- a/sos/plugins/logs.py
|
||||
+++ b/sos/plugins/logs.py
|
||||
@@ -42,6 +42,7 @@ class Logs(Plugin):
|
||||
logs = self.do_regex_find_all("^\S+\s+(-?\/.*$)\s+", syslog_conf)
|
||||
if self.is_installed("rsyslog") \
|
||||
or os.path.exists("/etc/rsyslog.conf"):
|
||||
+ rsyslog_conf = self.join_sysroot("/etc/rsyslog.conf")
|
||||
logs += self.do_regex_find_all("^\S+\s+(-?\/.*$)\s+",
|
||||
rsyslog_conf)
|
||||
for i in logs:
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,37 +0,0 @@
|
||||
From f8ab86cbd2302812cd9160bec4478cb4f84e1442 Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Mon, 27 Apr 2015 10:28:34 -0400
|
||||
Subject: [PATCH] [mysql] Collect log file
|
||||
|
||||
When MariaDB is run under Pacemaker an OCF resource agent is used
|
||||
to start and stop the database. This configuration also overrides
|
||||
the log paths used for the database. In particular the mysqld.log
|
||||
is present at '/var/log/mysqld.log'.
|
||||
|
||||
Collect both paths as we do not currently detect whether we are
|
||||
running with an OCF agent or stand-alone.
|
||||
|
||||
Fixes: #554
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index 8dba204..aa8e9b9 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -37,6 +37,8 @@ class Mysql(Plugin):
|
||||
|
||||
self.add_copy_spec([
|
||||
self.mysql_cnf,
|
||||
+ # Required for MariaDB under pacemaker (MariaDB-Galera)
|
||||
+ "/var/log/mysqld.log",
|
||||
"/var/log/mysql/mysqld.log",
|
||||
"/var/log/mariadb/mariadb.log",
|
||||
])
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,39 +0,0 @@
|
||||
From db9ac3fb615b731be87b4116a8939105bf5ced56 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 23 Dec 2014 14:40:50 +0000
|
||||
Subject: [PATCH] [mysql] fix command-line dbpass handling
|
||||
|
||||
The logic for chosing between a command-line and environment
|
||||
variable passed password in the MySQL plugin was incorrect. This
|
||||
prevents a database dump from being collected when a password is
|
||||
given on the command line.
|
||||
|
||||
Altough use of the command line to pass authentication tokens
|
||||
is discouraged we should ensure the case works.
|
||||
|
||||
Fixes #456.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index d148472..edab6d0 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -45,9 +45,9 @@ class Mysql(Plugin):
|
||||
if self.get_option("dbdump"):
|
||||
dbuser = self.get_option("dbuser")
|
||||
dbpass = self.get_option("dbpass")
|
||||
- if dbpass is False and 'MYSQL_PWD' in os.environ:
|
||||
+ if 'MYSQL_PWD' in os.environ:
|
||||
dbpass = os.environ['MYSQL_PWD']
|
||||
- else:
|
||||
+ if not dbpass or dbpass is False:
|
||||
# no MySQL password
|
||||
return
|
||||
os.environ['MYSQL_PWD'] = dbpass
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,80 +0,0 @@
|
||||
From 7c12e6c994b3320ef57a13e06f5c445b6bca7935 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 22 Jan 2015 15:37:15 +0000
|
||||
Subject: [PATCH] [mysql] improve handling of dbuser, dbpass and MYSQL_PWD
|
||||
|
||||
Make sure that the mysql plugin behaves correctly when given
|
||||
different combinations of values for dbuser, dbpass and MYSQL_PWD.
|
||||
|
||||
* If dbdump is set then either dbpass or MYSQL_PWD must be set
|
||||
* Warn if dbdump is set and dbuser or dbpass is True/False/null
|
||||
(indicates either 'sosreport -a' or '-k mysql.dbpass')
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 24 ++++++++++++++++++++----
|
||||
1 file changed, 20 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index dd899a3..8dba204 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -24,35 +24,51 @@ class Mysql(Plugin):
|
||||
profiles = ('services',)
|
||||
mysql_cnf = "/etc/my.cnf"
|
||||
|
||||
+ pw_warn_text = " (password visible in process listings)"
|
||||
+
|
||||
option_list = [
|
||||
("dbuser", "username for database dumps", "", "mysql"),
|
||||
- ("dbpass", "password for database dumps", "", False),
|
||||
+ ("dbpass", "password for database dumps" + pw_warn_text, "", False),
|
||||
("dbdump", "collect a database dump", "", False)
|
||||
]
|
||||
|
||||
def setup(self):
|
||||
super(Mysql, self).setup()
|
||||
+
|
||||
self.add_copy_spec([
|
||||
self.mysql_cnf,
|
||||
"/var/log/mysql/mysqld.log",
|
||||
"/var/log/mariadb/mariadb.log",
|
||||
])
|
||||
+
|
||||
if self.get_option("all_logs"):
|
||||
self.add_copy_spec([
|
||||
"/var/log/mysql*",
|
||||
"/var/log/mariadb*"
|
||||
])
|
||||
+
|
||||
if self.get_option("dbdump"):
|
||||
+ msg = "database user name and password must be supplied"
|
||||
+ dbdump_err = "mysql.dbdump: %s" % msg
|
||||
+
|
||||
dbuser = self.get_option("dbuser")
|
||||
dbpass = self.get_option("dbpass")
|
||||
- if isinstance(dbuser, bool) or isinstance(dbpass, bool):
|
||||
- # sosreport -a
|
||||
- return
|
||||
+
|
||||
if 'MYSQL_PWD' in os.environ:
|
||||
dbpass = os.environ['MYSQL_PWD']
|
||||
+
|
||||
+ if dbuser is True or dbpass is True:
|
||||
+ # sosreport -a or -k mysql.{dbuser,dbpass}
|
||||
+ self.soslog.warning(dbdump_err)
|
||||
+ return
|
||||
+
|
||||
if not dbpass or dbpass is False:
|
||||
# no MySQL password
|
||||
+ self.soslog.warning(dbdump_err)
|
||||
return
|
||||
+
|
||||
+ # no need to save/restore as this variable is private to
|
||||
+ # the mysql plugin.
|
||||
os.environ['MYSQL_PWD'] = dbpass
|
||||
|
||||
opts = "--user=%s --all-databases" % dbuser
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,44 +0,0 @@
|
||||
From 05466cd6d9d70321fc7a0097334ef36af8dfeb43 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 20 Jan 2015 16:16:17 +0000
|
||||
Subject: [PATCH] [mysql] test for boolean values in user and password options
|
||||
|
||||
If sosreport is run with '-a' all options will be set to boolean
|
||||
True. This causes an exception if an attempt is made to set an
|
||||
environment variable to the option value:
|
||||
|
||||
Traceback (most recent call last):
|
||||
File "/usr/sbin/sosreport", line 25, in <module>
|
||||
main(sys.argv[1:])
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1435, in main
|
||||
sos.execute()
|
||||
TypeError: must be string, not bool
|
||||
|
||||
> /usr/lib64/python2.7/os.py(471)__setitem__()
|
||||
-> putenv(key, item)
|
||||
|
||||
Test both values with isinstance(val, bool) and do not attempt to
|
||||
collect a database dump if either is a boolean.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index edab6d0..dd899a3 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -45,6 +45,9 @@ class Mysql(Plugin):
|
||||
if self.get_option("dbdump"):
|
||||
dbuser = self.get_option("dbuser")
|
||||
dbpass = self.get_option("dbpass")
|
||||
+ if isinstance(dbuser, bool) or isinstance(dbpass, bool):
|
||||
+ # sosreport -a
|
||||
+ return
|
||||
if 'MYSQL_PWD' in os.environ:
|
||||
dbpass = os.environ['MYSQL_PWD']
|
||||
if not dbpass or dbpass is False:
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,42 +0,0 @@
|
||||
From 465746d768ce69684eee57eaa3509d9ae898fee2 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 17 Dec 2014 12:39:05 +0000
|
||||
Subject: [PATCH] [navicli] catch exception if input is unreadable
|
||||
|
||||
CLARiiON SP IP Address or [Enter] to exit: Traceback (most recent call last):
|
||||
File "/usr/sbin/sosreport", line 25, in <module>
|
||||
main(sys.argv[1:])
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1408, in main
|
||||
sos.execute()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1387, in execute
|
||||
self.setup()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1117, in setup
|
||||
plug.setup()
|
||||
File "/usr/lib/python2.7/site-packages/sos/plugins/navicli.py", line 72, in setup
|
||||
ans = input("CLARiiON SP IP Address or [Enter] to exit: ")
|
||||
EOFError: EOF when reading a line
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/navicli.py | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/navicli.py b/sos/plugins/navicli.py
|
||||
index 5175f89..3ee7d50 100644
|
||||
--- a/sos/plugins/navicli.py
|
||||
+++ b/sos/plugins/navicli.py
|
||||
@@ -69,7 +69,10 @@ class Navicli(Plugin, RedHatPlugin):
|
||||
CLARiiON_IP_address_list = []
|
||||
CLARiiON_IP_loop = "stay_in"
|
||||
while CLARiiON_IP_loop == "stay_in":
|
||||
- ans = input("CLARiiON SP IP Address or [Enter] to exit: ")
|
||||
+ try:
|
||||
+ ans = input("CLARiiON SP IP Address or [Enter] to exit: ")
|
||||
+ except:
|
||||
+ return
|
||||
if self.check_ext_prog("navicli -h %s getsptime" % (ans,)):
|
||||
CLARiiON_IP_address_list.append(ans)
|
||||
else:
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,57 +0,0 @@
|
||||
From b61a927bade2f183e7cf9404b11a93570fe8895b Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 10 Feb 2015 19:30:05 +0000
|
||||
Subject: [PATCH] [networking] additional ip, firewall and traffic shaping
|
||||
commands
|
||||
|
||||
Collect tc qdisc output, ipv4/6 routing policy, NOARP arp cache,
|
||||
iptables with --exact counters, and iproute2 configuration.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/networking.py | 10 ++++++++--
|
||||
1 file changed, 8 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/networking.py b/sos/plugins/networking.py
|
||||
index 8dfc0e6..9f6ece0 100644
|
||||
--- a/sos/plugins/networking.py
|
||||
+++ b/sos/plugins/networking.py
|
||||
@@ -82,7 +82,8 @@ class Networking(Plugin):
|
||||
"/etc/NetworkManager/NetworkManager.conf",
|
||||
"/etc/NetworkManager/system-connections",
|
||||
"/etc/dnsmasq*",
|
||||
- "/sys/class/net/*/flags"
|
||||
+ "/sys/class/net/*/flags",
|
||||
+ "/etc/iproute2"
|
||||
])
|
||||
self.add_forbidden_path("/proc/net/rpc/use-gss-proxy")
|
||||
self.add_forbidden_path("/proc/net/rpc/*/channel")
|
||||
@@ -98,19 +99,24 @@ class Networking(Plugin):
|
||||
"netstat -agn",
|
||||
"ip route show table all",
|
||||
"ip -6 route show table all",
|
||||
+ "ip -4 rule",
|
||||
+ "ip -6 rule",
|
||||
"ip link",
|
||||
"ip address",
|
||||
"ifenslave -a",
|
||||
"ip mroute show",
|
||||
"ip maddr show",
|
||||
"ip neigh show",
|
||||
+ "ip neigh show nud noarp",
|
||||
"ip netns",
|
||||
"nmcli general status",
|
||||
"nmcli connection show",
|
||||
"nmcli connection show active",
|
||||
"nmcli device status",
|
||||
"nmcli device show",
|
||||
- "biosdevname -d"
|
||||
+ "biosdevname -d",
|
||||
+ "tc -s qdisc show",
|
||||
+ "iptables -vnxL"
|
||||
])
|
||||
ip_link_result = self.call_ext_prog("ip -o link")
|
||||
if ip_link_result['status'] == 0:
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,28 +0,0 @@
|
||||
From 79d90ff649f89f784bdf41769f2326faa11cb7b0 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 17 Mar 2015 13:50:37 +0000
|
||||
Subject: [PATCH] [networking] re-add 'ip addr' with a root symlink
|
||||
|
||||
Commit e320ca8 accidentally deleted collection of "ip -o addr"
|
||||
and the root "ip_addr" symlink: put it back.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/networking.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/networking.py b/sos/plugins/networking.py
|
||||
index ae6cb1b..ae5ea71 100644
|
||||
--- a/sos/plugins/networking.py
|
||||
+++ b/sos/plugins/networking.py
|
||||
@@ -89,6 +89,7 @@ class Networking(Plugin):
|
||||
self.add_forbidden_path("/proc/net/rpc/*/channel")
|
||||
self.add_forbidden_path("/proc/net/rpc/*/flush")
|
||||
|
||||
+ self.add_cmd_output("ip -o addr", root_symlink = "ip_addr")
|
||||
self.add_cmd_output("route -n", root_symlink="route")
|
||||
self.collect_iptable("filter")
|
||||
self.collect_iptable("nat")
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,89 +0,0 @@
|
||||
From 3d4cf0365d520be81abfe3435fa9a8a56a933961 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 20 Oct 2014 09:31:32 +0100
|
||||
Subject: [PATCH 1/2] [mysql] obtain dbpass from the environment
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 13 ++++++++++---
|
||||
1 file changed, 10 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index 8bc6e72..1203f5c 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -13,7 +13,7 @@
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
-
|
||||
+import os
|
||||
|
||||
class Mysql(Plugin):
|
||||
"""MySQL and MariaDB RDBMS
|
||||
@@ -25,7 +25,7 @@ class Mysql(Plugin):
|
||||
|
||||
option_list = [
|
||||
("dbuser", "username for database dumps", "", "mysql"),
|
||||
- ("dbpass", "password for database dumps", "", ""),
|
||||
+ ("dbpass", "password for database dumps", "", False),
|
||||
("dbdump", "collect a database dump", "", False)
|
||||
]
|
||||
|
||||
@@ -44,7 +44,14 @@ class Mysql(Plugin):
|
||||
if self.get_option("dbdump"):
|
||||
dbuser = self.get_option("dbuser")
|
||||
dbpass = self.get_option("dbpass")
|
||||
- opts = "--user=%s --password=%s --all-databases" % (dbuser, dbpass)
|
||||
+ if dbpass == False and 'MYSQL_PWD' in os.environ:
|
||||
+ dbpass = os.environ['MYSQL_PWD']
|
||||
+ else:
|
||||
+ # no MySQL password
|
||||
+ return
|
||||
+ os.environ['MYSQL_PWD'] = dbpass
|
||||
+
|
||||
+ opts = "--user=%s --all-databases" % dbuser
|
||||
name = "mysqldump_--all-databases"
|
||||
self.add_cmd_output("mysqldump %s" % opts, suggest_filename=name)
|
||||
|
||||
--
|
||||
1.9.3
|
||||
|
||||
|
||||
From 6ce502113f550c027424fa477edc091283c32e50 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 20 Oct 2014 14:33:57 +0100
|
||||
Subject: [PATCH 2/2] [mysql] fix pep8 violations
|
||||
|
||||
The previous commit had a couple of pep8 errors that were fixed
|
||||
in the working tree but not added to the commit; fix them.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/mysql.py | 3 ++-
|
||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/mysql.py b/sos/plugins/mysql.py
|
||||
index 1203f5c..d148472 100644
|
||||
--- a/sos/plugins/mysql.py
|
||||
+++ b/sos/plugins/mysql.py
|
||||
@@ -15,6 +15,7 @@
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
import os
|
||||
|
||||
+
|
||||
class Mysql(Plugin):
|
||||
"""MySQL and MariaDB RDBMS
|
||||
"""
|
||||
@@ -44,7 +45,7 @@ class Mysql(Plugin):
|
||||
if self.get_option("dbdump"):
|
||||
dbuser = self.get_option("dbuser")
|
||||
dbpass = self.get_option("dbpass")
|
||||
- if dbpass == False and 'MYSQL_PWD' in os.environ:
|
||||
+ if dbpass is False and 'MYSQL_PWD' in os.environ:
|
||||
dbpass = os.environ['MYSQL_PWD']
|
||||
else:
|
||||
# no MySQL password
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,40 +0,0 @@
|
||||
From 3f8c4b658c5d702bde59bdd98cb114ea0064eae9 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 9 Oct 2014 17:07:38 +0100
|
||||
Subject: [PATCH] [openstack_neutron] fix legacy component detection test
|
||||
|
||||
Currently the Neutron plugin will assume it's running on a Neutron
|
||||
(rather than a legacy Quantum) installation if:
|
||||
|
||||
- '/etc/neutron' exists AND the user specifies quantum=True
|
||||
|
||||
Otherwise it's assumed to be a Quantum install. This is clearly
|
||||
broken; the sense of the 'openstack_neutron.quantum' part of the
|
||||
test should be inverted.
|
||||
|
||||
Fixes #420.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/openstack_neutron.py | 5 +----
|
||||
1 file changed, 1 insertion(+), 4 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/openstack_neutron.py b/sos/plugins/openstack_neutron.py
|
||||
index dba192e..d37430e 100644
|
||||
--- a/sos/plugins/openstack_neutron.py
|
||||
+++ b/sos/plugins/openstack_neutron.py
|
||||
@@ -40,10 +40,7 @@ class Neutron(Plugin):
|
||||
component_name = "neutron"
|
||||
|
||||
def setup(self):
|
||||
- if os.path.exists("/etc/neutron/") and \
|
||||
- self.get_option("quantum", False):
|
||||
- self.component_name = self.plugin_name
|
||||
- else:
|
||||
+ if not os.path.exists("/etc/neutron/") or self.get_option("quantum"):
|
||||
self.component_name = "quantum"
|
||||
|
||||
self.add_copy_spec([
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,357 +0,0 @@
|
||||
From 02ef6e2ba8d1a8fe4468aaa8be0ae88f8c74646a Mon Sep 17 00:00:00 2001
|
||||
From: Lee Yarwood <lyarwood@redhat.com>
|
||||
Date: Wed, 15 Jul 2015 15:42:50 +0100
|
||||
Subject: [PATCH] [openstack] Ensure openstack passwords and secrets are
|
||||
obfuscated.
|
||||
|
||||
- Add a postproc method to ceilometer, cinder, glance, hoirzon and swift.
|
||||
- Add missing keys to the remaining plugins.
|
||||
- Modify the regular expression used by all plugins to ignore commented
|
||||
out keys.
|
||||
- Modify all plugins to use do_path_regex_sub() to apply regex to all
|
||||
collected configuration files.
|
||||
|
||||
Resolves: #574
|
||||
|
||||
Signed-off-by: Lee Yarwood <lyarwood@redhat.com>
|
||||
---
|
||||
sos/plugins/openstack_ceilometer.py | 12 ++++++++++++
|
||||
sos/plugins/openstack_cinder.py | 17 +++++++++++++++++
|
||||
sos/plugins/openstack_glance.py | 10 ++++++++++
|
||||
sos/plugins/openstack_heat.py | 9 +++++++++
|
||||
sos/plugins/openstack_horizon.py | 9 +++++++++
|
||||
sos/plugins/openstack_keystone.py | 23 ++++++++---------------
|
||||
sos/plugins/openstack_neutron.py | 17 ++++++++---------
|
||||
sos/plugins/openstack_nova.py | 10 +++++-----
|
||||
sos/plugins/openstack_sahara.py | 11 +++++------
|
||||
sos/plugins/openstack_swift.py | 11 +++++++++++
|
||||
sos/plugins/openstack_trove.py | 19 ++++++-------------
|
||||
11 files changed, 100 insertions(+), 48 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/openstack_ceilometer.py b/sos/plugins/openstack_ceilometer.py
|
||||
index 7c11057..44a733b 100644
|
||||
--- a/sos/plugins/openstack_ceilometer.py
|
||||
+++ b/sos/plugins/openstack_ceilometer.py
|
||||
@@ -35,6 +35,18 @@ class OpenStackCeilometer(Plugin):
|
||||
"/var/log/ceilometer"
|
||||
])
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "admin_password", "connection_password", "host_password",
|
||||
+ "memcache_secret_key", "os_password", "password", "qpid_password",
|
||||
+ "rabbit_password", "readonly_user_password", "secret_key",
|
||||
+ "ssl_key_password", "telemetry_secret", "connection",
|
||||
+ "metering_secret"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/ceilometer/*", regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackCeilometer(OpenStackCeilometer, DebianPlugin,
|
||||
UbuntuPlugin):
|
||||
diff --git a/sos/plugins/openstack_cinder.py b/sos/plugins/openstack_cinder.py
|
||||
index 8588f6c..2f22b5a 100644
|
||||
--- a/sos/plugins/openstack_cinder.py
|
||||
+++ b/sos/plugins/openstack_cinder.py
|
||||
@@ -42,6 +42,23 @@ class OpenStackCinder(Plugin):
|
||||
if self.get_option("log"):
|
||||
self.add_copy_spec(["/var/log/cinder/"])
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "admin_password", "backup_tsm_password", "chap_password",
|
||||
+ "nas_password", "cisco_fc_fabric_password", "coraid_password",
|
||||
+ "eqlx_chap_password", "fc_fabric_password",
|
||||
+ "hitachi_auth_password", "hitachi_horcm_password",
|
||||
+ "hp3par_password", "hplefthand_password", "memcache_secret_key",
|
||||
+ "netapp_password", "netapp_sa_password", "nexenta_password",
|
||||
+ "password", "qpid_password", "rabbit_password", "san_password",
|
||||
+ "ssl_key_password", "vmware_host_password", "zadara_password",
|
||||
+ "zfssa_initiator_password", "connection", "zfssa_target_password",
|
||||
+ "os_privileged_user_password", "hmac_keys"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/cinder/*", regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackCinder(OpenStackCinder, DebianPlugin, UbuntuPlugin):
|
||||
|
||||
diff --git a/sos/plugins/openstack_glance.py b/sos/plugins/openstack_glance.py
|
||||
index 35c406a..33e69a9 100644
|
||||
--- a/sos/plugins/openstack_glance.py
|
||||
+++ b/sos/plugins/openstack_glance.py
|
||||
@@ -38,6 +38,16 @@ class OpenStackGlance(plugins.Plugin):
|
||||
"/var/log/glance/"
|
||||
])
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "admin_password", "password", "qpid_password", "rabbit_password",
|
||||
+ "s3_store_secret_key", "ssl_key_password", "connection",
|
||||
+ "vmware_server_password"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/glance/*", regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackGlance(OpenStackGlance,
|
||||
plugins.DebianPlugin,
|
||||
|
||||
diff --git a/sos/plugins/openstack_heat.py b/sos/plugins/openstack_heat.py
|
||||
index 70185db..b60285a 100644
|
||||
--- a/sos/plugins/openstack_heat.py
|
||||
+++ b/sos/plugins/openstack_heat.py
|
||||
@@ -36,6 +36,15 @@ class OpenStackHeat(Plugin):
|
||||
"/var/log/heat/"
|
||||
])
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "admin_password", "memcache_secret_key", "password", "connection",
|
||||
+ "qpid_password", "rabbit_password", "stack_domain_admin_password",
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/heat/*", regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStack(OpenStackHeat,
|
||||
plugins.DebianPlugin,
|
||||
|
||||
diff --git a/sos/plugins/openstack_horizon.py b/sos/plugins/openstack_horizon.py
|
||||
index 4c93cd9..5449ce9 100644
|
||||
--- a/sos/plugins/openstack_horizon.py
|
||||
+++ b/sos/plugins/openstack_horizon.py
|
||||
@@ -33,6 +33,15 @@ class OpenStackHorizon(Plugin):
|
||||
if self.get_option("log"):
|
||||
self.add_copy_spec("/var/log/horizon/")
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "SECRET_KEY", "EMAIL_HOST_PASSWORD"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/openstack-dashboard/*",
|
||||
+ regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackHorizon(OpenStackHorizon, DebianPlugin):
|
||||
|
||||
diff --git a/sos/plugins/openstack_keystone.py b/sos/plugins/openstack_keystone.py
|
||||
index 7d93d88..bff9ef6 100644
|
||||
--- a/sos/plugins/openstack_keystone.py
|
||||
+++ b/sos/plugins/openstack_keystone.py
|
||||
@@ -38,21 +38,14 @@ class OpenStackKeystone(Plugin):
|
||||
self.add_copy_spec("/var/log/keystone/")
|
||||
|
||||
def postproc(self):
|
||||
- self.do_file_sub('/etc/keystone/keystone.conf',
|
||||
- r"(?m)^(admin_password.*=)(.*)",
|
||||
- r"\1 ******")
|
||||
- self.do_file_sub('/etc/keystone/keystone.conf',
|
||||
- r"(?m)^(admin_token.*=)(.*)",
|
||||
- r"\1 ******")
|
||||
- self.do_file_sub('/etc/keystone/keystone.conf',
|
||||
- r"(?m)^(connection.*=.*mysql://)(.*)(:)(.*)(@)(.*)",
|
||||
- r"\1\2:******@\6")
|
||||
- self.do_file_sub('/etc/keystone/keystone.conf',
|
||||
- r"(?m)^(password.*=)(.*)",
|
||||
- r"\1 ******")
|
||||
- self.do_file_sub('/etc/keystone/keystone.conf',
|
||||
- r"(?m)^(ca_password.*=)(.*)",
|
||||
- r"\1 ******")
|
||||
+ protect_keys = [
|
||||
+ "password", "qpid_password", "rabbit_password", "ssl_key_password",
|
||||
+ "ldap_dns_password", "neutron_admin_password", "host_password",
|
||||
+ "connection", "admin_password", "admin_token", "ca_password"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/keystone/*", regexp, r"\1*********")
|
||||
|
||||
|
||||
class DebianOpenStackKeystone(OpenStackKeystone, DebianPlugin, UbuntuPlugin):
|
||||
diff --git a/sos/plugins/openstack_neutron.py b/sos/plugins/openstack_neutron.py
|
||||
index ab895c8..91ee9f5 100644
|
||||
--- a/sos/plugins/openstack_neutron.py
|
||||
+++ b/sos/plugins/openstack_neutron.py
|
||||
@@ -14,7 +14,6 @@
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
-import glob
|
||||
import os
|
||||
import re
|
||||
|
||||
@@ -55,16 +54,16 @@ class Neutron(Plugin):
|
||||
protect_keys = [
|
||||
"rabbit_password", "qpid_password", "nova_admin_password",
|
||||
"xenapi_connection_password", "password", "connection",
|
||||
- "admin_password", "metadata_proxy_shared_secret", "qpid_password",
|
||||
- "eapi_password", "crd_password", "primary_l3_host_password",
|
||||
- "serverauth", "ucsm_password", "ha_vrrp_auth_password",
|
||||
- "ssl_key_password", "nsx_password", "vcenter_password",
|
||||
- "edge_appliance_password", "tenant_admin_password", "apic_password"
|
||||
+ "admin_password", "metadata_proxy_shared_secret", "eapi_password",
|
||||
+ "crd_password", "primary_l3_host_password", "serverauth",
|
||||
+ "ucsm_password", "ha_vrrp_auth_password", "ssl_key_password",
|
||||
+ "nsx_password", "vcenter_password", "edge_appliance_password",
|
||||
+ "tenant_admin_password", "apic_password"
|
||||
]
|
||||
- regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
|
||||
- for config_file in glob.glob("/etc/%s/*" % self.component_name):
|
||||
- self.do_file_sub(config_file, regexp, r"\1*********")
|
||||
+ self.do_path_regex_sub("/etc/%s/*" % self.component_name,
|
||||
+ regexp, r"\1*********")
|
||||
|
||||
def netns_dumps(self):
|
||||
# It would've been beautiful if we could get parts of the networking
|
||||
diff --git a/sos/plugins/openstack_nova.py b/sos/plugins/openstack_nova.py
|
||||
index 20fb3a3..e226dac 100644
|
||||
--- a/sos/plugins/openstack_nova.py
|
||||
+++ b/sos/plugins/openstack_nova.py
|
||||
@@ -66,13 +66,13 @@ class OpenStackNova(Plugin):
|
||||
"ldap_dns_password", "neutron_admin_password", "rabbit_password",
|
||||
"qpid_password", "powervm_mgr_passwd", "virtual_power_host_pass",
|
||||
"xenapi_connection_password", "password", "host_password",
|
||||
- "vnc_password", "connection", "sql_connection", "admin_password"
|
||||
+ "vnc_password", "connection", "sql_connection", "admin_password",
|
||||
+ "connection_password", "memcache_secret_key", "s3_secret_key",
|
||||
+ "metadata_proxy_shared_secret"
|
||||
]
|
||||
|
||||
- regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
-
|
||||
- for conf_file in ["/etc/nova/nova.conf", "/etc/nova/api-paste.ini"]:
|
||||
- self.do_file_sub(conf_file, regexp, r"\1*********")
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/nova/*", regexp, r"\1*********")
|
||||
|
||||
|
||||
class DebianOpenStackNova(OpenStackNova, DebianPlugin, UbuntuPlugin):
|
||||
diff --git a/sos/plugins/openstack_sahara.py b/sos/plugins/openstack_sahara.py
|
||||
index 9d971ba..18e56d7 100644
|
||||
--- a/sos/plugins/openstack_sahara.py
|
||||
+++ b/sos/plugins/openstack_sahara.py
|
||||
@@ -33,14 +33,13 @@ class OpenStackSahara(Plugin):
|
||||
|
||||
def postproc(self):
|
||||
protect_keys = [
|
||||
- 'memcache_secret_key', 'qpid_password', 'rabbit_password',
|
||||
- 'admin_password', 'password', 'ssl_key_password',
|
||||
- 'admin_token', 'connection'
|
||||
+ "admin_password", "memcache_secret_key", "password",
|
||||
+ "qpid_password", "rabbit_password", "ssl_key_password",
|
||||
+ "xenapi_connection_password", "connection"
|
||||
]
|
||||
|
||||
- regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
-
|
||||
- self.do_file_sub('/etc/sahara/sahara.conf', regexp, r"\1*********")
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/sahara/*", regexp, r"\1*********")
|
||||
|
||||
|
||||
class DebianOpenStackSahara(OpenStackSahara, DebianPlugin, UbuntuPlugin):
|
||||
diff --git a/sos/plugins/openstack_swift.py b/sos/plugins/openstack_swift.py
|
||||
index f0f94bb..f337331 100644
|
||||
--- a/sos/plugins/openstack_swift.py
|
||||
+++ b/sos/plugins/openstack_swift.py
|
||||
@@ -33,6 +33,17 @@ class OpenStackSwift(Plugin):
|
||||
# Swift
|
||||
self.add_copy_spec("/etc/swift/")
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "ldap_dns_password", "neutron_admin_password", "rabbit_password",
|
||||
+ "qpid_password", "powervm_mgr_passwd", "virtual_power_host_pass",
|
||||
+ "xenapi_connection_password", "password", "host_password",
|
||||
+ "vnc_password", "connection", "sql_connection", "admin_password"
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/swift/*.conf*", regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackSwift(OpenStackSwift, DebianPlugin, UbuntuPlugin):
|
||||
|
||||
diff --git a/sos/plugins/openstack_trove.py b/sos/plugins/openstack_trove.py
|
||||
index 3b87506..566ae42 100644
|
||||
--- a/sos/plugins/openstack_trove.py
|
||||
+++ b/sos/plugins/openstack_trove.py
|
||||
@@ -14,6 +14,7 @@
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
+
|
||||
from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
|
||||
|
||||
@@ -34,21 +35,13 @@ class OpenStackTrove(Plugin):
|
||||
def postproc(self):
|
||||
|
||||
protect_keys = [
|
||||
- "dns_passkey", "nova_proxy_admin_pass", "rabbit_password",
|
||||
- "qpid_password", "connection", "sql_connection", "admin_password"
|
||||
- ]
|
||||
-
|
||||
- conf_list = [
|
||||
- '/etc/trove/trove.conf',
|
||||
- '/etc/trove/trove-conductor.conf',
|
||||
- '/etc/trove/trove-guestmanager.conf',
|
||||
- '/etc/trove/trove-taskmanager.conf'
|
||||
+ "default_password_length", "notifier_queue_password",
|
||||
+ "rabbit_password", "replication_password", "connection",
|
||||
+ "admin_password", "dns_passkey"
|
||||
]
|
||||
|
||||
- regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
-
|
||||
- for conf in conf_list:
|
||||
- self.do_file_sub(conf, regexp, r"\1*********")
|
||||
+ regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+ self.do_path_regex_sub("/etc/trove/*", regexp, r"\1*********")
|
||||
|
||||
|
||||
class DebianOpenStackTrove(OpenStackTrove, DebianPlugin, UbuntuPlugin):
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 08ba22aebb066de389cffed414a725e61a6b86d7 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Mon, 7 Sep 2015 09:54:17 +0200
|
||||
Subject: [PATCH] [openstack_neutron] obfuscate server_auth in restproxy.ini
|
||||
|
||||
server_auth secrets in /etc/neutron/plugins/ml2/restproxy.ini need to be
|
||||
obfuscated.
|
||||
|
||||
Resolves: #639
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/openstack_neutron.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/openstack_neutron.py b/sos/plugins/openstack_neutron.py
|
||||
index 91ee9f5..fc494d2 100644
|
||||
--- a/sos/plugins/openstack_neutron.py
|
||||
+++ b/sos/plugins/openstack_neutron.py
|
||||
@@ -58,7 +58,7 @@ class Neutron(Plugin):
|
||||
"crd_password", "primary_l3_host_password", "serverauth",
|
||||
"ucsm_password", "ha_vrrp_auth_password", "ssl_key_password",
|
||||
"nsx_password", "vcenter_password", "edge_appliance_password",
|
||||
- "tenant_admin_password", "apic_password"
|
||||
+ "tenant_admin_password", "apic_password", "server_auth"
|
||||
]
|
||||
regexp = r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,88 +0,0 @@
|
||||
From f1a7aea0f45485cbe12e95f38c6b0dc6ad12dd58 Mon Sep 17 00:00:00 2001
|
||||
From: Poornima <pkshiras@redhat.com>
|
||||
Date: Thu, 9 Apr 2015 18:47:58 +0530
|
||||
Subject: [PATCH] [openstack_sahara] add new plugin
|
||||
|
||||
Capture configuration and log data for the OpenStack Sahara project
|
||||
(formerly Savanna). Sahara is a tool to simplify the deployment of
|
||||
data-intensive applications in OpenStack environments.
|
||||
|
||||
Signed-off-by: Poornima M. Kshirsagar pkshiras@redhat.com
|
||||
Signed-off-by: Bryn M. Reeves bmr@redhat.com
|
||||
---
|
||||
sos/plugins/openstack_sahara.py | 63 +++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 63 insertions(+)
|
||||
create mode 100644 sos/plugins/openstack_sahara.py
|
||||
|
||||
diff --git a/sos/plugins/openstack_sahara.py b/sos/plugins/openstack_sahara.py
|
||||
new file mode 100644
|
||||
index 0000000..f0b95e4
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/openstack_sahara.py
|
||||
@@ -0,0 +1,63 @@
|
||||
+# Copyright (C) 2015 Red Hat, Inc.,Poornima M. Kshirsagar <pkshiras@redhat.com>
|
||||
+
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class OpenStackSahara(Plugin):
|
||||
+ """OpenStack Sahara"""
|
||||
+ plugin_name = 'openstack_sahara'
|
||||
+ profiles = ('openstack',)
|
||||
+
|
||||
+ option_list = [("log", "gathers openstack sahara logs", "slow", True)]
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec("/etc/sahara/")
|
||||
+ self.add_cmd_output("journalctl -u openstack-sahara-all")
|
||||
+
|
||||
+ if self.get_option("log"):
|
||||
+ self.add_copy_spec("/var/log/sahara/")
|
||||
+
|
||||
+
|
||||
+class DebianOpenStackSahara(OpenStackSahara, DebianPlugin, UbuntuPlugin):
|
||||
+ """OpenStackSahara related information for Debian based distributions."""
|
||||
+
|
||||
+ packages = (
|
||||
+ 'sahara-api',
|
||||
+ 'sahara-common',
|
||||
+ 'sahara-engine',
|
||||
+ 'python-sahara',
|
||||
+ 'python-saharaclient',
|
||||
+ )
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(DebianOpenStackSahara, self).setup()
|
||||
+
|
||||
+
|
||||
+class RedHatOpenStackSahara(OpenStackSahara, RedHatPlugin):
|
||||
+ """OpenStack sahara related information for Red Hat distributions."""
|
||||
+
|
||||
+ packages = (
|
||||
+ 'openstack-sahara',
|
||||
+ 'python-saharaclient'
|
||||
+ )
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(RedHatOpenStackSahara, self).setup()
|
||||
+ self.add_copy_spec("/etc/sudoers.d/sahara")
|
||||
+
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,72 +0,0 @@
|
||||
From 5917dbd8f38bab29de9e40d1135b0e9e85cb91bc Mon Sep 17 00:00:00 2001
|
||||
From: Lee Yarwood <lyarwood@redhat.com>
|
||||
Date: Tue, 7 Jul 2015 14:54:49 +0100
|
||||
Subject: [PATCH] [openstack_neutron] Obscure passwords and secrets
|
||||
|
||||
The following passwords and secrets are now obscured :
|
||||
|
||||
- rabbit_password
|
||||
- qpid_password
|
||||
- nova_admin_password
|
||||
- xenapi_connection_password
|
||||
- password
|
||||
- connection
|
||||
- admin_password
|
||||
- metadata_proxy_shared_secret
|
||||
- qpid_password
|
||||
- eapi_password
|
||||
- crd_password
|
||||
- primary_l3_host_password
|
||||
- serverauth
|
||||
- ucsm_password
|
||||
- ha_vrrp_auth_password
|
||||
- ssl_key_password
|
||||
- vcenter_password
|
||||
- edge_appliance_password
|
||||
- tenant_admin_password
|
||||
- apic_password
|
||||
|
||||
Fixes #594
|
||||
|
||||
Signed-off-by: Lee Yarwood <lyarwood@redhat.com>
|
||||
---
|
||||
sos/plugins/openstack_neutron.py | 16 ++++++++++++++++
|
||||
1 file changed, 16 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/openstack_neutron.py b/sos/plugins/openstack_neutron.py
|
||||
index 36de7cc..ab895c8 100644
|
||||
--- a/sos/plugins/openstack_neutron.py
|
||||
+++ b/sos/plugins/openstack_neutron.py
|
||||
@@ -14,6 +14,7 @@
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
+import glob
|
||||
import os
|
||||
import re
|
||||
|
||||
@@ -50,6 +51,21 @@ class Neutron(Plugin):
|
||||
|
||||
self.netns_dumps()
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ "rabbit_password", "qpid_password", "nova_admin_password",
|
||||
+ "xenapi_connection_password", "password", "connection",
|
||||
+ "admin_password", "metadata_proxy_shared_secret", "qpid_password",
|
||||
+ "eapi_password", "crd_password", "primary_l3_host_password",
|
||||
+ "serverauth", "ucsm_password", "ha_vrrp_auth_password",
|
||||
+ "ssl_key_password", "nsx_password", "vcenter_password",
|
||||
+ "edge_appliance_password", "tenant_admin_password", "apic_password"
|
||||
+ ]
|
||||
+ regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+
|
||||
+ for config_file in glob.glob("/etc/%s/*" % self.component_name):
|
||||
+ self.do_file_sub(config_file, regexp, r"\1*********")
|
||||
+
|
||||
def netns_dumps(self):
|
||||
# It would've been beautiful if we could get parts of the networking
|
||||
# plugin to run in different namespaces. There are a couple of options
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,97 +0,0 @@
|
||||
From 85d6ea5cdd32cf1b90a10ff0d50a14dcf24902f8 Mon Sep 17 00:00:00 2001
|
||||
From: Lee Yarwood <lyarwood@redhat.com>
|
||||
Date: Tue, 7 Apr 2015 18:26:42 +0100
|
||||
Subject: [PATCH] [openstack] New Openstack Trove (DBaaS) plugin.
|
||||
|
||||
https://wiki.openstack.org/wiki/Trove
|
||||
|
||||
Signed-off-by: Lee Yarwood <lyarwood@redhat.com>
|
||||
Signed-off-by: Adam Stokes <adam.stokes@ubuntu.com>
|
||||
---
|
||||
sos/plugins/openstack_trove.py | 74 ++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 74 insertions(+)
|
||||
create mode 100644 sos/plugins/openstack_trove.py
|
||||
|
||||
diff --git a/sos/plugins/openstack_trove.py b/sos/plugins/openstack_trove.py
|
||||
new file mode 100644
|
||||
index 0000000..7c8b661
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/openstack_trove.py
|
||||
@@ -0,0 +1,74 @@
|
||||
+# Copyright (C) 2015 Red Hat, Inc., Lee Yarwood <lyarwood@redhat.com>
|
||||
+
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class OpenStackTrove(Plugin):
|
||||
+ """OpenStack Trove
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = "openstack_trove"
|
||||
+ profiles = ('openstack',)
|
||||
+ option_list = [("log", "gathers openstack trove logs", "slow", True)]
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec('/etc/trove/')
|
||||
+
|
||||
+ if self.get_option('log'):
|
||||
+ self.add_copy_spec('/var/log/trove')
|
||||
+
|
||||
+ def postproc(self):
|
||||
+
|
||||
+ protect_keys = [
|
||||
+ "dns_passkey", "nova_proxy_admin_pass", "rabbit_password",
|
||||
+ "qpid_password", "connection", "sql_connection", "admin_password"
|
||||
+ ]
|
||||
+
|
||||
+ conf_list = [
|
||||
+ '/etc/trove/trove.conf',
|
||||
+ '/etc/trove/trove-conductor.conf',
|
||||
+ '/etc/trove/trove-guestmanager.conf',
|
||||
+ '/etc/trove/trove-taskmanager.conf'
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+
|
||||
+ for conf in conf_list:
|
||||
+ self.do_file_sub(conf, regexp, r"\1*********")
|
||||
+
|
||||
+
|
||||
+class DebianOpenStackTrove(OpenStackTrove, DebianPlugin, UbuntuPlugin):
|
||||
+
|
||||
+ packages = [
|
||||
+ 'python-trove',
|
||||
+ 'trove-common',
|
||||
+ 'trove-api',
|
||||
+ 'trove-taskmanager'
|
||||
+ ]
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(DebianOpenStackTrove, self).setup()
|
||||
+
|
||||
+
|
||||
+class RedHatOpenStackTrove(OpenStackTrove, RedHatPlugin):
|
||||
+
|
||||
+ packages = ['openstack-trove']
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(RedHatOpenStackTrove, self).setup()
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,158 +0,0 @@
|
||||
From 775b2bbfb28701ec2e687f0ece68a4558cef8740 Mon Sep 17 00:00:00 2001
|
||||
From: Lee Yarwood <lyarwood@redhat.com>
|
||||
Date: Tue, 17 Feb 2015 14:51:00 +0000
|
||||
Subject: [PATCH] [openvswitch] Capture additional output for OVS bridges.
|
||||
|
||||
This includes `dump-flows` and `fdb/show` output useful for debugging
|
||||
Openstack tenant and L3 networking issues.
|
||||
|
||||
Signed-off-by: Lee Yarwood <lyarwood@redhat.com>
|
||||
---
|
||||
sos/plugins/openvswitch.py | 8 ++++++++
|
||||
1 file changed, 8 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/openvswitch.py b/sos/plugins/openvswitch.py
|
||||
index 3611671..5200563 100644
|
||||
--- a/sos/plugins/openvswitch.py
|
||||
+++ b/sos/plugins/openvswitch.py
|
||||
@@ -32,6 +32,14 @@ class OpenVSwitch(Plugin):
|
||||
# to the Open vSwitch server, avoiding hangs when running sosreport.
|
||||
self.add_cmd_output("ovs-vsctl -t 5 show")
|
||||
|
||||
+ # Gather additional output for each OVS bridge on the host.
|
||||
+ br_list_result = self.call_ext_prog("ovs-vsctl list-br")
|
||||
+ if br_list_result['status'] == 0:
|
||||
+ for br in br_list_result['output'].splitlines():
|
||||
+ self.add_cmd_output("ovs-ofctl show %s" % br)
|
||||
+ self.add_cmd_output("ovs-ofctl dump-flows %s" % br)
|
||||
+ self.add_cmd_output("ovs-appctl fdb/show %s" % br)
|
||||
+
|
||||
|
||||
class RedHatOpenVSwitch(OpenVSwitch, RedHatPlugin):
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 21aff64a58a3e0f3fc5065b2e18ca3d489e16a51 Mon Sep 17 00:00:00 2001
|
||||
From: Flavio Leitner <fbl@redhat.com>
|
||||
Date: Fri, 19 Jun 2015 21:55:56 -0300
|
||||
Subject: [PATCH] [openvswitch] capture the logs
|
||||
|
||||
Both ovs-vswitchd.log and ovsdb-server.log are useful
|
||||
for troubleshooting.
|
||||
|
||||
Signed-off-by: Flavio Leitner <fbl@redhat.com>
|
||||
---
|
||||
sos/plugins/openvswitch.py | 4 ++++
|
||||
1 file changed, 4 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/openvswitch.py b/sos/plugins/openvswitch.py
|
||||
index fbf3a90..1d75608 100644
|
||||
--- a/sos/plugins/openvswitch.py
|
||||
+++ b/sos/plugins/openvswitch.py
|
||||
@@ -24,6 +24,10 @@ class OpenVSwitch(Plugin):
|
||||
profiles = ('network', 'virt')
|
||||
|
||||
def setup(self):
|
||||
+ self.add_copy_spec([
|
||||
+ "/var/log/openvswitch/ovs-vswitchd.log",
|
||||
+ "/var/log/openvswitch/ovsdb-server.log"
|
||||
+ ])
|
||||
# The '-s' option enables dumping of packet counters on the
|
||||
# ports.
|
||||
self.add_cmd_output("ovs-dpctl -s show")
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From f92205495113a8403066e911baeb4f5ee59c2101 Mon Sep 17 00:00:00 2001
|
||||
From: Flavio Leitner <fbl@redhat.com>
|
||||
Date: Fri, 19 Jun 2015 22:05:52 -0300
|
||||
Subject: [PATCH] [openvswitch] dump and capture the database
|
||||
|
||||
The database contains all the vswitch configuration and
|
||||
is essential to understand and replicate the environment.
|
||||
|
||||
Signed-off-by: Flavio Leitner <fbl@redhat.com>
|
||||
---
|
||||
sos/plugins/openvswitch.py | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/openvswitch.py b/sos/plugins/openvswitch.py
|
||||
index 1d75608..4dd15b2 100644
|
||||
--- a/sos/plugins/openvswitch.py
|
||||
+++ b/sos/plugins/openvswitch.py
|
||||
@@ -44,6 +44,9 @@ class OpenVSwitch(Plugin):
|
||||
self.add_cmd_output("ovs-ofctl dump-flows %s" % br)
|
||||
self.add_cmd_output("ovs-appctl fdb/show %s" % br)
|
||||
|
||||
+ # Gather the database.
|
||||
+ self.add_cmd_output("ovsdb-client dump")
|
||||
+
|
||||
|
||||
class RedHatOpenVSwitch(OpenVSwitch, RedHatPlugin):
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 4a57c54216242acb009fdb107d52712decfdfc1e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 6 Jul 2015 17:31:44 +0100
|
||||
Subject: [PATCH] [openvswitch] consolidate self.add_cmd_output() calls
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/openvswitch.py | 28 ++++++++++++++++------------
|
||||
1 file changed, 16 insertions(+), 12 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/openvswitch.py b/sos/plugins/openvswitch.py
|
||||
index 4dd15b2..8d691dc 100644
|
||||
--- a/sos/plugins/openvswitch.py
|
||||
+++ b/sos/plugins/openvswitch.py
|
||||
@@ -24,28 +24,32 @@ class OpenVSwitch(Plugin):
|
||||
profiles = ('network', 'virt')
|
||||
|
||||
def setup(self):
|
||||
+
|
||||
self.add_copy_spec([
|
||||
"/var/log/openvswitch/ovs-vswitchd.log",
|
||||
"/var/log/openvswitch/ovsdb-server.log"
|
||||
])
|
||||
- # The '-s' option enables dumping of packet counters on the
|
||||
- # ports.
|
||||
- self.add_cmd_output("ovs-dpctl -s show")
|
||||
|
||||
- # The '-t 5' adds an upper bound on how long to wait to connect
|
||||
- # to the Open vSwitch server, avoiding hangs when running sosreport.
|
||||
- self.add_cmd_output("ovs-vsctl -t 5 show")
|
||||
+ self.add_cmd_output([
|
||||
+ # The '-s' option enables dumping of packet counters on the
|
||||
+ # ports.
|
||||
+ "ovs-dpctl -s show",
|
||||
+ # The '-t 5' adds an upper bound on how long to wait to connect
|
||||
+ # to the Open vSwitch server, avoiding hangs when running sos.
|
||||
+ "ovs-vsctl -t 5 show",
|
||||
+ # Gather the database.
|
||||
+ "ovsdb-client dump"
|
||||
+ ])
|
||||
|
||||
# Gather additional output for each OVS bridge on the host.
|
||||
br_list_result = self.call_ext_prog("ovs-vsctl list-br")
|
||||
if br_list_result['status'] == 0:
|
||||
for br in br_list_result['output'].splitlines():
|
||||
- self.add_cmd_output("ovs-ofctl show %s" % br)
|
||||
- self.add_cmd_output("ovs-ofctl dump-flows %s" % br)
|
||||
- self.add_cmd_output("ovs-appctl fdb/show %s" % br)
|
||||
-
|
||||
- # Gather the database.
|
||||
- self.add_cmd_output("ovsdb-client dump")
|
||||
+ self.add_cmd_output([
|
||||
+ "ovs-ofctl show %s" % br,
|
||||
+ "ovs-ofctl dump-flows %s" % br,
|
||||
+ "ovs-appctl fdb/show %s" % br
|
||||
+ ])
|
||||
|
||||
|
||||
class RedHatOpenVSwitch(OpenVSwitch, RedHatPlugin):
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,36 +0,0 @@
|
||||
From ae98e1e119d2abfe771cfa6c286e2e4e177d86d7 Mon Sep 17 00:00:00 2001
|
||||
From: Jake Hunsaker <jhunsake@redhat.com>
|
||||
Date: Tue, 16 Dec 2014 11:26:50 -0500
|
||||
Subject: [PATCH] [ovirt] Collect engine tunables and domain information.
|
||||
|
||||
Currently sos does not capture engine-config values or domain information.
|
||||
We should capture both of these as the tunables can help in troubleshooting.
|
||||
|
||||
Similarly the domain information can help track AD/IPA issues.
|
||||
|
||||
These can currently be dug out from the DB dump, however having them in a plaintext
|
||||
file makes checking these much faster and easier, and a DB is not always available.
|
||||
|
||||
Signed-off-by: Jake Hunsaker <jhunsake@redhat.com>
|
||||
Signed-off-by: Adam Stokes <adam.stokes@ubuntu.com>
|
||||
---
|
||||
sos/plugins/ovirt.py | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/ovirt.py b/sos/plugins/ovirt.py
|
||||
index b097d93..9436ac6 100644
|
||||
--- a/sos/plugins/ovirt.py
|
||||
+++ b/sos/plugins/ovirt.py
|
||||
@@ -83,6 +83,9 @@ class Ovirt(Plugin, RedHatPlugin):
|
||||
|
||||
self.add_forbidden_path('/etc/ovirt-engine/.pgpass')
|
||||
self.add_forbidden_path('/etc/rhevm/.pgpass')
|
||||
+ # Copy all engine tunables and domain information
|
||||
+ self.add_cmd_output("engine-config --all")
|
||||
+ self.add_cmd_output("engine-manage-domains list")
|
||||
# Copy engine config files.
|
||||
self.add_copy_spec([
|
||||
"/etc/ovirt-engine",
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,38 +0,0 @@
|
||||
From 0aec209ec6870c6ec3cbb6e2209d35adb2b62009 Mon Sep 17 00:00:00 2001
|
||||
From: Sandro Bonazzola <sbonazzo redhat com>
|
||||
Date: Tue, 16 Dec 2014 12:29:57 +0000
|
||||
Subject: [PATCH] [ovirt] remove ovirt-engine setup answer file password leak
|
||||
|
||||
Signed-off-by: Sandro Bonazzola <sbonazzo@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/ovirt.py | 15 +++++++++++++++
|
||||
1 file changed, 15 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/ovirt.py b/sos/plugins/ovirt.py
|
||||
index b169b90..407c918 100644
|
||||
--- a/sos/plugins/ovirt.py
|
||||
+++ b/sos/plugins/ovirt.py
|
||||
@@ -171,4 +171,19 @@ class Ovirt(Plugin, RedHatPlugin):
|
||||
r'{key}=********'.format(key=key)
|
||||
)
|
||||
|
||||
+ # Answer files contain passwords
|
||||
+ for key in (
|
||||
+ 'OVESETUP_CONFIG/adminPassword',
|
||||
+ 'OVESETUP_CONFIG/remoteEngineHostRootPassword',
|
||||
+ 'OVESETUP_DWH_DB/password',
|
||||
+ 'OVESETUP_DB/password',
|
||||
+ 'OVESETUP_REPORTS_CONFIG/adminPassword',
|
||||
+ 'OVESETUP_REPORTS_DB/password',
|
||||
+ ):
|
||||
+ self.do_path_regex_sub(
|
||||
+ r'/var/lib/ovirt-engine/setup/answers/.*',
|
||||
+ r'{key}=(.*)'.format(key=key),
|
||||
+ r'{key}=********'.format(key=key)
|
||||
+ )
|
||||
+
|
||||
# vim: expandtab tabstop=4 shiftwidth=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,31 +0,0 @@
|
||||
From f9aefde0d7f74867031a00b52f72d0ad1ff9463b Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 15 Oct 2014 15:51:13 +0100
|
||||
Subject: [PATCH] [ovirt_hosted_engine] fix exception when force-enabled
|
||||
|
||||
Fixes #416.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/ovirt_hosted_engine.py | 5 +++--
|
||||
1 file changed, 3 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/ovirt_hosted_engine.py b/sos/plugins/ovirt_hosted_engine.py
|
||||
index aee8bc0..02cb2b6 100644
|
||||
--- a/sos/plugins/ovirt_hosted_engine.py
|
||||
+++ b/sos/plugins/ovirt_hosted_engine.py
|
||||
@@ -56,8 +56,9 @@ class OvirtHostedEngine(Plugin, RedHatPlugin):
|
||||
|
||||
all_setup_logs = glob.glob(self.SETUP_LOG_GLOB)
|
||||
all_setup_logs.sort(reverse=True)
|
||||
- # Add latest ovirt-hosted-engine-setup log file
|
||||
- self.add_copy_spec(all_setup_logs[0])
|
||||
+ if len(all_setup_logs):
|
||||
+ # Add latest ovirt-hosted-engine-setup log file
|
||||
+ self.add_copy_spec(all_setup_logs[0])
|
||||
# Add older ovirt-hosted-engine-setup log files only if requested
|
||||
if self.get_option('all_logs'):
|
||||
self.add_copy_spec_limit(
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,32 +0,0 @@
|
||||
From c77c14ecd3e7e35a331cef169b08ffcb318952c2 Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Tue, 20 Jan 2015 11:08:59 -0500
|
||||
Subject: [PATCH] [block] don't use parted human readable output
|
||||
|
||||
Changed the parted command to return data in sectors units
|
||||
instead of human readable form.
|
||||
|
||||
Fixes #471.
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/block.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/block.py b/sos/plugins/block.py
|
||||
index 7984f0d..e02304c 100644
|
||||
--- a/sos/plugins/block.py
|
||||
+++ b/sos/plugins/block.py
|
||||
@@ -46,7 +46,7 @@ class Block(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
disk_path = os.path.join('/dev/', disk)
|
||||
self.add_cmd_output([
|
||||
"udevadm info -ap /sys/block/%s" % (disk),
|
||||
- "parted -s %s print" % (disk_path),
|
||||
+ "parted -s %s unit s print" % (disk_path),
|
||||
"fdisk -l %s" % disk_path
|
||||
])
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,31 +0,0 @@
|
||||
From 9cf393ac27728287927d2c1400e046a8c16679e7 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 11 Feb 2015 21:17:11 +0000
|
||||
Subject: [PATCH] [pcp] collect /etc/pcp.conf
|
||||
|
||||
The file /etc/pcp.conf is added to list of lists that will be collected.
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
|
||||
Fixes #465.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/pcp.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/pcp.py b/sos/plugins/pcp.py
|
||||
index a696908..69872a3 100644
|
||||
--- a/sos/plugins/pcp.py
|
||||
+++ b/sos/plugins/pcp.py
|
||||
@@ -89,6 +89,7 @@ class Pcp(Plugin, RedHatPlugin, DebianPlugin):
|
||||
var_conf_dir = os.path.join(self.pcp_var_dir, 'config')
|
||||
self.add_copy_spec([
|
||||
self.pcp_sysconf_dir,
|
||||
+ self.pcp_conffile,
|
||||
var_conf_dir
|
||||
])
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,26 +0,0 @@
|
||||
From 4d8b5418b1cf218ef9746674ca5935a7f4f3983e Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Fri, 31 Jul 2015 10:21:17 +0100
|
||||
Subject: [PATCH] [Plugin] fix handling of symlinks in non-sysroot environments
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/__init__.py | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/__init__.py b/sos/plugins/__init__.py
|
||||
index aed7496..6731b28 100644
|
||||
--- a/sos/plugins/__init__.py
|
||||
+++ b/sos/plugins/__init__.py
|
||||
@@ -163,6 +163,8 @@ class Plugin(object):
|
||||
return os.path.join(self.sysroot, path)
|
||||
|
||||
def strip_sysroot(self, path):
|
||||
+ if not self.use_sysroot():
|
||||
+ return path
|
||||
if path.startswith(self.sysroot):
|
||||
return path[len(self.sysroot):]
|
||||
return path
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,118 +0,0 @@
|
||||
From 48a99c95078bab306cb56bb1a05420d88bf15a64 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 20 Oct 2014 16:12:01 +0100
|
||||
Subject: [PATCH] [plugin] limit names to PC_NAME_MAX
|
||||
|
||||
Commit 8bf7b0c removed the truncation of mangled command names to
|
||||
64 chars. This causes problems for some plugins (e.g. Issue #415)
|
||||
that generate long enough command lines to hit system name length
|
||||
limits.
|
||||
|
||||
Instead of arbitrarily limiting to 64 characters limit to the
|
||||
lesser of the archive format limit (if present) or the value of
|
||||
PC_NAME_MAX for any intermediate FileCacheArchive path.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/archive.py | 18 ++++++++++++++++++
|
||||
sos/plugins/__init__.py | 7 ++++---
|
||||
tests/plugin_tests.py | 12 ++++++++----
|
||||
3 files changed, 30 insertions(+), 7 deletions(-)
|
||||
|
||||
diff --git a/sos/archive.py b/sos/archive.py
|
||||
index 2e42bbd..6063625 100644
|
||||
--- a/sos/archive.py
|
||||
+++ b/sos/archive.py
|
||||
@@ -98,6 +98,12 @@ class Archive(object):
|
||||
to be included in the generated archive."""
|
||||
raise NotImplementedError
|
||||
|
||||
+ def name_max(self):
|
||||
+ """Return the maximum file name length this archive can support.
|
||||
+ This is the lesser of the name length limit of the archive
|
||||
+ format and any temporary file system based cache."""
|
||||
+ raise NotImplementedError
|
||||
+
|
||||
def get_archive_path(self):
|
||||
"""Return a string representing the path to the temporary
|
||||
archive. For archive classes that implement in-line handling
|
||||
@@ -206,6 +212,13 @@ class FileCacheArchive(Archive):
|
||||
def _makedirs(self, path, mode=0o700):
|
||||
os.makedirs(path, mode)
|
||||
|
||||
+ def name_max(self):
|
||||
+ if 'PC_NAME_MAX' in os.pathconf_names:
|
||||
+ pc_name_max = os.pathconf_names['PC_NAME_MAX']
|
||||
+ return os.pathconf(self._archive_root, pc_name_max)
|
||||
+ else:
|
||||
+ return 255
|
||||
+
|
||||
def get_tmp_dir(self):
|
||||
return self._archive_root
|
||||
|
||||
@@ -355,6 +368,11 @@ class TarFileArchive(FileCacheArchive):
|
||||
def name(self):
|
||||
return "%s.%s" % (self._name, self._suffix)
|
||||
|
||||
+ def name_max(self):
|
||||
+ # GNU Tar format supports unlimited file name length. Just return
|
||||
+ # the limit of the underlying FileCacheArchive.
|
||||
+ return super(TarFileArchive, self).name_max()
|
||||
+
|
||||
def _build_archive(self):
|
||||
# python2.6 TarFile lacks the filter parameter
|
||||
if not six.PY3 and sys.version_info[1] < 7:
|
||||
diff --git a/sos/plugins/__init__.py b/sos/plugins/__init__.py
|
||||
index 3e39100..b289144 100644
|
||||
--- a/sos/plugins/__init__.py
|
||||
+++ b/sos/plugins/__init__.py
|
||||
@@ -42,11 +42,11 @@ def regex_findall(regex, fname):
|
||||
return []
|
||||
|
||||
|
||||
-def _mangle_command(command):
|
||||
- # FIXME: this can be improved
|
||||
+def _mangle_command(command, name_max):
|
||||
mangledname = re.sub(r"^/(usr/|)(bin|sbin)/", "", command)
|
||||
mangledname = re.sub(r"[^\w\-\.\/]+", "_", mangledname)
|
||||
mangledname = re.sub(r"/", ".", mangledname).strip(" ._-")
|
||||
+ mangledname = mangledname[0:name_max]
|
||||
return mangledname
|
||||
|
||||
|
||||
@@ -518,7 +518,8 @@ class Plugin(object):
|
||||
return grep(regexp, *fnames)
|
||||
|
||||
def _mangle_command(self, exe):
|
||||
- return _mangle_command(exe)
|
||||
+ name_max = self.archive.name_max()
|
||||
+ return _mangle_command(exe, name_max)
|
||||
|
||||
def _make_command_filename(self, exe):
|
||||
"""The internal function to build up a filename based on a command."""
|
||||
diff --git a/tests/plugin_tests.py b/tests/plugin_tests.py
|
||||
index 817e4f2..f73a003 100644
|
||||
--- a/tests/plugin_tests.py
|
||||
+++ b/tests/plugin_tests.py
|
||||
@@ -115,10 +115,14 @@ class PluginToolTests(unittest.TestCase):
|
||||
self.assertEquals(matches, [])
|
||||
|
||||
def test_mangle_command(self):
|
||||
- self.assertEquals("foo", _mangle_command("/usr/bin/foo"))
|
||||
- self.assertEquals("foo_-x", _mangle_command("/usr/bin/foo -x"))
|
||||
- self.assertEquals("foo_--verbose", _mangle_command("/usr/bin/foo --verbose"))
|
||||
- self.assertEquals("foo_.path.to.stuff", _mangle_command("/usr/bin/foo /path/to/stuff"))
|
||||
+ name_max = 255
|
||||
+ self.assertEquals("foo", _mangle_command("/usr/bin/foo", name_max))
|
||||
+ self.assertEquals("foo_-x", _mangle_command("/usr/bin/foo -x", name_max))
|
||||
+ self.assertEquals("foo_--verbose", _mangle_command("/usr/bin/foo --verbose", name_max))
|
||||
+ self.assertEquals("foo_.path.to.stuff", _mangle_command("/usr/bin/foo /path/to/stuff", name_max))
|
||||
+ longcmd ="foo is " + "a" * 256 + " long_command"
|
||||
+ expected = longcmd[0:name_max].replace(' ', '_')
|
||||
+ self.assertEquals(expected, _mangle_command(longcmd, name_max))
|
||||
|
||||
|
||||
class PluginTests(unittest.TestCase):
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,137 +0,0 @@
|
||||
From 7b2885740216f8e4076781e088d37cb7b4f96f63 Mon Sep 17 00:00:00 2001
|
||||
From: John Haxby <john.haxby@oracle.com>
|
||||
Date: Wed, 28 Jan 2015 19:30:29 +0000
|
||||
Subject: [PATCH] [plugins,utilities] Allow commands to discard stderr
|
||||
|
||||
Just add "stderr=False" to add_cmd_output() if you don't want the
|
||||
command's stderr in the sosreport.
|
||||
|
||||
Signed-off-by: John Haxby <john.haxby@oracle.com>
|
||||
|
||||
Minor edits for pep8 conformance and to shorten the argument name.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/__init__.py | 29 +++++++++++++++++------------
|
||||
sos/utilities.py | 5 +++--
|
||||
2 files changed, 20 insertions(+), 14 deletions(-)
|
||||
---
|
||||
sos/plugins/__init__.py | 33 +++++++++++++++++++++------------
|
||||
sos/utilities.py | 5 +++--
|
||||
2 files changed, 24 insertions(+), 14 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/__init__.py b/sos/plugins/__init__.py
|
||||
index 4fd85be..9d126a5 100644
|
||||
--- a/sos/plugins/__init__.py
|
||||
+++ b/sos/plugins/__init__.py
|
||||
@@ -460,8 +460,9 @@ class Plugin(object):
|
||||
self.copy_paths.update(copy_paths)
|
||||
self._log_info("added copyspec '%s'" % copyspec)
|
||||
|
||||
- def get_command_output(self, prog, timeout=300, runat=None):
|
||||
- result = sos_get_command_output(prog, timeout=timeout, runat=runat)
|
||||
+ def get_command_output(self, prog, timeout=300, runat=None, stderr=True):
|
||||
+ result = sos_get_command_output(prog, timeout=timeout, runat=runat,
|
||||
+ stderr=stderr)
|
||||
if result['status'] == 124:
|
||||
self._log_warn("command '%s' timed out after %ds"
|
||||
% (prog, timeout))
|
||||
@@ -470,11 +471,12 @@ class Plugin(object):
|
||||
self._log_debug("could not run '%s': command not found" % prog)
|
||||
return result
|
||||
|
||||
- def call_ext_prog(self, prog, timeout=300, runat=None):
|
||||
+ def call_ext_prog(self, prog, timeout=300, runat=None, stderr=True):
|
||||
"""Execute a command independantly of the output gathering part of
|
||||
sosreport.
|
||||
"""
|
||||
- return self.get_command_output(prog, timeout=timeout, runat=runat)
|
||||
+ return self.get_command_output(prog, timeout=timeout, runat=runat,
|
||||
+ stderr=True)
|
||||
|
||||
def check_ext_prog(self, prog):
|
||||
"""Execute a command independently of the output gathering part of
|
||||
@@ -484,15 +486,19 @@ class Plugin(object):
|
||||
return self.call_ext_prog(prog)['status'] == 0
|
||||
|
||||
def add_cmd_output(self, cmds, suggest_filename=None,
|
||||
- root_symlink=None, timeout=300, runat=None):
|
||||
+ root_symlink=None, timeout=300, runat=None,
|
||||
+ stderr=True):
|
||||
"""Run a program or a list of programs and collect the output"""
|
||||
if isinstance(cmds, six.string_types):
|
||||
cmds = [cmds]
|
||||
if len(cmds) > 1 and (suggest_filename or root_symlink):
|
||||
self._log_warn("ambiguous filename or symlink for command list")
|
||||
for cmd in cmds:
|
||||
- cmdt = (cmd, suggest_filename, root_symlink, timeout, runat)
|
||||
- _logstr = "packed command tuple: ('%s', '%s', '%s', %s, '%s')"
|
||||
+ cmdt = (
|
||||
+ cmd, suggest_filename, root_symlink, timeout, runat, stderr
|
||||
+ )
|
||||
+ _tuplefmt = "('%s', '%s', '%s', %s, '%s', '%s')"
|
||||
+ _logstr = "packed command tuple: " + _tuplefmt
|
||||
self._log_debug(_logstr % cmdt)
|
||||
self.collect_cmds.append(cmdt)
|
||||
self._log_info("added cmd output '%s'" % cmd)
|
||||
@@ -547,12 +553,13 @@ class Plugin(object):
|
||||
|
||||
def get_cmd_output_now(self, exe, suggest_filename=None,
|
||||
root_symlink=False, timeout=300,
|
||||
- runat=None):
|
||||
+ runat=None, stderr=True):
|
||||
"""Execute a command and save the output to a file for inclusion in the
|
||||
report.
|
||||
"""
|
||||
start = time()
|
||||
- result = self.get_command_output(exe, timeout=timeout, runat=runat)
|
||||
+ result = self.get_command_output(exe, timeout=timeout, runat=runat,
|
||||
+ stderr=stderr)
|
||||
# 126 means 'found but not executable'
|
||||
if result['status'] == 126 or result['status'] == 127:
|
||||
return None
|
||||
@@ -601,13 +608,15 @@ class Plugin(object):
|
||||
|
||||
def _collect_cmd_output(self):
|
||||
for progs in zip(self.collect_cmds):
|
||||
- prog, suggest_filename, root_symlink, timeout, runat = progs[0]
|
||||
+ (prog, suggest_filename, root_symlink, timeout, runat, stderr
|
||||
+ ) = progs[0]
|
||||
self._log_debug("unpacked command tuple: "
|
||||
- + "('%s', '%s', '%s', %s, '%s')" % progs[0])
|
||||
+ + "('%s', '%s', '%s', %s, '%s', %s)" % progs[0])
|
||||
self._log_info("collecting output of '%s'" % prog)
|
||||
self.get_cmd_output_now(prog, suggest_filename=suggest_filename,
|
||||
root_symlink=root_symlink,
|
||||
- timeout=timeout, runat=runat)
|
||||
+ timeout=timeout, runat=runat,
|
||||
+ stderr=stderr)
|
||||
|
||||
def _collect_strings(self):
|
||||
for string, file_name in self.copy_strings:
|
||||
diff --git a/sos/utilities.py b/sos/utilities.py
|
||||
index 2638ce4..db340f8 100644
|
||||
--- a/sos/utilities.py
|
||||
+++ b/sos/utilities.py
|
||||
@@ -120,7 +120,7 @@ def is_executable(command):
|
||||
return any(os.access(path, os.X_OK) for path in candidates)
|
||||
|
||||
|
||||
-def sos_get_command_output(command, timeout=300, runat=None):
|
||||
+def sos_get_command_output(command, timeout=300, runat=None, stderr=True):
|
||||
"""Execute a command through the system shell. First checks to see if the
|
||||
requested command is executable. Returns (returncode, stdout, 0)"""
|
||||
def _child_chdir():
|
||||
@@ -142,7 +142,8 @@ def sos_get_command_output(command, timeout=300, runat=None):
|
||||
command = command.encode('utf-8', 'ignore')
|
||||
args = shlex.split(command)
|
||||
try:
|
||||
- p = Popen(args, shell=False, stdout=PIPE, stderr=STDOUT,
|
||||
+ p = Popen(args, shell=False, stdout=PIPE,
|
||||
+ stderr=STDOUT if stderr else PIPE,
|
||||
bufsize=-1, env=cmd_env, close_fds=True,
|
||||
preexec_fn=_child_chdir)
|
||||
except OSError as e:
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,100 +0,0 @@
|
||||
From 3a2ad99c71dae022cfb7fb02e11473001c50ae23 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 27 Jan 2015 13:07:52 +0000
|
||||
Subject: [PATCH] [policies] run PackageManager query_command under timeout
|
||||
|
||||
PackageManager query commands may block due to file system locks
|
||||
or problems with the package database. Run the query command with
|
||||
a timeout of 30s and exit if the timeout expires.
|
||||
|
||||
Signed-off-by: Aruna Balakrishnaiah <aruna@linux.vnet.ibm.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
|
||||
---
|
||||
Changes from v3:
|
||||
Add default timeout instead of making it configurable
|
||||
Add print function instead of error()
|
||||
|
||||
Changes from v2:
|
||||
Introduce timeout in shell_out wrapper
|
||||
|
||||
Changes from v1:
|
||||
Addressed issues of the maintainer
|
||||
Introduce timeout instead of relying on yum.
|
||||
---
|
||||
sos/policies/__init__.py | 3 ++-
|
||||
sos/policies/redhat.py | 10 +++++++++-
|
||||
sos/utilities.py | 4 ++--
|
||||
3 files changed, 13 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/sos/policies/__init__.py b/sos/policies/__init__.py
|
||||
index 9fcbd55..34a2f6a 100644
|
||||
--- a/sos/policies/__init__.py
|
||||
+++ b/sos/policies/__init__.py
|
||||
@@ -56,6 +56,7 @@ class PackageManager(object):
|
||||
"""
|
||||
|
||||
query_command = None
|
||||
+ timeout = 30
|
||||
|
||||
def __init__(self, query_command=None):
|
||||
self.packages = {}
|
||||
@@ -92,7 +93,7 @@ class PackageManager(object):
|
||||
version': 'major.minor.version'}}
|
||||
"""
|
||||
if self.query_command:
|
||||
- pkg_list = shell_out(self.query_command).splitlines()
|
||||
+ pkg_list = shell_out(self.query_command, self.timeout).splitlines()
|
||||
for pkg in pkg_list:
|
||||
if '|' not in pkg:
|
||||
continue
|
||||
diff --git a/sos/policies/redhat.py b/sos/policies/redhat.py
|
||||
index 2219246..38510d9 100644
|
||||
--- a/sos/policies/redhat.py
|
||||
+++ b/sos/policies/redhat.py
|
||||
@@ -15,6 +15,7 @@
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
# This enables the use of with syntax in python 2.5 (e.g. jython)
|
||||
+from __future__ import print_function
|
||||
import os
|
||||
import sys
|
||||
|
||||
@@ -46,8 +47,15 @@ class RedHatPolicy(LinuxPolicy):
|
||||
'rpm -qa --queryformat "%{NAME}|%{VERSION}\\n"')
|
||||
self.valid_subclasses = [RedHatPlugin]
|
||||
|
||||
+ pkgs = self.package_manager.all_pkgs()
|
||||
+
|
||||
+ # If rpm query timed out after timeout duration exit
|
||||
+ if not pkgs:
|
||||
+ print("Could not obtain installed package list", file=sys.stderr)
|
||||
+ sys.exit(1)
|
||||
+
|
||||
# handle PATH for UsrMove
|
||||
- if self.package_manager.all_pkgs()['filesystem']['version'][0] == '3':
|
||||
+ if pkgs['filesystem']['version'][0] == '3':
|
||||
self.PATH = "/usr/sbin:/usr/bin:/root/bin"
|
||||
else:
|
||||
self.PATH = "/sbin:/bin:/usr/sbin:/usr/bin:/root/bin"
|
||||
diff --git a/sos/utilities.py b/sos/utilities.py
|
||||
index 51909c6..2638ce4 100644
|
||||
--- a/sos/utilities.py
|
||||
+++ b/sos/utilities.py
|
||||
@@ -180,11 +180,11 @@ def import_module(module_fqname, superclasses=None):
|
||||
return modules
|
||||
|
||||
|
||||
-def shell_out(cmd, runat=None):
|
||||
+def shell_out(cmd, timeout=30, runat=None):
|
||||
"""Shell out to an external command and return the output or the empty
|
||||
string in case of error.
|
||||
"""
|
||||
- return sos_get_command_output(cmd, runat=runat)['output']
|
||||
+ return sos_get_command_output(cmd, timeout=timeout, runat=runat)['output']
|
||||
|
||||
|
||||
class ImporterHelper(object):
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,31 +0,0 @@
|
||||
From 988fee7e6d0c2c91cf1f2c9363d4e3cea7244163 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 2 Oct 2014 17:25:17 +0100
|
||||
Subject: [PATCH] [powerpc] allow PowerPC plugin to run on ppc64le
|
||||
|
||||
The plugin currently tests whether policy().get_arch() is equal
|
||||
to "ppc64". On little endian PowerPC machines this method returns
|
||||
"ppc64le". Change the check_enabled() method to test whether the
|
||||
returned string contains "ppc64".
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/powerpc.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/powerpc.py b/sos/plugins/powerpc.py
|
||||
index 896d1d4..39b52f6 100644
|
||||
--- a/sos/plugins/powerpc.py
|
||||
+++ b/sos/plugins/powerpc.py
|
||||
@@ -27,7 +27,7 @@ class PowerPC(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
profiles = ('system', 'hardware')
|
||||
|
||||
def check_enabled(self):
|
||||
- return (self.policy().get_arch() == "ppc64")
|
||||
+ return "ppc64" in self.policy().get_arch()
|
||||
|
||||
def setup(self):
|
||||
try:
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,68 +0,0 @@
|
||||
From c5f969e8a79a2bc7e0280e11e4a02599552b326f Mon Sep 17 00:00:00 2001
|
||||
From: Shane Bradley <sbradley@redhat.com>
|
||||
Date: Tue, 20 Jan 2015 11:33:31 -0500
|
||||
Subject: [PATCH] [puppet] adding new plugin for puppet
|
||||
|
||||
Added a new plugin to collect files for puppet.
|
||||
|
||||
Fixes: #473.
|
||||
|
||||
Signed-off-by: Shane Bradley <sbradley@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/puppet.py | 43 +++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 43 insertions(+)
|
||||
create mode 100644 sos/plugins/puppet.py
|
||||
|
||||
diff --git a/sos/plugins/puppet.py b/sos/plugins/puppet.py
|
||||
new file mode 100644
|
||||
index 0000000..4da95a2
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/puppet.py
|
||||
@@ -0,0 +1,43 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+from glob import glob
|
||||
+
|
||||
+
|
||||
+class Puppet(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+ """Puppet service
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'puppet'
|
||||
+ profiles = ('services',)
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec([
|
||||
+ "/etc/puppet/*.conf",
|
||||
+ "/etc/puppet/rack/*",
|
||||
+ "/etc/puppet/manifests/*",
|
||||
+ "/var/log/puppet/*.log",
|
||||
+ ])
|
||||
+
|
||||
+ def postproc(self):
|
||||
+ for device_conf in glob("/etc/puppet/device.conf*"):
|
||||
+ self.do_file_sub(
|
||||
+ device_conf,
|
||||
+ r"(.*url*.ssh://.*:).*(@.*)",
|
||||
+ r"\1%s\2" % ('***')
|
||||
+ )
|
||||
+
|
||||
+ return
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,28 +0,0 @@
|
||||
From 786f74a79f6baec716be8c8a05da90b5c63848d0 Mon Sep 17 00:00:00 2001
|
||||
From: Jorge Niedbalski <niedbalski@gmail.com>
|
||||
Date: Fri, 14 Nov 2014 11:43:31 -0300
|
||||
Subject: [PATCH] [plugins/rabbitmq] Added cluster_status command output
|
||||
|
||||
* Added the 'rabbitmqctl cluster_status' output command
|
||||
|
||||
Signed-off-by: Jorge Niedbalski R. <niedbalski@gmail.com>
|
||||
---
|
||||
sos/plugins/rabbitmq.py | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/rabbitmq.py b/sos/plugins/rabbitmq.py
|
||||
index ee09fa3..3e81d66 100644
|
||||
--- a/sos/plugins/rabbitmq.py
|
||||
+++ b/sos/plugins/rabbitmq.py
|
||||
@@ -25,6 +25,8 @@ class RabbitMQ(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
|
||||
def setup(self):
|
||||
self.add_cmd_output("rabbitmqctl report")
|
||||
+ self.add_cmd_output("rabbitmqctl cluster_status")
|
||||
+
|
||||
self.add_copy_spec("/etc/rabbitmq/*")
|
||||
self.add_copy_spec_limit("/var/log/rabbitmq/*",
|
||||
sizelimit=self.get_option('log_size'))
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,35 +0,0 @@
|
||||
From 706e523d608b588cfd70b2dfa957feafe0645796 Mon Sep 17 00:00:00 2001
|
||||
From: Rohan Kanade <rkanade@redhat.com>
|
||||
Date: Mon, 15 Jun 2015 20:24:10 +0530
|
||||
Subject: [PATCH] [openstack_sahara] redact secrets from sahara configuration
|
||||
|
||||
Signed-off-by: Rohan Kanade <rkanade@redhat.com>
|
||||
---
|
||||
sos/plugins/openstack_sahara.py | 11 +++++++++++
|
||||
1 files changed, 11 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/openstack_sahara.py b/sos/plugins/openstack_sahara.py
|
||||
index f0b95e4..9d971ba 100644
|
||||
--- a/sos/plugins/openstack_sahara.py
|
||||
+++ b/sos/plugins/openstack_sahara.py
|
||||
@@ -31,6 +31,17 @@ class OpenStackSahara(Plugin):
|
||||
if self.get_option("log"):
|
||||
self.add_copy_spec("/var/log/sahara/")
|
||||
|
||||
+ def postproc(self):
|
||||
+ protect_keys = [
|
||||
+ 'memcache_secret_key', 'qpid_password', 'rabbit_password',
|
||||
+ 'admin_password', 'password', 'ssl_key_password',
|
||||
+ 'admin_token', 'connection'
|
||||
+ ]
|
||||
+
|
||||
+ regexp = r"((?m)^\s*#*(%s)\s*=\s*)(.*)" % "|".join(protect_keys)
|
||||
+
|
||||
+ self.do_file_sub('/etc/sahara/sahara.conf', regexp, r"\1*********")
|
||||
+
|
||||
|
||||
class DebianOpenStackSahara(OpenStackSahara, DebianPlugin, UbuntuPlugin):
|
||||
"""OpenStackSahara related information for Debian based distributions."""
|
||||
--
|
||||
1.7.1
|
||||
|
@ -1,612 +0,0 @@
|
||||
From e768bf71c96317bc64b643ab9262cb88f1d9058c Mon Sep 17 00:00:00 2001
|
||||
From: Luca Miccini <luca.miccini@redhat.com>
|
||||
Date: Tue, 24 Feb 2015 18:38:20 +0100
|
||||
Subject: [PATCH 1/7] [saphana] add SAP HANA plugin
|
||||
|
||||
Add a plugin for the SAP HANA component and add it to a new 'sap'
|
||||
profile.
|
||||
|
||||
Signed-off-by: Luca Miccini <luca.miccini@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/saphana.py | 84 ++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 84 insertions(+)
|
||||
create mode 100644 sos/plugins/saphana.py
|
||||
|
||||
diff --git a/sos/plugins/saphana.py b/sos/plugins/saphana.py
|
||||
new file mode 100644
|
||||
index 0000000..2ff26f5
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/saphana.py
|
||||
@@ -0,0 +1,84 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+import os
|
||||
+from sos.plugins import Plugin, RedHatPlugin
|
||||
+
|
||||
+
|
||||
+class saphana(Plugin, RedHatPlugin):
|
||||
+ """SAP HANA"""
|
||||
+
|
||||
+ plugin_name = 'saphana'
|
||||
+ profiles = ['sap']
|
||||
+
|
||||
+ files = ['/hana']
|
||||
+
|
||||
+ def setup(self):
|
||||
+
|
||||
+ sids = []
|
||||
+
|
||||
+ if os.path.isdir("/hana/shared"):
|
||||
+ s = os.listdir("/hana/shared")
|
||||
+ for sid in s:
|
||||
+ if len(sid) == 3:
|
||||
+ sid = sid.strip()
|
||||
+ sids.append(sid)
|
||||
+
|
||||
+ for sid in sids:
|
||||
+ sidadm = '%sadm' % sid.lower()
|
||||
+
|
||||
+ prefix = 'su - %s -c' % sidadm
|
||||
+
|
||||
+ self.add_cmd_output('%s "HDB info"' % prefix,
|
||||
+ suggest_filename="%s_HDB_info" % sid)
|
||||
+
|
||||
+ self.add_cmd_output('%s "hdbsrvutil -v"' % prefix,
|
||||
+ suggest_filename="%s_version" % sid)
|
||||
+
|
||||
+ self.add_cmd_output('%s \'hdbcons "mm l -s -S -p"\'' % prefix,
|
||||
+ suggest_filename="%s_memusage" % sid)
|
||||
+
|
||||
+ self.add_cmd_output('%s \'hdbcons -e hdbindexserver \
|
||||
+ "replication info"\'' % prefix,
|
||||
+ suggest_filename="%s_replicainfo" % sid)
|
||||
+
|
||||
+ if os.path.isdir("/hana/shared/%s/" % sid):
|
||||
+ i = os.listdir("/hana/shared/%s/" % sid)
|
||||
+ for inst in i:
|
||||
+ if "HDB" in inst:
|
||||
+ inst = inst.strip()[-2:]
|
||||
+
|
||||
+ # get GREEN/RED status
|
||||
+ self.add_cmd_output(
|
||||
+ 'su - %s -c "sapcontrol -nr %s \
|
||||
+ -function GetProcessList"'
|
||||
+ % (sidadm, inst),
|
||||
+ suggest_filename="%s_%s_status"
|
||||
+ % (sid, inst)
|
||||
+ )
|
||||
+
|
||||
+ path = '/usr/sap/%s/HDB%s/exe/python_support'
|
||||
+ path %= (sid, inst)
|
||||
+
|
||||
+ if os.path.isdir("%s" % path):
|
||||
+ # SCALE OUT - slow
|
||||
+ self.add_cmd_output(
|
||||
+ 'su - %s -c "python \
|
||||
+ %s/landscapeHostConfiguration.py"'
|
||||
+ % (sidadm, path),
|
||||
+ suggest_filename="%s_%s_landscapeConfig"
|
||||
+ % (sid, inst)
|
||||
+ )
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 581b05584410e48be998c98efe25ab9783641d1b Mon Sep 17 00:00:00 2001
|
||||
From: Luca Miccini <luca.miccini@redhat.com>
|
||||
Date: Fri, 13 Mar 2015 12:43:08 +0100
|
||||
Subject: [PATCH 2/7] [vhostmd] add new plugin
|
||||
|
||||
Add a plugin for the Virtual Host Metrics Daemon (vhostmd) to
|
||||
collect VM performance metrics from the system.
|
||||
|
||||
Fixes #527.
|
||||
|
||||
Signed-off-by: Luca Miccini <luca.miccini@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/vhostmd.py | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 52 insertions(+)
|
||||
create mode 100644 sos/plugins/vhostmd.py
|
||||
|
||||
diff --git a/sos/plugins/vhostmd.py b/sos/plugins/vhostmd.py
|
||||
new file mode 100644
|
||||
index 0000000..6711945
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/vhostmd.py
|
||||
@@ -0,0 +1,52 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin
|
||||
+
|
||||
+
|
||||
+class vhostmd(Plugin, RedHatPlugin):
|
||||
+ """vhostmd virtualization metrics collection
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'vhostmd'
|
||||
+ profiles = ['sap']
|
||||
+
|
||||
+ packages = ['virt-what']
|
||||
+
|
||||
+ def setup(self):
|
||||
+ vw = self.get_command_output("virt-what")['output'].splitlines()
|
||||
+
|
||||
+ if not vw:
|
||||
+ return
|
||||
+
|
||||
+ if "vmware" in vw or "kvm" in vw or "xen" in vw:
|
||||
+ # if vm-dump-metrics is installed use it
|
||||
+ if self.is_installed("vm-dump-metrics"):
|
||||
+ self.add_cmd_output("vm-dump-metrics",
|
||||
+ suggest_filename="virt_metrics")
|
||||
+ else:
|
||||
+ # otherwise use the raw vhostmd disk presented (256k size)
|
||||
+ d = self.get_command_output("lsblk -d")
|
||||
+ for disk in d['output'].splitlines():
|
||||
+ if "256K" in disk:
|
||||
+ dev = disk.split()[0]
|
||||
+ check = self.get_command_output(
|
||||
+ "dd if=/dev/%s bs=25 count=1" % dev)
|
||||
+ if 'metric' in check['output']:
|
||||
+ self.add_cmd_output("dd if=/dev/%s bs=256k count=1"
|
||||
+ % dev,
|
||||
+ suggest_filename="virt_\
|
||||
+ metrics")
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 8a710151c792a5f8bddba33de29976bb218b6701 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 30 Jun 2015 17:55:58 +0100
|
||||
Subject: [PATCH 3/7] [vhostmd] add plugin to the system and virt profiles
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/vhostmd.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/vhostmd.py b/sos/plugins/vhostmd.py
|
||||
index 6711945..786a7c1 100644
|
||||
--- a/sos/plugins/vhostmd.py
|
||||
+++ b/sos/plugins/vhostmd.py
|
||||
@@ -20,7 +20,7 @@ class vhostmd(Plugin, RedHatPlugin):
|
||||
"""
|
||||
|
||||
plugin_name = 'vhostmd'
|
||||
- profiles = ['sap']
|
||||
+ profiles = ['sap', 'virt', 'system']
|
||||
|
||||
packages = ['virt-what']
|
||||
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From a5824f209c000d1a69ef305dd69f105400de3f4a Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 30 Jun 2015 18:00:28 +0100
|
||||
Subject: [PATCH 4/7] [vhostmd] enumerate disks via /sys/block instead of
|
||||
"lsblk -d"
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/vhostmd.py | 9 ++++++---
|
||||
1 file changed, 6 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/vhostmd.py b/sos/plugins/vhostmd.py
|
||||
index 786a7c1..0a86fb5 100644
|
||||
--- a/sos/plugins/vhostmd.py
|
||||
+++ b/sos/plugins/vhostmd.py
|
||||
@@ -13,6 +13,7 @@
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
from sos.plugins import Plugin, RedHatPlugin
|
||||
+import os
|
||||
|
||||
|
||||
class vhostmd(Plugin, RedHatPlugin):
|
||||
@@ -31,14 +32,16 @@ class vhostmd(Plugin, RedHatPlugin):
|
||||
return
|
||||
|
||||
if "vmware" in vw or "kvm" in vw or "xen" in vw:
|
||||
- # if vm-dump-metrics is installed use it
|
||||
if self.is_installed("vm-dump-metrics"):
|
||||
+ # if vm-dump-metrics is installed use it
|
||||
self.add_cmd_output("vm-dump-metrics",
|
||||
suggest_filename="virt_metrics")
|
||||
else:
|
||||
# otherwise use the raw vhostmd disk presented (256k size)
|
||||
- d = self.get_command_output("lsblk -d")
|
||||
- for disk in d['output'].splitlines():
|
||||
+ sysblock = "/sys/block"
|
||||
+ if not os.path.isdir(sysblock):
|
||||
+ return
|
||||
+ for disk in os.listdir(sysblock):
|
||||
if "256K" in disk:
|
||||
dev = disk.split()[0]
|
||||
check = self.get_command_output(
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From a191fc379d2ee3b4b42014eec4c3f83a6e423761 Mon Sep 17 00:00:00 2001
|
||||
From: Luca Miccini <luca.miccini@redhat.com>
|
||||
Date: Tue, 24 Feb 2015 18:40:07 +0100
|
||||
Subject: [PATCH 5/7] [sapnw] add SAP NetWeaver plugin
|
||||
|
||||
Closes #516.
|
||||
|
||||
Signed-off-by: Luca Miccini <luca.miccini@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 131 +++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 131 insertions(+)
|
||||
create mode 100644 sos/plugins/sapnw.py
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
new file mode 100644
|
||||
index 0000000..d2be8dd
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -0,0 +1,131 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+import os
|
||||
+from sets import Set
|
||||
+from sos.plugins import Plugin, RedHatPlugin
|
||||
+
|
||||
+
|
||||
+class sapnw(Plugin, RedHatPlugin):
|
||||
+ """SAP NetWeaver"""
|
||||
+
|
||||
+ files = ['/usr/sap']
|
||||
+
|
||||
+ def setup(self):
|
||||
+
|
||||
+ # list installed instances
|
||||
+ self.add_cmd_output("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
+ -function ListInstances",
|
||||
+ suggest_filename="SAPInstances_List")
|
||||
+ # list installed sap dbs
|
||||
+ self.add_cmd_output("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
+ -function ListDatabases",
|
||||
+ suggest_filename="SAPDatabases_List")
|
||||
+
|
||||
+ # list defined instances and guess profiles out of them
|
||||
+ # (good for HA setups with virtual hostnames)
|
||||
+ # using sap host control agent
|
||||
+
|
||||
+ p = self.get_command_output(
|
||||
+ "/usr/sap/hostctrl/exe/saphostctrl -function ListInstances")
|
||||
+
|
||||
+ sidsunique = Set([])
|
||||
+
|
||||
+ # Cycle through all the instances, get 'sid' 'instance_number'
|
||||
+ # and 'vhost' to determine the proper profile
|
||||
+ for line in p['output'].splitlines():
|
||||
+ if "DAA" not in line:
|
||||
+ fields = line.strip().split()
|
||||
+ sid = fields[3]
|
||||
+ inst = fields[5]
|
||||
+ vhost = fields[7]
|
||||
+ sidsunique.add(sid)
|
||||
+ p = os.listdir("/usr/sap/%s/SYS/profile/" % sid)
|
||||
+ for line in p:
|
||||
+ if sid in line and inst in line and vhost in line:
|
||||
+ ldenv = 'LD_LIBRARY_PATH=/usr/sap/%s/SYS/exe/run' % sid
|
||||
+ pt = '/usr/sap/%s/SYS/exe/uc/linuxx86_64' % sid
|
||||
+ profile = line.strip()
|
||||
+ self.add_cmd_output(
|
||||
+ "env -i %s %s/sappfpar \
|
||||
+ all pf=/usr/sap/%s/SYS/profile/%s"
|
||||
+ % (ldenv, pt, sid, profile),
|
||||
+ suggest_filename="%s_parameters" % profile)
|
||||
+
|
||||
+ # collect instance status
|
||||
+ self.add_cmd_output(
|
||||
+ "env -i %s %s/sapcontrol -nr %s \
|
||||
+ -function GetProcessList" % (ldenv, pt, inst),
|
||||
+ suggest_filename="%s_%s_GetProcList" % (sid, inst))
|
||||
+
|
||||
+ # collect version info for the various components
|
||||
+ self.add_cmd_output(
|
||||
+ "env -i %s %s/sapcontrol -nr %s \
|
||||
+ -function GetVersionInfo" % (ldenv, pt, inst),
|
||||
+ suggest_filename="%s_%s_GetVersInfo" % (sid, inst))
|
||||
+
|
||||
+ # collect <SID>adm user environment
|
||||
+ lowsid = sid.lower()
|
||||
+ self.add_cmd_output(
|
||||
+ "su - %sadm -c \"sapcontrol -nr %s -function \
|
||||
+ GetEnvironment\"" % (lowsid, inst),
|
||||
+ suggest_filename="%s_%sadm_%s_userenv"
|
||||
+ % (sid, lowsid, inst))
|
||||
+
|
||||
+ # traverse the sids list, collecting info about dbclient
|
||||
+ for sid in sidsunique:
|
||||
+ c = self.get_command_output("ls /usr/sap/%s/" % sid)
|
||||
+ for line in c['output'].splitlines():
|
||||
+ if 'DVEB' in line:
|
||||
+ self.add_cmd_output(
|
||||
+ "grep 'client driver' /usr/sap/%s/%s/work/dev_w0"
|
||||
+ % (sid, line), suggest_filename="%s_dbclient" % sid)
|
||||
+
|
||||
+ # get the installed db's
|
||||
+ d = self.get_command_output(
|
||||
+ '/usr/sap/hostctrl/exe/saphostctrl -function ListDatabases')
|
||||
+
|
||||
+ for line in d['output'].splitlines():
|
||||
+ if "Instance name" in line:
|
||||
+ fields = line.strip().split()
|
||||
+ dbadm = fields[2][:-1]
|
||||
+ dbtype = fields[8][:-1]
|
||||
+ sid = dbadm[3:].upper()
|
||||
+
|
||||
+ if dbtype == 'db6':
|
||||
+ self.add_cmd_output(
|
||||
+ "su - %s -c \"db2 get dbm cfg\""
|
||||
+ % dbadm, suggest_filename="%s_%s_db2_info"
|
||||
+ % (sid, dbadm))
|
||||
+
|
||||
+ if dbtype == 'sap':
|
||||
+ sid = fields[2][:-1]
|
||||
+ self.add_cmd_output(
|
||||
+ "cat /sapdb/%s/data/config/%s.pah"
|
||||
+ % (sid, sid),
|
||||
+ suggest_filename="%s_%s_maxdb_info"
|
||||
+ % (sid, dbadm))
|
||||
+
|
||||
+ if dbtype == 'ora':
|
||||
+ sid = fields[2][:-1]
|
||||
+ self.add_cmd_output(
|
||||
+ "cat /oracle/%s/*/dbs/init.ora" % sid,
|
||||
+ suggest_filename="%s_oracle_init.ora" % sid)
|
||||
+
|
||||
+ # if sapconf available run it in check mode
|
||||
+ if os.path.isfile("/usr/bin/sapconf"):
|
||||
+ self.add_cmd_output(
|
||||
+ "/usr/bin/sapconf -n", suggest_filename="sapconf_checkmode")
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 1d4185aa916703370f605f87341aa74563f06aa5 Mon Sep 17 00:00:00 2001
|
||||
From: Luca Miccini <luca.miccini@redhat.com>
|
||||
Date: Mon, 2 Mar 2015 12:01:23 +0100
|
||||
Subject: [PATCH 6/7] [sapnw] add 'sapnw' as member of the 'sap' profile
|
||||
|
||||
Signed-off-by: Luca Miccini <luca.miccini@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 74 +++++++++++++++++++++++++++++-----------------------
|
||||
1 file changed, 41 insertions(+), 33 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
index d2be8dd..521556b 100644
|
||||
--- a/sos/plugins/sapnw.py
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -17,46 +17,54 @@ from sets import Set
|
||||
from sos.plugins import Plugin, RedHatPlugin
|
||||
|
||||
|
||||
+def get_directory_listing(path):
|
||||
+ try:
|
||||
+ dir_list = os.listdir(path)
|
||||
+ except:
|
||||
+ dir_list = []
|
||||
+ return dir_list
|
||||
+
|
||||
+
|
||||
class sapnw(Plugin, RedHatPlugin):
|
||||
"""SAP NetWeaver"""
|
||||
|
||||
+ plugin_name = 'sapnw'
|
||||
+ profiles = ['sap']
|
||||
+
|
||||
files = ['/usr/sap']
|
||||
|
||||
def setup(self):
|
||||
|
||||
# list installed instances
|
||||
- self.add_cmd_output("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
- -function ListInstances",
|
||||
- suggest_filename="SAPInstances_List")
|
||||
+ inst_out = self.get_cmd_output_now("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
+ -function ListInstances",
|
||||
+ suggest_filename="SAPInstances")
|
||||
# list installed sap dbs
|
||||
- self.add_cmd_output("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
- -function ListDatabases",
|
||||
- suggest_filename="SAPDatabases_List")
|
||||
-
|
||||
- # list defined instances and guess profiles out of them
|
||||
- # (good for HA setups with virtual hostnames)
|
||||
- # using sap host control agent
|
||||
-
|
||||
- p = self.get_command_output(
|
||||
- "/usr/sap/hostctrl/exe/saphostctrl -function ListInstances")
|
||||
+ db_out = self.get_cmd_output_now("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
+ -function ListDatabases",
|
||||
+ suggest_filename="SAPDatabases")
|
||||
|
||||
sidsunique = Set([])
|
||||
|
||||
# Cycle through all the instances, get 'sid' 'instance_number'
|
||||
# and 'vhost' to determine the proper profile
|
||||
- for line in p['output'].splitlines():
|
||||
+ p = open(inst_out, "r").read().splitlines()
|
||||
+ for line in p:
|
||||
if "DAA" not in line:
|
||||
fields = line.strip().split()
|
||||
sid = fields[3]
|
||||
inst = fields[5]
|
||||
vhost = fields[7]
|
||||
sidsunique.add(sid)
|
||||
- p = os.listdir("/usr/sap/%s/SYS/profile/" % sid)
|
||||
- for line in p:
|
||||
+ for line in get_directory_listing("/usr/sap/%s/SYS/profile/"
|
||||
+ % sid):
|
||||
if sid in line and inst in line and vhost in line:
|
||||
ldenv = 'LD_LIBRARY_PATH=/usr/sap/%s/SYS/exe/run' % sid
|
||||
+ # TODO: I am assuming unicode here
|
||||
+ # nuc should be accounted
|
||||
pt = '/usr/sap/%s/SYS/exe/uc/linuxx86_64' % sid
|
||||
profile = line.strip()
|
||||
+ # collect profiles
|
||||
self.add_cmd_output(
|
||||
"env -i %s %s/sappfpar \
|
||||
all pf=/usr/sap/%s/SYS/profile/%s"
|
||||
@@ -67,13 +75,15 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
self.add_cmd_output(
|
||||
"env -i %s %s/sapcontrol -nr %s \
|
||||
-function GetProcessList" % (ldenv, pt, inst),
|
||||
- suggest_filename="%s_%s_GetProcList" % (sid, inst))
|
||||
+ suggest_filename="%s_%s_GetProcList"
|
||||
+ % (sid, inst))
|
||||
|
||||
# collect version info for the various components
|
||||
self.add_cmd_output(
|
||||
"env -i %s %s/sapcontrol -nr %s \
|
||||
-function GetVersionInfo" % (ldenv, pt, inst),
|
||||
- suggest_filename="%s_%s_GetVersInfo" % (sid, inst))
|
||||
+ suggest_filename="%s_%s_GetVersInfo"
|
||||
+ % (sid, inst))
|
||||
|
||||
# collect <SID>adm user environment
|
||||
lowsid = sid.lower()
|
||||
@@ -85,18 +95,18 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
|
||||
# traverse the sids list, collecting info about dbclient
|
||||
for sid in sidsunique:
|
||||
- c = self.get_command_output("ls /usr/sap/%s/" % sid)
|
||||
- for line in c['output'].splitlines():
|
||||
+ for line in get_directory_listing("/usr/sap/%s/" % sid):
|
||||
if 'DVEB' in line:
|
||||
self.add_cmd_output(
|
||||
"grep 'client driver' /usr/sap/%s/%s/work/dev_w0"
|
||||
- % (sid, line), suggest_filename="%s_dbclient" % sid)
|
||||
+ % (sid, line), suggest_filename="%s_dbclient"
|
||||
+ % sid)
|
||||
|
||||
- # get the installed db's
|
||||
- d = self.get_command_output(
|
||||
- '/usr/sap/hostctrl/exe/saphostctrl -function ListDatabases')
|
||||
+ if not db_out:
|
||||
+ return
|
||||
+ dbl = open(db_out, "r").read().splitlines()
|
||||
|
||||
- for line in d['output'].splitlines():
|
||||
+ for line in dbl:
|
||||
if "Instance name" in line:
|
||||
fields = line.strip().split()
|
||||
dbadm = fields[2][:-1]
|
||||
@@ -104,24 +114,22 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
sid = dbadm[3:].upper()
|
||||
|
||||
if dbtype == 'db6':
|
||||
+ # IBM DB2
|
||||
self.add_cmd_output(
|
||||
"su - %s -c \"db2 get dbm cfg\""
|
||||
% dbadm, suggest_filename="%s_%s_db2_info"
|
||||
% (sid, dbadm))
|
||||
|
||||
if dbtype == 'sap':
|
||||
+ # SAP MAXDB
|
||||
sid = fields[2][:-1]
|
||||
- self.add_cmd_output(
|
||||
- "cat /sapdb/%s/data/config/%s.pah"
|
||||
- % (sid, sid),
|
||||
- suggest_filename="%s_%s_maxdb_info"
|
||||
- % (sid, dbadm))
|
||||
+ self.add_copy_spec(
|
||||
+ "/sapdb/%s/data/config/%s.pah" % (sid, sid))
|
||||
|
||||
if dbtype == 'ora':
|
||||
+ # Oracle
|
||||
sid = fields[2][:-1]
|
||||
- self.add_cmd_output(
|
||||
- "cat /oracle/%s/*/dbs/init.ora" % sid,
|
||||
- suggest_filename="%s_oracle_init.ora" % sid)
|
||||
+ self.add_copy_spec("/oracle/%s/*/dbs/init.ora" % sid)
|
||||
|
||||
# if sapconf available run it in check mode
|
||||
if os.path.isfile("/usr/bin/sapconf"):
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 5ac02f4fbc38992f23aa1f44974f74f7c4e16ea5 Mon Sep 17 00:00:00 2001
|
||||
From: Luca Miccini <luca.miccini@redhat.com>
|
||||
Date: Wed, 11 Mar 2015 15:19:49 +0100
|
||||
Subject: [PATCH 7/7] [sapnw] add sybase ASE collection
|
||||
|
||||
Signed-off-by: Luca Miccini <luca.miccini@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 5 +++++
|
||||
1 file changed, 5 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
index 521556b..e18978f 100644
|
||||
--- a/sos/plugins/sapnw.py
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -131,6 +131,11 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
sid = fields[2][:-1]
|
||||
self.add_copy_spec("/oracle/%s/*/dbs/init.ora" % sid)
|
||||
|
||||
+ if dbtype == 'syb':
|
||||
+ # Sybase
|
||||
+ sid = fields[2][:-1]
|
||||
+ self.add_copy_spec("/sybase/%s/ASE*/%s.cfg" % (sid, sid))
|
||||
+
|
||||
# if sapconf available run it in check mode
|
||||
if os.path.isfile("/usr/bin/sapconf"):
|
||||
self.add_cmd_output(
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,153 +0,0 @@
|
||||
From 24fb011755e655127b7e09f4c02275539666b4b2 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Wed, 29 Jul 2015 14:47:19 +0200
|
||||
Subject: [PATCH] [sapnw] uses a deprecated Sets module
|
||||
|
||||
Use built-in set class instead of deprecated Set for sidsunique
|
||||
|
||||
Resolves: #608
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Adam Stokes <adam.stokes@ubuntu.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 3 +--
|
||||
1 file changed, 1 insertion(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
index e18978f..59beff2 100644
|
||||
--- a/sos/plugins/sapnw.py
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -13,7 +13,6 @@
|
||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
import os
|
||||
-from sets import Set
|
||||
from sos.plugins import Plugin, RedHatPlugin
|
||||
|
||||
|
||||
@@ -44,7 +43,7 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
-function ListDatabases",
|
||||
suggest_filename="SAPDatabases")
|
||||
|
||||
- sidsunique = Set([])
|
||||
+ sidsunique = set()
|
||||
|
||||
# Cycle through all the instances, get 'sid' 'instance_number'
|
||||
# and 'vhost' to determine the proper profile
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 10059897ceb0755bab844011f11ea6c6af8794ae Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Tue, 28 Jul 2015 13:50:54 +0200
|
||||
Subject: [PATCH] [sapnw] Add check if saphostctrl is not present
|
||||
|
||||
Split listing&collecting instances and dbs from lengthy setup().
|
||||
|
||||
Break execution when "inst_out = self.get_cmd_output_now" returns None.
|
||||
|
||||
db_out is already checked this way.
|
||||
|
||||
Resolves: #614
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 30 +++++++++++++++++-------------
|
||||
1 file changed, 17 insertions(+), 13 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
index 59beff2..d2c93ec 100644
|
||||
--- a/sos/plugins/sapnw.py
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -32,20 +32,16 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
|
||||
files = ['/usr/sap']
|
||||
|
||||
- def setup(self):
|
||||
-
|
||||
+ def collect_list_instances(self):
|
||||
# list installed instances
|
||||
inst_out = self.get_cmd_output_now("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
-function ListInstances",
|
||||
suggest_filename="SAPInstances")
|
||||
- # list installed sap dbs
|
||||
- db_out = self.get_cmd_output_now("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
- -function ListDatabases",
|
||||
- suggest_filename="SAPDatabases")
|
||||
+ if not inst_out:
|
||||
+ return
|
||||
|
||||
sidsunique = set()
|
||||
-
|
||||
- # Cycle through all the instances, get 'sid' 'instance_number'
|
||||
+ # Cycle through all the instances, get 'sid', 'instance_number'
|
||||
# and 'vhost' to determine the proper profile
|
||||
p = open(inst_out, "r").read().splitlines()
|
||||
for line in p:
|
||||
@@ -101,10 +97,15 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
% (sid, line), suggest_filename="%s_dbclient"
|
||||
% sid)
|
||||
|
||||
+ def collect_list_dbs(self):
|
||||
+ # list installed sap dbs
|
||||
+ db_out = self.get_cmd_output_now("/usr/sap/hostctrl/exe/saphostctrl \
|
||||
+ -function ListDatabases",
|
||||
+ suggest_filename="SAPDatabases")
|
||||
if not db_out:
|
||||
return
|
||||
- dbl = open(db_out, "r").read().splitlines()
|
||||
|
||||
+ dbl = open(db_out, "r").read().splitlines()
|
||||
for line in dbl:
|
||||
if "Instance name" in line:
|
||||
fields = line.strip().split()
|
||||
@@ -135,9 +136,12 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
sid = fields[2][:-1]
|
||||
self.add_copy_spec("/sybase/%s/ASE*/%s.cfg" % (sid, sid))
|
||||
|
||||
- # if sapconf available run it in check mode
|
||||
- if os.path.isfile("/usr/bin/sapconf"):
|
||||
- self.add_cmd_output(
|
||||
- "/usr/bin/sapconf -n", suggest_filename="sapconf_checkmode")
|
||||
+ def setup(self):
|
||||
+ collect_list_instances()
|
||||
+ collect_list_dbs()
|
||||
+
|
||||
+ # run sapconf in check mode
|
||||
+ self.add_cmd_output("sapconf -n",
|
||||
+ suggest_filename="sapconf_checkmode")
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From 1f83971325629cb3f470dac74de1be49f095118e Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Tue, 4 Aug 2015 10:44:37 +0200
|
||||
Subject: [PATCH] [sapnw] call self methods properly
|
||||
|
||||
Call methods from the self class within "self." scope.
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/sapnw.py | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/sapnw.py b/sos/plugins/sapnw.py
|
||||
index d2c93ec..be8c4b9 100644
|
||||
--- a/sos/plugins/sapnw.py
|
||||
+++ b/sos/plugins/sapnw.py
|
||||
@@ -137,8 +137,8 @@ class sapnw(Plugin, RedHatPlugin):
|
||||
self.add_copy_spec("/sybase/%s/ASE*/%s.cfg" % (sid, sid))
|
||||
|
||||
def setup(self):
|
||||
- collect_list_instances()
|
||||
- collect_list_dbs()
|
||||
+ self.collect_list_instances()
|
||||
+ self.collect_list_dbs()
|
||||
|
||||
# run sapconf in check mode
|
||||
self.add_cmd_output("sapconf -n",
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,92 +0,0 @@
|
||||
From 5cc06136d68536b806ce09ce61f800d9a7938790 Mon Sep 17 00:00:00 2001
|
||||
From: Lukas Zapletal <lzap+git@redhat.com>
|
||||
Date: Tue, 3 Feb 2015 16:42:11 +0100
|
||||
Subject: [PATCH] [foreman] Skip collection of generic resources
|
||||
|
||||
New option was added to foreman-debug (-g) to skip collecting of generic
|
||||
resources (firewall, selinux, cpu, memory). This patch leverages that.
|
||||
|
||||
https://github.com/theforeman/foreman/blob/develop/script/foreman-debug
|
||||
|
||||
Since katello-debug is now part of foreman-debug (as a plugin), there is no
|
||||
need of separate sosreport plugin.
|
||||
|
||||
https://github.com/Katello/katello/blob/master/deploy/script/katello-debug.sh
|
||||
|
||||
New subpackage called foreman-debug was introduced. It is present in both
|
||||
upstream Foreman and Katello installations as well as on both Satellite 6 main
|
||||
node and capsule instances. It can be used to detect if foreman-debug script is
|
||||
present.
|
||||
|
||||
Signed-off-by: Lukas Zapletal <lzap+git@redhat.com>
|
||||
---
|
||||
sos/plugins/foreman.py | 6 +++---
|
||||
sos/plugins/katello.py | 32 --------------------------------
|
||||
2 files changed, 3 insertions(+), 35 deletions(-)
|
||||
delete mode 100644 sos/plugins/katello.py
|
||||
|
||||
diff --git a/sos/plugins/foreman.py b/sos/plugins/foreman.py
|
||||
index 896add1..e50cbdf 100644
|
||||
--- a/sos/plugins/foreman.py
|
||||
+++ b/sos/plugins/foreman.py
|
||||
@@ -18,16 +18,16 @@ from sos.plugins import Plugin, RedHatPlugin
|
||||
|
||||
|
||||
class Foreman(Plugin, RedHatPlugin):
|
||||
- """Foreman systems management
|
||||
+ """Foreman/Satellite 6 systems management
|
||||
"""
|
||||
|
||||
plugin_name = 'foreman'
|
||||
profiles = ('sysmgmt',)
|
||||
- packages = ('foreman')
|
||||
+ packages = ('foreman-debug')
|
||||
|
||||
def setup(self):
|
||||
cmd = "foreman-debug"
|
||||
path = self.get_cmd_output_path(name="foreman-debug")
|
||||
- self.add_cmd_output("%s -q -a -d %s" % (cmd, path))
|
||||
+ self.add_cmd_output("%s -g -q -a -d %s" % (cmd, path))
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
diff --git a/sos/plugins/katello.py b/sos/plugins/katello.py
|
||||
deleted file mode 100644
|
||||
index 795c07e..0000000
|
||||
--- a/sos/plugins/katello.py
|
||||
+++ /dev/null
|
||||
@@ -1,32 +0,0 @@
|
||||
-# Copyright (C) 2013 Red Hat, Inc., Lukas Zapletal <lzap@redhat.com>
|
||||
-
|
||||
-# This program is free software; you can redistribute it and/or modify
|
||||
-# it under the terms of the GNU General Public License as published by
|
||||
-# the Free Software Foundation; either version 2 of the License, or
|
||||
-# (at your option) any later version.
|
||||
-
|
||||
-# This program is distributed in the hope that it will be useful,
|
||||
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
-# GNU General Public License for more details.
|
||||
-
|
||||
-# You should have received a copy of the GNU General Public License
|
||||
-# along with this program; if not, write to the Free Software
|
||||
-# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
-
|
||||
-from sos.plugins import Plugin, RedHatPlugin
|
||||
-
|
||||
-
|
||||
-class Katello(Plugin, RedHatPlugin):
|
||||
- """Katello systems management
|
||||
- """
|
||||
-
|
||||
- plugin_name = 'katello'
|
||||
- profiles = ('sysmgmt',)
|
||||
- packages = ('katello', 'katello-common', 'katello-headpin')
|
||||
-
|
||||
- def setup(self):
|
||||
- self.add_cmd_output("katello-debug --notar -d %s"
|
||||
- % self.get_cmd_output_path(name="katello-debug"))
|
||||
-
|
||||
-# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,479 +0,0 @@
|
||||
From b502b9f51b4d314ed6fa76d66a6db8aea7d32c12 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:00:16 +0200
|
||||
Subject: [PATCH 1/8] [startup] rename plugin to 'services'
|
||||
|
||||
The plugin is supposed to collect information about services
|
||||
rather than about their startup.
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/services.py | 56 +++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
sos/plugins/startup.py | 56 -------------------------------------------------
|
||||
2 files changed, 56 insertions(+), 56 deletions(-)
|
||||
create mode 100644 sos/plugins/services.py
|
||||
delete mode 100644 sos/plugins/startup.py
|
||||
|
||||
diff --git a/sos/plugins/services.py b/sos/plugins/services.py
|
||||
new file mode 100644
|
||||
index 0000000..606a135
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/services.py
|
||||
@@ -0,0 +1,56 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class Services(Plugin):
|
||||
+ """System services
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = "services"
|
||||
+ profiles = ('system', 'boot')
|
||||
+
|
||||
+ option_list = [("servicestatus", "get a status of all running services",
|
||||
+ "slow", False)]
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec([
|
||||
+ "/etc/inittab",
|
||||
+ "/etc/rc.d"
|
||||
+ ])
|
||||
+ if self.get_option('servicestatus'):
|
||||
+ self.add_cmd_output("/sbin/service --status-all")
|
||||
+ self.add_cmd_output("/sbin/runlevel")
|
||||
+
|
||||
+
|
||||
+class RedHatServices(Services, RedHatPlugin):
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(RedHatServices, self).setup()
|
||||
+ self.add_cmd_output("/sbin/chkconfig --list", root_symlink="chkconfig")
|
||||
+
|
||||
+
|
||||
+class DebianServices(Services, DebianPlugin, UbuntuPlugin):
|
||||
+
|
||||
+ def setup(self):
|
||||
+ super(DebianServices, self).setup()
|
||||
+ self.add_copy_spec("/etc/rc*.d")
|
||||
+
|
||||
+ self.add_cmd_output("/sbin/initctl show-config",
|
||||
+ root_symlink="initctl")
|
||||
+ if self.get_option('servicestatus'):
|
||||
+ self.add_cmd_output("/sbin/initctl list")
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
diff --git a/sos/plugins/startup.py b/sos/plugins/startup.py
|
||||
deleted file mode 100644
|
||||
index 9d92370..0000000
|
||||
--- a/sos/plugins/startup.py
|
||||
+++ /dev/null
|
||||
@@ -1,56 +0,0 @@
|
||||
-# This program is free software; you can redistribute it and/or modify
|
||||
-# it under the terms of the GNU General Public License as published by
|
||||
-# the Free Software Foundation; either version 2 of the License, or
|
||||
-# (at your option) any later version.
|
||||
-
|
||||
-# This program is distributed in the hope that it will be useful,
|
||||
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
-# GNU General Public License for more details.
|
||||
-
|
||||
-# You should have received a copy of the GNU General Public License
|
||||
-# along with this program; if not, write to the Free Software
|
||||
-# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
-
|
||||
-from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
-
|
||||
-
|
||||
-class Startup(Plugin):
|
||||
- """System startup
|
||||
- """
|
||||
-
|
||||
- plugin_name = "startup"
|
||||
- profiles = ('system', 'boot')
|
||||
-
|
||||
- option_list = [("servicestatus", "get a status of all running services",
|
||||
- "slow", False)]
|
||||
-
|
||||
- def setup(self):
|
||||
- self.add_copy_spec([
|
||||
- "/etc/inittab",
|
||||
- "/etc/rc.d"
|
||||
- ])
|
||||
- if self.get_option('servicestatus'):
|
||||
- self.add_cmd_output("/sbin/service --status-all")
|
||||
- self.add_cmd_output("/sbin/runlevel")
|
||||
-
|
||||
-
|
||||
-class RedHatStartup(Startup, RedHatPlugin):
|
||||
-
|
||||
- def setup(self):
|
||||
- super(RedHatStartup, self).setup()
|
||||
- self.add_cmd_output("/sbin/chkconfig --list", root_symlink="chkconfig")
|
||||
-
|
||||
-
|
||||
-class DebianStartup(Startup, DebianPlugin, UbuntuPlugin):
|
||||
-
|
||||
- def setup(self):
|
||||
- super(DebianStartup, self).setup()
|
||||
- self.add_copy_spec("/etc/rc*.d")
|
||||
-
|
||||
- self.add_cmd_output("/sbin/initctl show-config",
|
||||
- root_symlink="initctl")
|
||||
- if self.get_option('servicestatus'):
|
||||
- self.add_cmd_output("/sbin/initctl list")
|
||||
-
|
||||
-# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 5204d62fdb362fb5cc4a897c90faa9539715fc74 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Tue, 7 Jul 2015 13:03:14 +0200
|
||||
Subject: [PATCH 2/8] [services] add "ls /var/lock/subsys"
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/services.py | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/services.py b/sos/plugins/services.py
|
||||
index 606a135..ab9f8ce 100644
|
||||
--- a/sos/plugins/services.py
|
||||
+++ b/sos/plugins/services.py
|
||||
@@ -32,7 +32,10 @@ class Services(Plugin):
|
||||
])
|
||||
if self.get_option('servicestatus'):
|
||||
self.add_cmd_output("/sbin/service --status-all")
|
||||
- self.add_cmd_output("/sbin/runlevel")
|
||||
+ self.add_cmd_output([
|
||||
+ "/sbin/runlevel",
|
||||
+ "ls /var/lock/subsys"
|
||||
+ ])
|
||||
|
||||
|
||||
class RedHatServices(Services, RedHatPlugin):
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From e00447e7ee346aa3be685a91ebba7cf208c4f205 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:04:19 +0200
|
||||
Subject: [PATCH 3/8] [ntp] Collect "ntpq -p" output
|
||||
|
||||
Partially solves #570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/ntp.py | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/ntp.py b/sos/plugins/ntp.py
|
||||
index 0e39b9d..c0f731d 100644
|
||||
--- a/sos/plugins/ntp.py
|
||||
+++ b/sos/plugins/ntp.py
|
||||
@@ -30,7 +30,10 @@ class Ntp(Plugin):
|
||||
"/etc/ntp/step-tickers",
|
||||
"/etc/ntp/ntpservers"
|
||||
])
|
||||
- self.add_cmd_output("ntptime")
|
||||
+ self.add_cmd_output([
|
||||
+ "ntptime",
|
||||
+ "ntpq -p"
|
||||
+ ])
|
||||
|
||||
|
||||
class RedHatNtp(Ntp, RedHatPlugin):
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 83ef3aff955a33bb58c578479ac6b63a615b4521 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:07:06 +0200
|
||||
Subject: [PATCH 4/8] [networking] Collect "ethtool -T $NIC"
|
||||
|
||||
Partially solves #570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/networking.py | 1 +
|
||||
1 file changed, 1 insertion(+)
|
||||
|
||||
diff --git a/sos/plugins/networking.py b/sos/plugins/networking.py
|
||||
index f2b06a6..b2c74c1 100644
|
||||
--- a/sos/plugins/networking.py
|
||||
+++ b/sos/plugins/networking.py
|
||||
@@ -184,6 +184,7 @@ class Networking(Plugin):
|
||||
"ethtool -i "+eth,
|
||||
"ethtool -k "+eth,
|
||||
"ethtool -S "+eth,
|
||||
+ "ethtool -T "+eth,
|
||||
"ethtool -a "+eth,
|
||||
"ethtool -c "+eth,
|
||||
"ethtool -g "+eth
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 002cef3eddc288352d0b92f6272fbd2e85280e6e Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:17:40 +0200
|
||||
Subject: [PATCH 5/8] [ptp] Add new plugin for Precision time protocol
|
||||
|
||||
Partially resolves #570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/ptp.py | 36 ++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 36 insertions(+)
|
||||
create mode 100644 sos/plugins/ptp.py
|
||||
|
||||
diff --git a/sos/plugins/ptp.py b/sos/plugins/ptp.py
|
||||
new file mode 100644
|
||||
index 0000000..a6ac648
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/ptp.py
|
||||
@@ -0,0 +1,36 @@
|
||||
+# Copyright (C) 2015 Pavel Moravec <pmoravec@redhat.com>
|
||||
+
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class Ptp(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+ """Precision time protocol
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = "ptp"
|
||||
+ profiles = ('system', 'services')
|
||||
+
|
||||
+ packages = ('linuxptp',)
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_copy_spec([
|
||||
+ "/etc/ptp4l.conf",
|
||||
+ "/etc/timemaster.conf",
|
||||
+ "/sys/class/ptp"
|
||||
+ ])
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 72e2e32eaa97c6c76b61635dd0fafeb4dcc1aa7d Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:19:29 +0200
|
||||
Subject: [PATCH 6/8] [process] Collect few "ps" outputs
|
||||
|
||||
Partially solves $570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
(edits for readability & line length)
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/process.py | 9 ++++++++-
|
||||
1 file changed, 8 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/process.py b/sos/plugins/process.py
|
||||
index 6ae189b..a643844 100644
|
||||
--- a/sos/plugins/process.py
|
||||
+++ b/sos/plugins/process.py
|
||||
@@ -23,13 +23,20 @@ class Process(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
profiles = ('system',)
|
||||
|
||||
def setup(self):
|
||||
+ ps_axo = "ps axo"
|
||||
+ # process group and thread options
|
||||
+ ps_group_opts = "pid,ppid,user,group,lwp,nlwp,start_time,comm,cgroup"
|
||||
+ ps_sched_opts = "flags,state,uid,pid,ppid,pgid,sid,cls,pri,addr,sz,"
|
||||
+ ps_sched_opts += "wchan,stime,tty,time,cmd"
|
||||
self.add_copy_spec("/proc/sched_debug")
|
||||
self.add_cmd_output("ps auxwww", root_symlink="ps")
|
||||
self.add_cmd_output("pstree", root_symlink="pstree")
|
||||
self.add_cmd_output("lsof -b +M -n -l", root_symlink="lsof")
|
||||
self.add_cmd_output([
|
||||
"ps auxwwwm",
|
||||
- "ps alxwww"
|
||||
+ "ps alxwww",
|
||||
+ "%s %s" % (ps_axo, ps_group_opts),
|
||||
+ "%s %s" % (ps_axo, ps_sched_opts)
|
||||
])
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 0b9a4c545582ed73f89ee4a7572ecb631633819e Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:21:28 +0200
|
||||
Subject: [PATCH 7/8] [sysvipc] Collect "ipcs -u"
|
||||
|
||||
Partially solves #570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/sysvipc.py | 5 ++++-
|
||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/sysvipc.py b/sos/plugins/sysvipc.py
|
||||
index a0732e7..a98abf9 100644
|
||||
--- a/sos/plugins/sysvipc.py
|
||||
+++ b/sos/plugins/sysvipc.py
|
||||
@@ -29,6 +29,9 @@ class SysVIPC(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
"/proc/sysvipc/sem",
|
||||
"/proc/sysvipc/shm"
|
||||
])
|
||||
- self.add_cmd_output("ipcs")
|
||||
+ self.add_cmd_output([
|
||||
+ "ipcs",
|
||||
+ "ipcs -u"
|
||||
+ ])
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From fb7bbcf9e60002d75db383fac08244a7fa06a1d6 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 31 May 2015 16:24:23 +0200
|
||||
Subject: [PATCH 8/8] [devices] New plugin to collect "udevadm info
|
||||
--export-db"
|
||||
|
||||
Partially resolves #570
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/devices.py | 28 ++++++++++++++++++++++++++++
|
||||
1 file changed, 28 insertions(+)
|
||||
create mode 100644 sos/plugins/devices.py
|
||||
|
||||
diff --git a/sos/plugins/devices.py b/sos/plugins/devices.py
|
||||
new file mode 100644
|
||||
index 0000000..5e0283a
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/devices.py
|
||||
@@ -0,0 +1,28 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class Devices(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+ """ devices specific commands
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'devices'
|
||||
+ profiles = ('system', 'hardware', 'boot')
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_cmd_output("udevadm info --export-db")
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
From c05fa2947937a5adc3496c4e66b649633de054e9 Mon Sep 17 00:00:00 2001
|
||||
From: Alexandru Juncu <alexj@linux.com>
|
||||
Date: Tue, 24 Feb 2015 18:28:04 +0100
|
||||
Subject: [PATCH] [last] information about login actions
|
||||
|
||||
This is useful information to be correlated with shutdown/reboot
|
||||
events in /var/log/messages to identify graceful shutdowns/reboots
|
||||
and lower false positives about system crashes.
|
||||
|
||||
Resolves #572.
|
||||
|
||||
Signed-off-by: Alexandru Juncu <alexj@linux.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/last.py | 33 +++++++++++++++++++++++++++++++++
|
||||
1 file changed, 33 insertions(+)
|
||||
create mode 100644 sos/plugins/last.py
|
||||
|
||||
diff --git a/sos/plugins/last.py b/sos/plugins/last.py
|
||||
new file mode 100644
|
||||
index 0000000..d6b791d
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/last.py
|
||||
@@ -0,0 +1,33 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin
|
||||
+
|
||||
+
|
||||
+class Last(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin):
|
||||
+ """login information
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'last'
|
||||
+ profiles = ('system',)
|
||||
+
|
||||
+ def setup(self):
|
||||
+ self.add_cmd_output("last", root_symlink="last")
|
||||
+ self.add_cmd_output([
|
||||
+ "last reboot",
|
||||
+ "last shutdown",
|
||||
+ "lastlog"
|
||||
+ ])
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,63 +0,0 @@
|
||||
From b61a193b98b896164a8caefa088bb09297f1e3ca Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 1 Oct 2014 17:08:50 +0100
|
||||
Subject: [PATCH 1/2] [utilities] invert sense of six.PY2 test
|
||||
|
||||
Old versions of six do not include a 'PY2' attribute leading to
|
||||
an exception in sos_get_command_output(). Invert the sense of the
|
||||
test and check that six.PY3 is false instead as all versions of
|
||||
the module include this attribute.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/utilities.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/utilities.py b/sos/utilities.py
|
||||
index 7c06781..7e8cd7e 100644
|
||||
--- a/sos/utilities.py
|
||||
+++ b/sos/utilities.py
|
||||
@@ -139,7 +139,7 @@ def sos_get_command_output(command, timeout=300, runat=None):
|
||||
command = "timeout %ds %s" % (timeout, command)
|
||||
|
||||
# shlex.split() reacts badly to unicode on older python runtimes.
|
||||
- if six.PY2:
|
||||
+ if not six.PY3:
|
||||
command = command.encode('utf-8')
|
||||
args = shlex.split(command)
|
||||
try:
|
||||
--
|
||||
1.9.3
|
||||
|
||||
|
||||
From f9c811abc07f1e3044b1dbf29fdd5cd1f68812bc Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 1 Oct 2014 17:34:56 +0100
|
||||
Subject: [PATCH 2/2] [archive] invert sense of six.PY2 test
|
||||
|
||||
Old versions of six do not include a 'PY2' attribute leading to
|
||||
an exception in sos_get_command_output(). Invert the sense of the
|
||||
test and check that six.PY3 is false instead as all versions of
|
||||
the module include this attribute.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/archive.py | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/archive.py b/sos/archive.py
|
||||
index 245f904..2e42bbd 100644
|
||||
--- a/sos/archive.py
|
||||
+++ b/sos/archive.py
|
||||
@@ -357,7 +357,7 @@ class TarFileArchive(FileCacheArchive):
|
||||
|
||||
def _build_archive(self):
|
||||
# python2.6 TarFile lacks the filter parameter
|
||||
- if six.PY2 and sys.version_info[1] < 7:
|
||||
+ if not six.PY3 and sys.version_info[1] < 7:
|
||||
tar = _TarFile.open(self._archive_name, mode="w")
|
||||
else:
|
||||
tar = tarfile.open(self._archive_name, mode="w")
|
||||
--
|
||||
1.9.3
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,62 +0,0 @@
|
||||
From 75901ef7906690aadaabc8925ac9a2e8523ed1a3 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Sun, 1 Feb 2015 13:40:18 +0100
|
||||
Subject: [PATCH] [general] Better handling --name and --ticket-number in
|
||||
interactive mode
|
||||
|
||||
Carry forward values from the CLI options into the interactive mode,
|
||||
resolves #485
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/policies/__init__.py | 19 +++++++++++--------
|
||||
1 file changed, 11 insertions(+), 8 deletions(-)
|
||||
|
||||
diff --git a/sos/policies/__init__.py b/sos/policies/__init__.py
|
||||
index 34a2f6a..4c42d02 100644
|
||||
--- a/sos/policies/__init__.py
|
||||
+++ b/sos/policies/__init__.py
|
||||
@@ -402,17 +402,20 @@ class LinuxPolicy(Policy):
|
||||
def pre_work(self):
|
||||
# this method will be called before the gathering begins
|
||||
|
||||
- localname = self.get_local_name()
|
||||
+ cmdline_opts = self.commons['cmdlineopts']
|
||||
+ customer_name = cmdline_opts.customer_name
|
||||
+ localname = customer_name if customer_name else self.get_local_name()
|
||||
+ caseid = cmdline_opts.case_id if cmdline_opts.case_id else ""
|
||||
|
||||
- if not self.commons['cmdlineopts'].batch and not \
|
||||
- self.commons['cmdlineopts'].quiet:
|
||||
+ if not cmdline_opts.batch and not \
|
||||
+ cmdline_opts.quiet:
|
||||
try:
|
||||
self.report_name = input(_("Please enter your first initial "
|
||||
"and last name [%s]: ") % localname)
|
||||
|
||||
self.case_id = input(_("Please enter the case id "
|
||||
"that you are generating this "
|
||||
- "report for: "))
|
||||
+ "report for [%s]: ") % caseid)
|
||||
self._print()
|
||||
except:
|
||||
self._print()
|
||||
@@ -421,11 +424,11 @@ class LinuxPolicy(Policy):
|
||||
if len(self.report_name) == 0:
|
||||
self.report_name = localname
|
||||
|
||||
- if self.commons['cmdlineopts'].customer_name:
|
||||
- self.report_name = self.commons['cmdlineopts'].customer_name
|
||||
+ if customer_name:
|
||||
+ self.report_name = customer_name
|
||||
|
||||
- if self.commons['cmdlineopts'].case_id:
|
||||
- self.case_id = self.commons['cmdlineopts'].case_id
|
||||
+ if cmdline_opts.case_id:
|
||||
+ self.case_id = cmdline_opts.case_id
|
||||
|
||||
self.report_name = self.sanitize_report_name(self.report_name)
|
||||
if self.case_id:
|
||||
--
|
||||
1.8.3.1
|
||||
|
@ -1,61 +0,0 @@
|
||||
diff -up sos-3.2/sos/archive.py.orig sos-3.2/sos/archive.py
|
||||
--- sos-3.2/sos/archive.py.orig 2014-12-17 13:08:57.492362543 +0000
|
||||
+++ sos-3.2/sos/archive.py 2014-12-17 13:09:22.256522491 +0000
|
||||
@@ -388,9 +388,9 @@ class TarFileArchive(FileCacheArchive):
|
||||
close_fds=True)
|
||||
stdout, stderr = p.communicate()
|
||||
if stdout:
|
||||
- self.log_info(stdout.decode('utf-8'))
|
||||
+ self.log_info(stdout.decode('utf-8', 'ignore'))
|
||||
if stderr:
|
||||
- self.log_error(stderr.decode('utf-8'))
|
||||
+ self.log_error(stderr.decode('utf-8', 'ignore'))
|
||||
self._suffix += suffix
|
||||
return self.name()
|
||||
except Exception as e:
|
||||
diff -up sos-3.2/sos/plugins/__init__.py.orig sos-3.2/sos/plugins/__init__.py
|
||||
--- sos-3.2/sos/plugins/__init__.py.orig 2014-12-17 13:08:57.493362550 +0000
|
||||
+++ sos-3.2/sos/plugins/__init__.py 2014-12-17 13:09:22.257522498 +0000
|
||||
@@ -541,7 +541,7 @@ class Plugin(object):
|
||||
def add_string_as_file(self, content, filename):
|
||||
"""Add a string to the archive as a file named `filename`"""
|
||||
self.copy_strings.append((content, filename))
|
||||
- content = "..." + (content.splitlines()[0]).decode('utf8')
|
||||
+ content = "..." + (content.splitlines()[0]).decode('utf8', 'ignore')
|
||||
self._log_debug("added string '%s' as '%s'" % (content, filename))
|
||||
|
||||
def get_cmd_output_now(self, exe, suggest_filename=None,
|
||||
@@ -610,7 +610,8 @@ class Plugin(object):
|
||||
|
||||
def _collect_strings(self):
|
||||
for string, file_name in self.copy_strings:
|
||||
- content = "..." + (string.splitlines()[0]).decode('utf8')
|
||||
+ content = "..."
|
||||
+ content += (string.splitlines()[0]).decode('utf8', 'ignore')
|
||||
self._log_info("collecting string '%s' as '%s'"
|
||||
% (content, file_name))
|
||||
try:
|
||||
diff -up sos-3.2/sos/utilities.py.orig sos-3.2/sos/utilities.py
|
||||
--- sos-3.2/sos/utilities.py.orig 2014-12-17 13:09:16.709486664 +0000
|
||||
+++ sos-3.2/sos/utilities.py 2014-12-17 13:09:22.257522498 +0000
|
||||
@@ -140,7 +140,7 @@ def sos_get_command_output(command, time
|
||||
|
||||
# shlex.split() reacts badly to unicode on older python runtimes.
|
||||
if not six.PY3:
|
||||
- command = command.encode('utf-8')
|
||||
+ command = command.encode('utf-8', 'ignore')
|
||||
args = shlex.split(command)
|
||||
try:
|
||||
p = Popen(args, shell=False, stdout=PIPE, stderr=STDOUT,
|
||||
@@ -159,7 +159,10 @@ def sos_get_command_output(command, time
|
||||
if p.returncode == 126 or p.returncode == 127:
|
||||
stdout = six.binary_type(b"")
|
||||
|
||||
- return {'status': p.returncode, 'output': stdout.decode('utf-8')}
|
||||
+ return {
|
||||
+ 'status': p.returncode,
|
||||
+ 'output': stdout.decode('utf-8', 'ignore')
|
||||
+ }
|
||||
|
||||
|
||||
def import_module(module_fqname, superclasses=None):
|
@ -1,63 +0,0 @@
|
||||
From df219b43b5edab9868cb7d7511f7da1c1f5e225a Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Wed, 1 Jul 2015 14:18:50 +0100
|
||||
Subject: [PATCH] [general] verify --profile contains valid plugins only
|
||||
|
||||
If --profile contains an invalid profile name, stop, and
|
||||
print the list of available profiles as well as the offending
|
||||
profile name (helpful when multiple profiles have been specified).
|
||||
|
||||
E.g.:
|
||||
|
||||
sosreport (version 3.2)
|
||||
|
||||
Unknown or inactive profile(s) provided: virtuous
|
||||
The following profiles are available:
|
||||
|
||||
boot boot, startup, systemd, udev
|
||||
cluster
|
||||
[...]
|
||||
|
||||
Based on a patch from Pavel Moravec.
|
||||
|
||||
Fixes #505.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 10 ++++++++++
|
||||
1 file changed, 10 insertions(+)
|
||||
|
||||
diff --git a/sos/sosreport.py.orig b/sos/sosreport.py
|
||||
index 7ea7b33..2af9de5 100644
|
||||
--- a/sos/sosreport.py.orig
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -844,6 +844,7 @@ class SoSReport(object):
|
||||
self.plugin_names = deque()
|
||||
self.profiles = set()
|
||||
using_profiles = len(self.opts.profiles)
|
||||
+ remaining_profiles = list(self.opts.profiles)
|
||||
# validate and load plugins
|
||||
for plug in plugins:
|
||||
plugbase, ext = os.path.splitext(plug)
|
||||
@@ -896,12 +897,21 @@ class SoSReport(object):
|
||||
self._skip(plugin_class, _("not specified"))
|
||||
continue
|
||||
|
||||
+ for i in plugin_class.profiles:
|
||||
+ if i in remaining_profiles:
|
||||
+ remaining_profiles.remove(i)
|
||||
+
|
||||
self._load(plugin_class)
|
||||
except Exception as e:
|
||||
self.soslog.warning(_("plugin %s does not install, "
|
||||
"skipping: %s") % (plug, e))
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
+ if len(remaining_profiles) > 0:
|
||||
+ self.soslog.error(_("Unknown or inactive profile(s) provided:"
|
||||
+ " %s") % ", ".join(remaining_profiles))
|
||||
+ self.list_profiles()
|
||||
+ self._exit(1)
|
||||
|
||||
def _set_all_options(self):
|
||||
if self.opts.usealloptions:
|
@ -1,71 +0,0 @@
|
||||
From 95bb5df9eda253afed15fa81340d31e03c40fe94 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 13 Jan 2015 17:10:06 +0000
|
||||
Subject: [PATCH] [sosreport] catch OSError exceptions in SoSReport.execute()
|
||||
|
||||
OSError exceptions during logging setup and tear down are not
|
||||
currently handled:
|
||||
|
||||
Traceback (most recent call last):
|
||||
File "/usr/sbin/sosreport", line 25, in <module>
|
||||
main(sys.argv[1:])
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1409, in main
|
||||
sos.execute()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 1366, in execute
|
||||
self._setup_logging()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 739, in _setup_logging
|
||||
self.sos_log_file = self.get_temp_file()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 670, in get_temp_file
|
||||
return self.tempfile_util.new()
|
||||
File "/usr/lib/python2.7/site-packages/sos/sosreport.py", line 82, in new
|
||||
fd, fname = tempfile.mkstemp(dir=self.tmp_dir)
|
||||
File "/usr/lib64/python2.7/tempfile.py", line 304, in mkstemp
|
||||
return _mkstemp_inner(dir, prefix, suffix, flags)
|
||||
File "/usr/lib64/python2.7/tempfile.py", line 239, in _mkstemp_inner
|
||||
fd = _os.open(file, flags, 0600)
|
||||
OSError: [Errno 28] No space left on device: '/tmp/tmp.4ejNitjwcr/nospace_tmp/tmpBjPTOm'
|
||||
|
||||
Address this by adding OSError to the list of caught exceptions
|
||||
in the main SoSReport.execute() method. Wrap the exception branch
|
||||
clean up in a try/except block to catch additional exceptions
|
||||
while attempting to clean up (e.g. unlink failures following an
|
||||
EROFS on the temporary archive path).
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 19 +++++++++++++------
|
||||
1 file changed, 13 insertions(+), 6 deletions(-)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 0dd26ad..2a16555 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -1395,12 +1395,19 @@ class SoSReport(object):
|
||||
self.version()
|
||||
|
||||
return self.final_work()
|
||||
- except (SystemExit, KeyboardInterrupt):
|
||||
- if self.archive:
|
||||
- self.archive.cleanup()
|
||||
- if self.tempfile_util:
|
||||
- self.tempfile_util.clean()
|
||||
- return False
|
||||
+
|
||||
+ except (OSError, SystemExit, KeyboardInterrupt):
|
||||
+ try:
|
||||
+ # archive and tempfile cleanup may fail due to a fatal
|
||||
+ # OSError exception (ENOSPC, EROFS etc.).
|
||||
+ if self.archive:
|
||||
+ self.archive.cleanup()
|
||||
+ if self.tempfile_util:
|
||||
+ self.tempfile_util.clean()
|
||||
+ except:
|
||||
+ pass
|
||||
+
|
||||
+ return False
|
||||
|
||||
|
||||
def main(args):
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,41 +0,0 @@
|
||||
From ed44939d5988098feb3f3ddededd68a0a4b9a9df Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 13 Jan 2015 17:26:33 +0000
|
||||
Subject: [PATCH] [sosreport] do not make logging calls after OSError
|
||||
|
||||
Following an OSError during archive setup the logging subsystem
|
||||
is potentially in an inconsistent or unusable state (e.g. due to
|
||||
a readonly file system error).
|
||||
|
||||
Use the print function directly since we just need to report the
|
||||
error and exit.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 9 ++++++---
|
||||
1 file changed, 6 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 2a16555..3c0397c 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -1091,10 +1091,13 @@ class SoSReport(object):
|
||||
self._make_archive_paths()
|
||||
return
|
||||
except (OSError, IOError) as e:
|
||||
+ # we must not use the logging subsystem here as it is potentially
|
||||
+ # in an inconsistent or unreliable state (e.g. an EROFS for the
|
||||
+ # file system containing our temporary log files).
|
||||
if e.errno in fatal_fs_errors:
|
||||
- self.ui_log.error("")
|
||||
- self.ui_log.error(" %s while setting up archive" % e.strerror)
|
||||
- self.ui_log.error("")
|
||||
+ print("")
|
||||
+ print(" %s while setting up archive" % e.strerror)
|
||||
+ print("")
|
||||
else:
|
||||
raise e
|
||||
except Exception as e:
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,39 +0,0 @@
|
||||
From d7759d3ddae5fe99a340c88a1d370d65cfa73fd6 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Thu, 30 Oct 2014 16:46:01 +0000
|
||||
Subject: [PATCH] [sosreport] fix archive permissions regression
|
||||
|
||||
Restore the umask save/restore around archive creation and ensure
|
||||
the effective umask is 077 at the time of archive creation.
|
||||
|
||||
Fixes #425.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 664414f..99b5f47 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -1327,6 +1327,7 @@ class SoSReport(object):
|
||||
self._finish_logging()
|
||||
# package up the results for the support organization
|
||||
if not self.opts.build:
|
||||
+ old_umask = os.umask(0o077)
|
||||
if not self.opts.quiet:
|
||||
print(_("Creating compressed archive..."))
|
||||
# compression could fail for a number of reasons
|
||||
@@ -1345,6 +1346,8 @@ class SoSReport(object):
|
||||
raise
|
||||
else:
|
||||
return False
|
||||
+ finally:
|
||||
+ os.umask(old_umask)
|
||||
else:
|
||||
final_filename = self.archive.get_archive_path()
|
||||
self.policy.display_results(final_filename, build=self.opts.build)
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,52 +0,0 @@
|
||||
diff -up sos-3.2/sos/sosreport.py.orig sos-3.2/sos/sosreport.py
|
||||
--- sos-3.2/sos/sosreport.py.orig 2015-01-20 14:39:34.149596845 +0000
|
||||
+++ sos-3.2/sos/sosreport.py 2015-01-20 14:39:56.132654519 +0000
|
||||
@@ -1131,11 +1131,13 @@ class SoSReport(object):
|
||||
% e.strerror)
|
||||
self.ui_log.error("")
|
||||
self._exit(1)
|
||||
+ if self.raise_plugins:
|
||||
+ raise
|
||||
+ self._log_plugin_exception(plugname, "setup")
|
||||
except:
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
- else:
|
||||
- self._log_plugin_exception(plugname, "setup")
|
||||
+ self._log_plugin_exception(plugname, "setup")
|
||||
|
||||
def version(self):
|
||||
"""Fetch version information from all plugins and store in the report
|
||||
@@ -1177,11 +1179,13 @@ class SoSReport(object):
|
||||
% e.strerror)
|
||||
self.ui_log.error("")
|
||||
self._exit(1)
|
||||
+ if self.raise_plugins:
|
||||
+ raise
|
||||
+ self._log_plugin_exception(plugname, "collect")
|
||||
except:
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
- else:
|
||||
- self._log_plugin_exception(plugname, "collect")
|
||||
+ self._log_plugin_exception(plugname, "collect")
|
||||
self.ui_log.info("")
|
||||
|
||||
def report(self):
|
||||
@@ -1324,12 +1328,13 @@ class SoSReport(object):
|
||||
% e.strerror)
|
||||
self.ui_log.error("")
|
||||
self._exit(1)
|
||||
+ if self.raise_plugins:
|
||||
+ raise
|
||||
+ self._log_plugin_exception(plugname, "postproc")
|
||||
except:
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
- else:
|
||||
- self._log_plugin_exception(plugname, "postproc")
|
||||
-
|
||||
+ self._log_plugin_exception(plugname, "postproc")
|
||||
|
||||
def final_work(self):
|
||||
# this must come before archive creation to ensure that log
|
@ -1,67 +0,0 @@
|
||||
From 8b49485153cc7dc03cd974dbc3a100c81ef04720 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 19 Jan 2015 19:40:06 +0000
|
||||
Subject: [PATCH] [sosreport] log plugin exceptions to a file
|
||||
|
||||
Add exception logging for the Plugin.postproc() method and move
|
||||
plugin exceptions into a separate per-plugin log file. This is
|
||||
less cluttered than pushing a multi-line traceback through the
|
||||
soslog.error logger and matches the behaviour of older releases.
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/sosreport.py | 17 +++++++++++++----
|
||||
1 file changed, 13 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/sos/sosreport.py b/sos/sosreport.py
|
||||
index 3c0397c..f17194a 100644
|
||||
--- a/sos/sosreport.py
|
||||
+++ b/sos/sosreport.py
|
||||
@@ -1071,8 +1071,14 @@ class SoSReport(object):
|
||||
self.ui_log.info("")
|
||||
self._exit()
|
||||
|
||||
- def _log_plugin_exception(self, plugin_name):
|
||||
- self.soslog.error("%s\n%s" % (plugin_name, traceback.format_exc()))
|
||||
+ def _log_plugin_exception(self, plugin, method):
|
||||
+ trace = traceback.format_exc()
|
||||
+ msg = "caught exception in plugin method"
|
||||
+ plugin_err_log = "%s-plugin-errors.txt" % plugin
|
||||
+ logpath = os.path.join(self.logdir, plugin_err_log)
|
||||
+ self.soslog.error('%s "%s.%s()"' % (msg, plugin, method))
|
||||
+ self.soslog.error('writing traceback to %s' % logpath)
|
||||
+ self.archive.add_string("%s\n" % trace, logpath)
|
||||
|
||||
def prework(self):
|
||||
self.policy.pre_work()
|
||||
@@ -1129,7 +1135,7 @@ class SoSReport(object):
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
else:
|
||||
- self._log_plugin_exception(plugname)
|
||||
+ self._log_plugin_exception(plugname, "setup")
|
||||
|
||||
def version(self):
|
||||
"""Fetch version information from all plugins and store in the report
|
||||
@@ -1175,7 +1181,7 @@ class SoSReport(object):
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
else:
|
||||
- self._log_plugin_exception(plugname)
|
||||
+ self._log_plugin_exception(plugname, "collect")
|
||||
self.ui_log.info("")
|
||||
|
||||
def report(self):
|
||||
@@ -1321,6 +1327,9 @@ class SoSReport(object):
|
||||
except:
|
||||
if self.raise_plugins:
|
||||
raise
|
||||
+ else:
|
||||
+ self._log_plugin_exception(plugname, "postproc")
|
||||
+
|
||||
|
||||
def final_work(self):
|
||||
# this must come before archive creation to ensure that log
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,310 +0,0 @@
|
||||
diff -up sos-3.2/sos/policies/__init__.py.orig sos-3.2/sos/policies/__init__.py
|
||||
--- sos-3.2/sos/policies/__init__.py.orig 2015-12-16 13:06:08.730706383 +0000
|
||||
+++ sos-3.2/sos/policies/__init__.py 2015-12-16 13:07:09.456189257 +0000
|
||||
@@ -10,11 +10,9 @@ from os import environ
|
||||
|
||||
from sos.utilities import (ImporterHelper,
|
||||
import_module,
|
||||
- get_hash_name,
|
||||
shell_out)
|
||||
from sos.plugins import IndependentPlugin
|
||||
from sos import _sos as _
|
||||
-import hashlib
|
||||
from textwrap import fill
|
||||
from six import print_
|
||||
from six.moves import input
|
||||
@@ -284,43 +282,29 @@ No changes will be made to system config
|
||||
considered to be a superuser"""
|
||||
return (os.getuid() == 0)
|
||||
|
||||
- def _create_checksum(self, final_filename=None):
|
||||
- if not final_filename:
|
||||
- return False
|
||||
-
|
||||
- archive_fp = open(final_filename, 'rb')
|
||||
- digest = hashlib.new(get_hash_name())
|
||||
- digest.update(archive_fp.read())
|
||||
- archive_fp.close()
|
||||
- return digest.hexdigest()
|
||||
-
|
||||
- def get_preferred_hash_algorithm(self):
|
||||
+ def get_preferred_hash_name(self):
|
||||
"""Returns the string name of the hashlib-supported checksum algorithm
|
||||
to use"""
|
||||
return "md5"
|
||||
|
||||
- def display_results(self, final_filename=None, build=False):
|
||||
+ def display_results(self, archive, directory, checksum):
|
||||
+ # Display results is called from the tail of SoSReport.final_work()
|
||||
+ #
|
||||
+ # Logging is already shutdown and all terminal output must use the
|
||||
+ # print() call.
|
||||
|
||||
# make sure a report exists
|
||||
- if not final_filename:
|
||||
+ if not archive and not directory:
|
||||
return False
|
||||
|
||||
self._print()
|
||||
|
||||
- if not build:
|
||||
- # store checksum into file
|
||||
- fp = open(final_filename + "." + get_hash_name(), "w")
|
||||
- checksum = self._create_checksum(final_filename)
|
||||
- if checksum:
|
||||
- fp.write(checksum + "\n")
|
||||
- fp.close()
|
||||
-
|
||||
+ if archive:
|
||||
self._print(_("Your sosreport has been generated and saved "
|
||||
- "in:\n %s") % final_filename)
|
||||
+ "in:\n %s") % archive)
|
||||
else:
|
||||
- checksum = None
|
||||
self._print(_("sosreport build tree is located at : %s" %
|
||||
- final_filename))
|
||||
+ directory))
|
||||
|
||||
self._print()
|
||||
if checksum:
|
||||
@@ -371,20 +355,28 @@ class LinuxPolicy(Policy):
|
||||
vendor = "None"
|
||||
PATH = "/bin:/sbin:/usr/bin:/usr/sbin"
|
||||
|
||||
+ _preferred_hash_name = None
|
||||
+
|
||||
def __init__(self, sysroot=None):
|
||||
super(LinuxPolicy, self).__init__(sysroot=sysroot)
|
||||
|
||||
- def get_preferred_hash_algorithm(self):
|
||||
+ def get_preferred_hash_name(self):
|
||||
+
|
||||
+ if self._preferred_hash_name:
|
||||
+ return self._preferred_hash_name
|
||||
+
|
||||
checksum = "md5"
|
||||
try:
|
||||
fp = open("/proc/sys/crypto/fips_enabled", "r")
|
||||
except:
|
||||
+ self._preferred_hash_name = checksum
|
||||
return checksum
|
||||
|
||||
fips_enabled = fp.read()
|
||||
if fips_enabled.find("1") >= 0:
|
||||
checksum = "sha256"
|
||||
fp.close()
|
||||
+ self._preferred_hash_name = checksum
|
||||
return checksum
|
||||
|
||||
def default_runlevel(self):
|
||||
diff -up sos-3.2/sos/sosreport.py.orig sos-3.2/sos/sosreport.py
|
||||
--- sos-3.2/sos/sosreport.py.orig 2015-12-16 13:06:08.748706527 +0000
|
||||
+++ sos-3.2/sos/sosreport.py 2015-12-16 13:07:09.458189272 +0000
|
||||
@@ -32,7 +32,9 @@ from sos.utilities import ImporterHelper
|
||||
from stat import ST_UID, ST_GID, ST_MODE, ST_CTIME, ST_ATIME, ST_MTIME, S_IMODE
|
||||
from time import strftime, localtime
|
||||
from collections import deque
|
||||
+from shutil import rmtree
|
||||
import tempfile
|
||||
+import hashlib
|
||||
|
||||
from sos import _sos as _
|
||||
from sos import __version__
|
||||
@@ -658,6 +660,7 @@ class SoSReport(object):
|
||||
self.tempfile_util = None
|
||||
self._args = args
|
||||
self.sysroot = "/"
|
||||
+ self.sys_tmp = None
|
||||
|
||||
try:
|
||||
import signal
|
||||
@@ -676,15 +679,22 @@ class SoSReport(object):
|
||||
|
||||
self._is_root = self.policy.is_root()
|
||||
|
||||
- self.tmpdir = os.path.abspath(
|
||||
- self.policy.get_tmp_dir(self.opts.tmp_dir))
|
||||
- if not os.path.isdir(self.tmpdir) \
|
||||
- or not os.access(self.tmpdir, os.W_OK):
|
||||
+ # system temporary directory to use
|
||||
+ tmp = os.path.abspath(self.policy.get_tmp_dir(self.opts.tmp_dir))
|
||||
+
|
||||
+ if not os.path.isdir(tmp) \
|
||||
+ or not os.access(tmp, os.W_OK):
|
||||
# write directly to stderr as logging is not initialised yet
|
||||
- sys.stderr.write("temporary directory %s " % self.tmpdir
|
||||
+ sys.stderr.write("temporary directory %s " % tmp
|
||||
+ "does not exist or is not writable\n")
|
||||
self._exit(1)
|
||||
+
|
||||
+ self.sys_tmp = tmp
|
||||
+
|
||||
+ # our (private) temporary directory
|
||||
+ self.tmpdir = tempfile.mkdtemp(prefix="sos.", dir=self.sys_tmp)
|
||||
self.tempfile_util = TempFileUtil(self.tmpdir)
|
||||
+
|
||||
self._set_directories()
|
||||
|
||||
self._setup_logging()
|
||||
@@ -1406,25 +1416,47 @@ class SoSReport(object):
|
||||
raise
|
||||
self._log_plugin_exception(plugname, "postproc")
|
||||
|
||||
+ def _create_checksum(self, archive, hash_name):
|
||||
+ if not archive:
|
||||
+ return False
|
||||
+
|
||||
+ archive_fp = open(archive, 'rb')
|
||||
+ digest = hashlib.new(hash_name)
|
||||
+ digest.update(archive_fp.read())
|
||||
+ archive_fp.close()
|
||||
+ return digest.hexdigest()
|
||||
+
|
||||
+ def _write_checksum(self, archive, hash_name, checksum):
|
||||
+ # store checksum into file
|
||||
+ fp = open(archive + "." + hash_name, "w")
|
||||
+ if checksum:
|
||||
+ fp.write(checksum + "\n")
|
||||
+ fp.close()
|
||||
+
|
||||
def final_work(self):
|
||||
- # this must come before archive creation to ensure that log
|
||||
+ # This must come before archive creation to ensure that log
|
||||
# files are closed and cleaned up at exit.
|
||||
+ #
|
||||
+ # All subsequent terminal output must use print().
|
||||
self._finish_logging()
|
||||
- # package up the results for the support organization
|
||||
+
|
||||
+ archive = None # archive path
|
||||
+ directory = None # report directory path (--build)
|
||||
+
|
||||
+ # package up and compress the results
|
||||
if not self.opts.build:
|
||||
old_umask = os.umask(0o077)
|
||||
if not self.opts.quiet:
|
||||
print(_("Creating compressed archive..."))
|
||||
# compression could fail for a number of reasons
|
||||
try:
|
||||
- final_filename = self.archive.finalize(
|
||||
+ archive = self.archive.finalize(
|
||||
self.opts.compression_type)
|
||||
except (OSError, IOError) as e:
|
||||
if e.errno in fatal_fs_errors:
|
||||
- self.ui_log.error("")
|
||||
- self.ui_log.error(" %s while finalizing archive"
|
||||
- % e.strerror)
|
||||
- self.ui_log.error("")
|
||||
+ print("")
|
||||
+ print(_(" %s while finalizing archive" % e.strerror))
|
||||
+ print("")
|
||||
self._exit(1)
|
||||
except:
|
||||
if self.opts.debug:
|
||||
@@ -1434,8 +1466,58 @@ class SoSReport(object):
|
||||
finally:
|
||||
os.umask(old_umask)
|
||||
else:
|
||||
- final_filename = self.archive.get_archive_path()
|
||||
- self.policy.display_results(final_filename, build=self.opts.build)
|
||||
+ # move the archive root out of the private tmp directory.
|
||||
+ directory = self.archive.get_archive_path()
|
||||
+ dir_name = os.path.basename(directory)
|
||||
+ try:
|
||||
+ os.rename(directory, os.path.join(self.sys_tmp, dir_name))
|
||||
+ except (OSError, IOError):
|
||||
+ print(_("Error moving directory: %s" % directory))
|
||||
+ return False
|
||||
+
|
||||
+ checksum = None
|
||||
+
|
||||
+ if not self.opts.build:
|
||||
+ # compute and store the archive checksum
|
||||
+ hash_name = self.policy.get_preferred_hash_name()
|
||||
+ checksum = self._create_checksum(archive, hash_name)
|
||||
+ self._write_checksum(archive, hash_name, checksum)
|
||||
+
|
||||
+ # output filename is in the private tmpdir - move it to the
|
||||
+ # containing directory.
|
||||
+ final_name = os.path.join(self.sys_tmp, os.path.basename(archive))
|
||||
+
|
||||
+ archive_hash = archive + "." + hash_name
|
||||
+ final_hash = final_name + "." + hash_name
|
||||
+
|
||||
+ # move the archive and checksum file
|
||||
+ try:
|
||||
+ os.rename(archive, final_name)
|
||||
+ archive = final_name
|
||||
+ except (OSError, IOError):
|
||||
+ print(_("Error moving archive file: %s" % archive))
|
||||
+ return False
|
||||
+
|
||||
+ # There is a race in the creation of the final checksum file:
|
||||
+ # since the archive has already been published and the checksum
|
||||
+ # file name is predictable once the archive name is known a
|
||||
+ # malicious user could attempt to create a symbolic link in order
|
||||
+ # to misdirect writes to a file of the attacker's choosing.
|
||||
+ #
|
||||
+ # To mitigate this we write the checksum inside the private tmp
|
||||
+ # directory and use an atomic rename that is guaranteed to either
|
||||
+ # succeed or fail: at worst the move will fail and be reported to
|
||||
+ # the user. The correct checksum value is still written to the
|
||||
+ # terminal and nothing is written to a location under the control
|
||||
+ # of the user creating the link.
|
||||
+ try:
|
||||
+ os.rename(archive_hash, final_hash)
|
||||
+ except (OSError, IOError):
|
||||
+ print(_("Error moving checksum file: %s" % archive_hash))
|
||||
+ return False
|
||||
+
|
||||
+ self.policy.display_results(archive, directory, checksum)
|
||||
+
|
||||
self.tempfile_util.clean()
|
||||
return True
|
||||
|
||||
@@ -1490,8 +1572,10 @@ class SoSReport(object):
|
||||
self.archive.cleanup()
|
||||
if self.tempfile_util:
|
||||
self.tempfile_util.clean()
|
||||
+ if self.tmpdir:
|
||||
+ rmtree(self.tmpdir)
|
||||
except:
|
||||
- pass
|
||||
+ raise
|
||||
|
||||
return False
|
||||
|
||||
diff -up sos-3.2/sos/utilities.py.orig sos-3.2/sos/utilities.py
|
||||
--- sos-3.2/sos/utilities.py.orig 2015-12-16 13:06:08.732706400 +0000
|
||||
+++ sos-3.2/sos/utilities.py 2015-12-16 13:07:09.455189249 +0000
|
||||
@@ -53,18 +53,6 @@ def fileobj(path_or_file, mode='r'):
|
||||
return closing(path_or_file)
|
||||
|
||||
|
||||
-def get_hash_name():
|
||||
- """Returns the algorithm used when computing a hash"""
|
||||
- import sos.policies
|
||||
- policy = sos.policies.load()
|
||||
- try:
|
||||
- name = policy.get_preferred_hash_algorithm()
|
||||
- hashlib.new(name)
|
||||
- return name
|
||||
- except:
|
||||
- return 'sha256'
|
||||
-
|
||||
-
|
||||
def convert_bytes(bytes_, K=1 << 10, M=1 << 20, G=1 << 30, T=1 << 40):
|
||||
"""Converts a number of bytes to a shorter, more human friendly format"""
|
||||
fn = float(bytes_)
|
||||
diff -up sos-3.2/tests/utilities_tests.py.orig sos-3.2/tests/utilities_tests.py
|
||||
--- sos-3.2/tests/utilities_tests.py.orig 2015-12-16 13:06:57.512094280 +0000
|
||||
+++ sos-3.2/tests/utilities_tests.py 2015-12-16 13:07:09.455189249 +0000
|
||||
@@ -5,7 +5,7 @@ import unittest
|
||||
import six
|
||||
from six import StringIO
|
||||
|
||||
-from sos.utilities import grep, get_hash_name, is_executable, sos_get_command_output, find, tail, shell_out
|
||||
+from sos.utilities import grep, is_executable, sos_get_command_output, find, tail, shell_out
|
||||
import sos
|
||||
|
||||
TEST_DIR = os.path.dirname(__file__)
|
@ -1,32 +0,0 @@
|
||||
From d0408ac43e1ec3b114e69b2950202f87f2fcd250 Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Mon, 19 Jan 2015 18:12:15 +0000
|
||||
Subject: [PATCH] [squid] collect logs from /var/log/squid
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/squid.py | 8 ++++++--
|
||||
1 file changed, 6 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/sos/plugins/squid.py b/sos/plugins/squid.py
|
||||
index 0d596e5..f1aea73 100644
|
||||
--- a/sos/plugins/squid.py
|
||||
+++ b/sos/plugins/squid.py
|
||||
@@ -29,8 +29,12 @@ class RedHatSquid(Squid, RedHatPlugin):
|
||||
packages = ('squid',)
|
||||
|
||||
def setup(self):
|
||||
- self.add_copy_spec_limit("/etc/squid/squid.conf",
|
||||
- sizelimit=self.get_option('log_size'))
|
||||
+ log_size = self.get_option('log_size')
|
||||
+ log_path = "/var/log/squid/"
|
||||
+ self.add_copy_spec_limit("/etc/squid/squid.conf", sizelimit=log_size)
|
||||
+ self.add_copy_spec_limit(log_path + "access.log", sizelimit=log_size)
|
||||
+ self.add_copy_spec_limit(log_path + "cache.log", sizelimit=log_size)
|
||||
+ self.add_copy_spec_limit(log_path + "squid.out", sizelimit=log_size)
|
||||
|
||||
|
||||
class DebianSquid(Squid, DebianPlugin, UbuntuPlugin):
|
||||
--
|
||||
1.9.3
|
||||
|
@ -1,131 +0,0 @@
|
||||
From 5280e3c73894805662c831d1f6cadda8233cf402 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Fri, 3 Apr 2015 09:53:46 +0200
|
||||
Subject: [PATCH 1/3] [virsh] add new plugin
|
||||
|
||||
Move the virsh commands and virt-manager logs into new plugin
|
||||
(corresponding to the 'libvirt-client' package on Red Hat distros).
|
||||
|
||||
Resolves #544
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/virsh.py | 46 ++++++++++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 46 insertions(+)
|
||||
create mode 100644 sos/plugins/virsh.py
|
||||
|
||||
diff --git a/sos/plugins/virsh.py b/sos/plugins/virsh.py
|
||||
new file mode 100644
|
||||
index 0000000..4b6bcc0
|
||||
--- /dev/null
|
||||
+++ b/sos/plugins/virsh.py
|
||||
@@ -0,0 +1,46 @@
|
||||
+# This program is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 2 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+
|
||||
+# This program is distributed in the hope that it will be useful,
|
||||
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program; if not, write to the Free Software
|
||||
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
+
|
||||
+from sos.plugins import Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin
|
||||
+import glob
|
||||
+import os
|
||||
+
|
||||
+
|
||||
+class LibvirtClient(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
+ """client for libvirt virtualization API
|
||||
+ """
|
||||
+
|
||||
+ plugin_name = 'virsh'
|
||||
+ profiles = ('system', 'virt')
|
||||
+
|
||||
+ packages = ('libvirt-client')
|
||||
+
|
||||
+ def setup(self):
|
||||
+ # virt-manager logs
|
||||
+ if not self.get_option("all_logs"):
|
||||
+ self.add_copy_spec_limit("/root/.virt-manager/*", sizelimit=5)
|
||||
+ else:
|
||||
+ self.add_copy_spec("/root/.virt-manager/*")
|
||||
+
|
||||
+ # get lit of VMs/domains
|
||||
+ domains_file = self.get_cmd_output_now('virsh list --all')
|
||||
+
|
||||
+ # cycle through the VMs/domains list, ignore 2 header lines and latest
|
||||
+ # empty line, and dumpxml domain name in 2nd column
|
||||
+ if domains_file:
|
||||
+ domains_lines = open(domains_file, "r").read().splitlines()[2:]
|
||||
+ for domain in filter(lambda x: x, domains_lines):
|
||||
+ self.add_cmd_output("virsh dumpxml %s" % domain.split()[1])
|
||||
+
|
||||
+# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 60373759aaa9f0668f0200e000e6c1949334597b Mon Sep 17 00:00:00 2001
|
||||
From: "Bryn M. Reeves" <bmr@redhat.com>
|
||||
Date: Tue, 30 Jun 2015 13:10:51 +0100
|
||||
Subject: [PATCH 2/3] [libvirt] add listing of /var/lib/libvirt/qemu
|
||||
|
||||
Signed-off-by: Bryn M. Reeves <bmr@redhat.com>
|
||||
---
|
||||
sos/plugins/libvirt.py | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/sos/plugins/libvirt.py b/sos/plugins/libvirt.py
|
||||
index 8d5dcfc..0b31d31 100644
|
||||
--- a/sos/plugins/libvirt.py
|
||||
+++ b/sos/plugins/libvirt.py
|
||||
@@ -58,6 +58,8 @@ class Libvirt(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
if os.path.exists(libvirt_keytab):
|
||||
self.add_cmd_output("klist -ket %s" % libvirt_keytab)
|
||||
|
||||
+ self.add_cmd_output("ls -lR /var/lib/libvirt/qemu")
|
||||
+
|
||||
def postproc(self):
|
||||
for xmlfile in glob.glob("/etc/libvirt/qemu/*.xml"):
|
||||
self.do_file_sub(
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
|
||||
From 26fa7d3ae5a6c31030ac045aeaa32452ad888df8 Mon Sep 17 00:00:00 2001
|
||||
From: Pavel Moravec <pmoravec@redhat.com>
|
||||
Date: Fri, 15 May 2015 16:10:41 +0200
|
||||
Subject: [PATCH 3/3] [virsh] make dumpxml calls read-only and set timeout=180
|
||||
|
||||
Call virsh dumpxml in read-only mode to bypass authentication
|
||||
and extend the command timeout to 180s.
|
||||
|
||||
Resolves #544
|
||||
|
||||
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
|
||||
---
|
||||
sos/plugins/virsh.py | 3 ++-
|
||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/sos/plugins/virsh.py b/sos/plugins/virsh.py
|
||||
index 4b6bcc0..0381b39 100644
|
||||
--- a/sos/plugins/virsh.py
|
||||
+++ b/sos/plugins/virsh.py
|
||||
@@ -41,6 +41,7 @@ class LibvirtClient(Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin):
|
||||
if domains_file:
|
||||
domains_lines = open(domains_file, "r").read().splitlines()[2:]
|
||||
for domain in filter(lambda x: x, domains_lines):
|
||||
- self.add_cmd_output("virsh dumpxml %s" % domain.split()[1])
|
||||
+ self.add_cmd_output("virsh -r dumpxml %s" % domain.split()[1],
|
||||
+ timeout=180)
|
||||
|
||||
# vim: et ts=4 sw=4
|
||||
--
|
||||
1.8.3.1
|
||||
|
162
sos.spec
162
sos.spec
@ -1,10 +1,11 @@
|
||||
%{!?python_sitelib: %define python_sitelib %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")}
|
||||
|
||||
Summary: A set of tools to gather troubleshooting information from a system
|
||||
Name: sos
|
||||
Version: 3.2
|
||||
Release: 6%{?dist}
|
||||
Version: 3.3
|
||||
Release: 1%{?dist}
|
||||
Group: Applications/System
|
||||
Source0: https://github.com/sosreport/sos/archive/%{version}/sos-%{version}.tar.gz
|
||||
Source0: https://github.com/sosreport/sos/archive/%{version}.tar.gz
|
||||
License: GPLv2+
|
||||
BuildArch: noarch
|
||||
Url: http://github.com/sosreport/sos
|
||||
@ -14,78 +15,6 @@ Requires: libxml2-python3
|
||||
Requires: bzip2
|
||||
Requires: xz
|
||||
Obsoletes: sos-plugins-openstack
|
||||
Patch0: sos-six-compat.patch
|
||||
Patch1: sos-call-rhsm-debug-with-no-subscriptions.patch
|
||||
Patch2: sos-powerpc-allow-powerpc-plugin-to-run-on-ppc64le.patch
|
||||
Patch3: sos-ovirt_hosted_engine-fix-exception-when-force-enabled.patch
|
||||
Patch4: sos-corosync-add-postprocessing-for-corosync-objctl.patch
|
||||
Patch5: sos-add-support-for-tomcat7.patch
|
||||
Patch6: sos-obtain-mysql-password-from-env.patch
|
||||
Patch7: sos-sosreport-fix-archive-permissions-regression.patch
|
||||
Patch8: sos-fix-kpatch-force-enabled.patch
|
||||
Patch9: sos-disable-the-zip-compression-type.patch
|
||||
Patch10: sos-navicli-catch-unreadable-stdin.patch
|
||||
Patch11: sos-docs-update-man-page-for-new-options.patch
|
||||
Patch12: sos-sos-unicode-use-errors-ignore.patch
|
||||
Patch13: sos-mysql-fix-command-line-dbpass-handling.patch
|
||||
Patch14: sos-anaconda-make-useradd-password-regex-tolerant.patch
|
||||
Patch15: sos-sosreport-catch-oserror-in-execute.patch
|
||||
Patch16: sos-sosreport-do-not-make-logging-calls-after-oserror.patch
|
||||
Patch17: sos-plugin-limit-names-to-pc_name_max.patch
|
||||
Patch18: sos-squid-collect-var-log-squid.patch
|
||||
Patch19: sos-sosreport-log-plugin-exceptions-to-file.patch
|
||||
Patch20: sos-ctdb-fix-redhatplugin-tagging-use.patch
|
||||
Patch21: sos-sosreport-fix-silent-exception-handling.patch
|
||||
Patch22: sos-mysql-test-for-boolean-values.patch
|
||||
Patch23: sos-mysql-improve-dbuser-dbpass-handling.patch
|
||||
Patch24: sos-cluster-crmreport-create-dir.patch
|
||||
Patch25: sos-openstack-neutron-to-collect-neutron-folders.patch
|
||||
Patch26: sos-ovirt-engine-remove-password-leak.patch
|
||||
Patch27: sos-fix-exception-when-networkmanager-disabled.patch
|
||||
Patch28: sos-openstack-sahara-plugin.patch
|
||||
Patch29: sos-redact-secrets-from-sahara-config.patch
|
||||
Patch30: sos-cluster-data-ownership.patch
|
||||
Patch31: sos-sat6-capsule-debug.patch
|
||||
Patch32: sos-httpd-collect-conf-modules.patch
|
||||
Patch33: sos-pcp-collect-config.patch
|
||||
Patch34: sos-puppet-collect-config.patch
|
||||
Patch35: sos-parted-no-human-readable.patch
|
||||
Patch36: sos-sos-ticket-number-name-params.patch
|
||||
Patch37: sos-network-more-diagnostic.patch
|
||||
Patch38: sos-infiniband-more-diagnostic.patch
|
||||
Patch39: sos-rabbitmq-cluster-status.patch
|
||||
Patch40: sos-networking-ip-addr.patch
|
||||
Patch41: sos-kimchid-plugin.patch
|
||||
Patch42: sos-iprconfig-plugin.patch
|
||||
Patch43: sos-ovirt-engine-config-domain-list.patch
|
||||
Patch44: sos-activemq-collect-logs-config.patch
|
||||
Patch45: sos-cluster-enable-when-luci-only.patch
|
||||
Patch46: sos-hpasm-no-data-timeout.patch
|
||||
Patch47: sos-mariadb-mysql-add-log.patch
|
||||
Patch48: sos-chrony-new-plugin.patch
|
||||
Patch49: sos-cluster-crm-report-password-sanitize.patch
|
||||
Patch50: sos-virsh-plugin.patch
|
||||
Patch51: sos-sap-hana-netweaver-vhostmd-plugins.patch
|
||||
Patch52: sos-sos-verify-profile-for-valid-plugins-only.patch
|
||||
Patch53: sos-kernel-additional-diagnostic.patch
|
||||
Patch54: sos-ceph-add-calamari-rados.patch
|
||||
Patch55: sos-iprconfig-enable-on-ppc64le.patch
|
||||
Patch56: sos-openstack_trove-plugin.patch
|
||||
Patch57: sos-services-add-more-diagnostics.patch
|
||||
Patch58: sos-openstack_neutron-obfuscate-passwords.patch
|
||||
Patch59: sos-policies-PackageManager-timeout.patch
|
||||
Patch60: sos-plugins-allow-discard-stderr.patch
|
||||
Patch61: sos-sos-inside-container.patch
|
||||
Patch62: sos-openstack-obfuscate-passwords-secrets.patch
|
||||
Patch63: sos-openvswitch-collect-logs-db-bridges.patch
|
||||
Patch64: sos-sapnw-cmd-output-check.patch
|
||||
Patch65: sos-logs-plugin-traceback.patch
|
||||
Patch66: sos-pick-up-symlink-targets.patch
|
||||
Patch67: sos-html-report-generate.patch
|
||||
Patch68: sos-collect-docker-daemon-logs.patch
|
||||
Patch69: sos-ceph-collect-var-lib-var-run.patch
|
||||
Patch70: sos-sosreport-prepare-report-in-a-private-subdirectory.patch
|
||||
Patch71: sos-clean-up-private-temp.patch
|
||||
|
||||
%description
|
||||
Sos is a set of tools that gathers information about system
|
||||
@ -95,84 +24,12 @@ support technicians and developers.
|
||||
|
||||
%prep
|
||||
%setup -qn %{name}-%{version}
|
||||
%patch0 -p1
|
||||
%patch1 -p1
|
||||
%patch2 -p1
|
||||
%patch3 -p1
|
||||
%patch4 -p1
|
||||
%patch5 -p1
|
||||
%patch6 -p1
|
||||
%patch7 -p1
|
||||
%patch8 -p1
|
||||
%patch9 -p1
|
||||
%patch10 -p1
|
||||
%patch11 -p1
|
||||
%patch12 -p1
|
||||
%patch13 -p1
|
||||
%patch14 -p1
|
||||
%patch15 -p1
|
||||
%patch16 -p1
|
||||
%patch17 -p1
|
||||
%patch18 -p1
|
||||
%patch19 -p1
|
||||
%patch20 -p1
|
||||
%patch21 -p1
|
||||
%patch22 -p1
|
||||
%patch23 -p1
|
||||
%patch24 -p1
|
||||
%patch25 -p1
|
||||
%patch26 -p1
|
||||
%patch27 -p1
|
||||
%patch28 -p1
|
||||
%patch29 -p1
|
||||
%patch30 -p1
|
||||
%patch31 -p1
|
||||
%patch32 -p1
|
||||
%patch33 -p1
|
||||
%patch34 -p1
|
||||
%patch35 -p1
|
||||
%patch36 -p1
|
||||
%patch37 -p1
|
||||
%patch38 -p1
|
||||
%patch39 -p1
|
||||
%patch40 -p1
|
||||
%patch41 -p1
|
||||
%patch42 -p1
|
||||
%patch43 -p1
|
||||
%patch44 -p1
|
||||
%patch45 -p1
|
||||
%patch46 -p1
|
||||
%patch47 -p1
|
||||
%patch48 -p1
|
||||
%patch49 -p1
|
||||
%patch50 -p1
|
||||
%patch51 -p1
|
||||
%patch52 -p1
|
||||
%patch53 -p1
|
||||
%patch54 -p1
|
||||
%patch55 -p1
|
||||
%patch56 -p1
|
||||
%patch57 -p1
|
||||
%patch58 -p1
|
||||
%patch59 -p1
|
||||
%patch60 -p1
|
||||
%patch61 -p1
|
||||
%patch62 -p1
|
||||
%patch63 -p1
|
||||
%patch64 -p1
|
||||
%patch65 -p1
|
||||
%patch66 -p1
|
||||
%patch67 -p1
|
||||
%patch68 -p1
|
||||
%patch69 -p1
|
||||
%patch70 -p1
|
||||
%patch71 -p1
|
||||
|
||||
%build
|
||||
%{__python3} setup.py build
|
||||
%py3_build
|
||||
|
||||
%install
|
||||
%{__python3} setup.py install --skip-build --root %{buildroot} --install-scripts %{_sbindir}
|
||||
%py3_install '--install-scripts=%{_sbindir}'
|
||||
|
||||
install -Dm644 %{name}.conf %{buildroot}%{_sysconfdir}/%{name}.conf
|
||||
|
||||
@ -183,10 +40,15 @@ install -Dm644 %{name}.conf %{buildroot}%{_sysconfdir}/%{name}.conf
|
||||
%{python3_sitelib}/*
|
||||
%{_mandir}/man1/*
|
||||
%{_mandir}/man5/*
|
||||
%doc AUTHORS README.md LICENSE
|
||||
%doc AUTHORS README.md
|
||||
%license LICENSE
|
||||
%config(noreplace) %{_sysconfdir}/sos.conf
|
||||
|
||||
%changelog
|
||||
* Thu Feb 23 2017 Sandro Bonazzola <sbonazzo@fedoraproject.org> - 3.3-1
|
||||
- Rebase on upstream 3.3
|
||||
- Resolves: BZ#1411314
|
||||
|
||||
* Sat Feb 11 2017 Fedora Release Engineering <releng@fedoraproject.org> - 3.2-6
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user