1
0
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:
Adolfo Gómez García 2017-03-22 11:55:39 +01:00
parent 8b644d4fec
commit a80fc629a2
4 changed files with 125 additions and 9 deletions

View 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')

View File

@ -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)

View File

@ -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)

View File

@ -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