1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
# 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.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
import re
from sos.plugins import (Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin,
SuSEPlugin)
class ClearContainers(Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin,
SuSEPlugin):
"""Intel(R) Clear Containers configuration
"""
plugin_name = 'clear_containers'
profiles = ('system', 'virt', 'container')
runtime = 'cc-runtime'
packages = (runtime,)
def attach_cc_config_files(self):
# start with the default file locations
config_files = [
'/etc/clear-containers/configuration.toml'
'/usr/share/defaults/clear-containers/configuration.toml'
]
# obtain a list of config files by asking the runtime
cmd = '{} --cc-show-default-config-paths'.format(self.runtime)
configs = self.get_command_output(cmd)['output']
for config in configs.splitlines():
if config != "":
config_files.append(config)
# get a unique list of config files
config_files = set(config_files)
self.add_copy_spec(config_files)
def attach_cc_log_files(self):
# start with the default global log
log_files = [
'/var/lib/clear-containers/runtime/runtime.log'
]
# query the runtime to find the configured global log file
cmd = '{} cc-env'.format(self.runtime)
output = self.get_command_output(cmd)['output']
for line in output.splitlines():
result = re.search(r'\bGlobalLogPath\b\s+=\s+"(.+)"', line)
if result:
global_logfile = result.group(1)
if global_logfile:
log_files.append(global_logfile)
break
# get a unique list of log files
log_files = set(log_files)
self.add_copy_spec(log_files, self.limit)
def setup(self):
self.limit = self.get_option("log_size")
if self.get_option("all_logs"):
# no limit on amount of data recorded
self.limit = None
self.add_cmd_output('{} cc-env'.format(self.runtime))
self.attach_cc_config_files()
self.attach_cc_log_files()
self.add_journal(units="cc-proxy")
self.add_journal(identifier="cc-shim")
# vim: set et ts=4 sw=4 :
|