mirror of
https://github.com/dkmstr/openuds.git
synced 2025-01-10 01:17:59 +03:00
Backported ovirt cleanups from 2.5 to 2.1
This commit is contained in:
parent
8b644d4fec
commit
a80fc629a2
114
server/src/uds/services/OVirt/OVirtJobs.py
Normal file
114
server/src/uds/services/OVirt/OVirtJobs.py
Normal file
@ -0,0 +1,114 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
#
|
||||
# Copyright (c) 2012-2017 Virtual Cable S.L.
|
||||
# All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without modification,
|
||||
# are permitted provided that the following conditions are met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright notice,
|
||||
# this list of conditions and the following disclaimer.
|
||||
# * Redistributions in binary form must reproduce the above copyright notice,
|
||||
# this list of conditions and the following disclaimer in the documentation
|
||||
# and/or other materials provided with the distribution.
|
||||
# * Neither the name of Virtual Cable S.L. nor the names of its contributors
|
||||
# may be used to endorse or promote products derived from this software
|
||||
# without specific prior written permission.
|
||||
#
|
||||
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
'''
|
||||
@author: Adolfo Gómez, dkmaster at dkmon dot com
|
||||
'''
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from uds.core import jobs
|
||||
from uds.core.util import log
|
||||
from uds.core.util.State import State
|
||||
|
||||
from uds.models import Provider, Service, getSqlDatetime
|
||||
|
||||
|
||||
import logging
|
||||
import time
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class OVirtHouseKeeping(jobs.Job):
|
||||
frecuency = 60 * 60 * 24 * 15 + 1 # Once every 15 days
|
||||
friendly_name = 'Ovirt house keeping'
|
||||
|
||||
def run(self):
|
||||
return
|
||||
|
||||
|
||||
class OVirtDeferredRemoval(jobs.Job):
|
||||
frecuency = 60 * 5 # Once every NN minutes
|
||||
friendly_name = 'Ovirt removal'
|
||||
counter = 0
|
||||
|
||||
@staticmethod
|
||||
def remove(providerInstance, vmId):
|
||||
logger.debug('Adding {} from {} to defeffed removal process'.format(vmId, providerInstance))
|
||||
OVirtDeferredRemoval.counter += 1
|
||||
try:
|
||||
# Tries to stop machine sync when found, if any error is done, defer removal for a scheduled task
|
||||
try:
|
||||
# First check state & stop machine if needed
|
||||
state = providerInstance.getMachineState(vmId)
|
||||
if state in ('up', 'powering_up', 'suspended'):
|
||||
providerInstance.stopMachine(vmId)
|
||||
elif state != 'unknown': # Machine exists, remove it later
|
||||
|
||||
providerInstance.storage.saveData('tr' + vmId, vmId, attr1='tRm')
|
||||
|
||||
except Exception as e:
|
||||
providerInstance.storage.saveData('tr' + vmId, vmId, attr1='tRm')
|
||||
logger.info('Machine {} could not be removed right now, queued for later: {}'.format(vmId, e))
|
||||
|
||||
except Exception as e:
|
||||
logger.warn('Exception got queuing for Removal: {}'.format(e))
|
||||
|
||||
def run(self):
|
||||
from .OVirtProvider import Provider as OVirtProvider
|
||||
|
||||
logger.debug('Looking for deferred vm removals')
|
||||
|
||||
# Look for Providers of type VCServiceProvider
|
||||
for provider in Provider.objects.filter(maintenance_mode=False, data_type=OVirtProvider.typeType):
|
||||
logger.debug('Provider {} if os type ovirt'.format(provider))
|
||||
|
||||
storage = provider.getEnvironment().storage
|
||||
instance = provider.getInstance()
|
||||
|
||||
for i in storage.filter('tRm'):
|
||||
vmId = i[1]
|
||||
try:
|
||||
logger.debug('Found {} for removal {}'.format(vmId, i))
|
||||
# If machine is powered on, tries to stop it
|
||||
# tries to remove in sync mode
|
||||
state = instance.getMachineState(vmId)
|
||||
if state in ('up', 'powering_up', 'suspended'):
|
||||
instance.stopMachine(vmId)
|
||||
return
|
||||
|
||||
if state != 'unknown': # Machine exists, try to remove it now
|
||||
instance.removeMachine(vmId)
|
||||
|
||||
# It this is reached, remove check
|
||||
storage.remove('tr' + vmId)
|
||||
except Exception as e: # Any other exception wil be threated again
|
||||
instance.doLog('Delayed removal of {} has failed: {}. Will retry later'.format(vmId, e))
|
||||
logger.error('Delayed removal of {} failed: {}'.format(i, e))
|
||||
|
||||
logger.debug('Deferred removal finished')
|
@ -1,7 +1,7 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
#
|
||||
# Copyright (c) 2012 Virtual Cable S.L.
|
||||
# Copyright (c) 2012-2017 Virtual Cable S.L.
|
||||
# All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without modification,
|
||||
@ -33,11 +33,12 @@
|
||||
from uds.core.services import UserDeployment
|
||||
from uds.core.util.State import State
|
||||
from uds.core.util import log
|
||||
from .OVirtJobs import OVirtDeferredRemoval
|
||||
|
||||
import pickle
|
||||
import logging
|
||||
|
||||
__updated__ = '2017-03-17'
|
||||
__updated__ = '2017-03-22'
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
@ -271,12 +272,7 @@ class OVirtLinkedDeployment(UserDeployment):
|
||||
self.doLog(log.ERROR, reason)
|
||||
|
||||
if self._vmid != '': # Powers off
|
||||
try:
|
||||
state = self.service().getMachineState(self._vmid)
|
||||
if state in ('up', 'powering_up', 'suspended'):
|
||||
self.service().stopMachine(self._vmid)
|
||||
except:
|
||||
logger.debug('Can\t set machine state to stopped')
|
||||
OVirtDeferredRemoval.remove(self.service().parent(), self._vmid)
|
||||
|
||||
self._queue = [opError]
|
||||
self._reason = str(reason)
|
||||
|
@ -29,4 +29,10 @@
|
||||
|
||||
|
||||
from .OVirtProvider import Provider
|
||||
from .OVirtJobs import OVirtHouseKeeping, OVirtDeferredRemoval
|
||||
|
||||
from uds.core import managers
|
||||
|
||||
# Scheduled task to do clean processes
|
||||
for cls in (OVirtDeferredRemoval, OVirtHouseKeeping):
|
||||
managers.taskManager().registerJob(cls)
|
||||
|
@ -5,8 +5,8 @@ Created on Nov 14, 2012
|
||||
'''
|
||||
|
||||
import ovirtsdk4 as ovirt
|
||||
import oivrtsdk4.types as ovirtTypes # @UnresolvedImport @UnusedImport
|
||||
|
||||
import time
|
||||
import threading
|
||||
import logging
|
||||
import six
|
||||
|
Loading…
Reference in New Issue
Block a user