696606f682
Change-Id: I64e66682c1e54f6edc260a22f46f5f6df8e85af1 Story: 2005896 Task: 33756
87 lines
3.2 KiB
Python
87 lines
3.2 KiB
Python
# 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.
|
|
|
|
import os
|
|
import select
|
|
import threading
|
|
|
|
from ironic_lib import exception
|
|
from oslo_config import cfg
|
|
from oslo_log import log
|
|
|
|
from ironic_python_agent import errors
|
|
from ironic_python_agent import inspector
|
|
|
|
LOG = log.getLogger(__name__)
|
|
|
|
|
|
class IronicInspection(threading.Thread):
|
|
"""Class for manual inspection functionality."""
|
|
|
|
def __init__(self):
|
|
super(IronicInspection, self).__init__()
|
|
if bool(cfg.CONF.keyfile) != bool(cfg.CONF.certfile):
|
|
LOG.warning("Only one of 'keyfile' and 'certfile' options is "
|
|
"defined in config file. Its value will be ignored.")
|
|
|
|
def _run(self):
|
|
try:
|
|
daemon_mode = cfg.CONF.introspection_daemon
|
|
post_interval = cfg.CONF.introspection_daemon_post_interval
|
|
|
|
inspector.inspect()
|
|
if not daemon_mode:
|
|
# No reason to continue unless we're in daemon mode.
|
|
return
|
|
|
|
self.reader, self.writer = os.pipe()
|
|
p = select.poll()
|
|
p.register(self.reader)
|
|
|
|
try:
|
|
while daemon_mode:
|
|
LOG.info('Sleeping until next check-in.')
|
|
# TODO(TheJulia): It would likely be good to introduce
|
|
# some jitter into this at some point...
|
|
if p.poll(post_interval * 1000):
|
|
if os.read(self.reader, 1).decode() == 'a':
|
|
break
|
|
try:
|
|
inspector.inspect()
|
|
except errors.InspectionError as e:
|
|
# Failures happen, no reason to exit as
|
|
# the failure could be intermittent.
|
|
LOG.warning('Error reporting introspection '
|
|
'data: %(err)s',
|
|
{'err': e})
|
|
except exception.ServiceLookupFailure as e:
|
|
# Likely a mDNS lookup failure. We should
|
|
# keep retrying.
|
|
LOG.error('Error looking up introspection '
|
|
'endpoint: %(err)s',
|
|
{'err': e})
|
|
|
|
finally:
|
|
os.close(self.reader)
|
|
os.close(self.writer)
|
|
self.reader = None
|
|
self.writer = None
|
|
except errors.InspectionError as e:
|
|
msg = "Inspection failed: %s" % e
|
|
raise errors.InspectionError(msg)
|
|
|
|
def run(self):
|
|
"""Run Inspection."""
|
|
if not cfg.CONF.inspection_callback_url:
|
|
cfg.CONF.set_override('inspection_callback_url', 'mdns')
|
|
self._run()
|