
The log extension is responsible for retrieving logs from the system, if journalctl is present the logs will come from it, otherwise we fallback to getting the logs from the /var/log directory + dmesg logs. In the coreos ramdisk, we need to bind mount /run/log in the container so the IPA service can have access to the journal. For the tinyIPA ramdisk, the logs from IPA are now being redirected to /var/logs/ironic-python-agent.log instead of only going to the default stdout. Inspector now shares the same method of collecting logs, extending its capabilities for non-systemd systems. Partial-Bug: #1587143 Change-Id: Ie507e2e5c58cffa255bbfb2fa5ffb95cb98ed8c4
35 lines
1.3 KiB
Python
35 lines
1.3 KiB
Python
# Copyright 2016 Red Hat, Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
from ironic_python_agent.extensions import base
|
|
from ironic_python_agent import utils
|
|
|
|
|
|
class LogExtension(base.BaseAgentExtension):
|
|
|
|
@base.sync_command('collect_system_logs')
|
|
def collect_system_logs(self):
|
|
"""Collect system logs.
|
|
|
|
Collect and package diagnostic and support data from the ramdisk.
|
|
|
|
:raises: CommandExecutionError if failed to collect the system logs.
|
|
:returns: A dictionary with the key `system_logs` and the value
|
|
of a gzipped and base64 encoded string of the file with
|
|
the logs.
|
|
"""
|
|
logs = utils.collect_system_logs()
|
|
return {'system_logs': logs}
|