With the events of eventlet removal, Watcher will need to be adapted to support both modes, eventlet and threading, for a couple of releases before removing all eventlet code. This patch adds methods and classes that allow decision engine modules to create futurist thread pools instead of green thread pools, based on a environment variable that can be enabled by service. It moves continuous audit handler instance to decison engine service, so it can be started together with the main decision engine service. Adds an environment variable that allows the user to disable eventlet monkey patching and to use oslo.service threading backend. Change-Id: I8a8be0a7cebdc44005fd77ec960543828c7da318 Signed-off-by: Douglas Viroel <viroel@gmail.com>
59 lines
2.0 KiB
Python
59 lines
2.0 KiB
Python
# -*- encoding: utf-8 -*-
|
|
# Copyright (c) 2015 b<>com
|
|
#
|
|
# Authors: Jean-Emile DARTOIS <jean-emile.dartois@b-com.com>
|
|
#
|
|
# 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 oslo_config import cfg
|
|
from oslo_log import log
|
|
|
|
from watcher.common import executor
|
|
from watcher.decision_engine.audit import event as e_handler
|
|
from watcher.decision_engine.audit import oneshot as o_handler
|
|
|
|
from watcher import objects
|
|
|
|
CONF = cfg.CONF
|
|
LOG = log.getLogger(__name__)
|
|
|
|
|
|
class AuditEndpoint(object):
|
|
|
|
def __init__(self, messaging):
|
|
self._messaging = messaging
|
|
self.amount_workers = CONF.watcher_decision_engine.max_audit_workers
|
|
self._executor = (
|
|
executor.get_futurist_pool_executor(self.amount_workers))
|
|
self._oneshot_handler = o_handler.OneShotAuditHandler()
|
|
self._event_handler = e_handler.EventAuditHandler()
|
|
|
|
@property
|
|
def executor(self):
|
|
return self._executor
|
|
|
|
def do_trigger_audit(self, context, audit_uuid):
|
|
audit = objects.Audit.get_by_uuid(context, audit_uuid, eager=True)
|
|
if audit.audit_type == objects.audit.AuditType.ONESHOT.value:
|
|
self._oneshot_handler.execute(audit, context)
|
|
if audit.audit_type == objects.audit.AuditType.EVENT.value:
|
|
self._event_handler.execute(audit, context)
|
|
|
|
def trigger_audit(self, context, audit_uuid):
|
|
LOG.debug("Trigger audit %s", audit_uuid)
|
|
self.executor.submit(self.do_trigger_audit,
|
|
context,
|
|
audit_uuid)
|
|
return audit_uuid
|