mirror of
https://github.com/dkmstr/openuds.git
synced 2025-01-25 06:03:51 +03:00
Added defred removal for cleaning up on ovirt as done on other
hypervisors
This commit is contained in:
parent
4e2e023ac6
commit
8fb4f190e6
123
server/src/uds/services/OVirt/OVirtJobs.py
Normal file
123
server/src/uds/services/OVirt/OVirtJobs.py
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
# -*- 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):
|
||||||
|
from .OVirtLinkedService import OVirtLinkedService
|
||||||
|
from django.db.models import Q
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
releaseOlderThan = getSqlDatetime(True) - self.frecuency
|
||||||
|
|
||||||
|
for a in Service.objects.all():
|
||||||
|
if a.isOfType(OVirtLinkedService.typeType):
|
||||||
|
log.doLog(a, log.INFO, 'Cleaning contained macs & names older than {0}'.format(datetime.fromtimestamp(releaseOlderThan)), log.SERVICE)
|
||||||
|
a.getEnvironment().idGenerators('mac').releaseOlderThan(releaseOlderThan)
|
||||||
|
|
||||||
|
|
||||||
|
class OVirtDeferredRemoval(jobs.Job):
|
||||||
|
frecuency = 60 * 60 # Once every minute
|
||||||
|
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)
|
||||||
|
|
||||||
|
if 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 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2012 Virtual Cable S.L.
|
# Copyright (c) 2012-2017 Virtual Cable S.L.
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without modification,
|
# 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.services import UserDeployment
|
||||||
from uds.core.util.State import State
|
from uds.core.util.State import State
|
||||||
from uds.core.util import log
|
from uds.core.util import log
|
||||||
|
from .OVirtJobs import OVirtDeferredRemoval
|
||||||
|
|
||||||
import pickle
|
import pickle
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
__updated__ = '2017-03-17'
|
__updated__ = '2017-03-22'
|
||||||
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
@ -271,12 +272,7 @@ class OVirtLinkedDeployment(UserDeployment):
|
|||||||
self.doLog(log.ERROR, reason)
|
self.doLog(log.ERROR, reason)
|
||||||
|
|
||||||
if self._vmid != '': # Powers off
|
if self._vmid != '': # Powers off
|
||||||
try:
|
OVirtDeferredRemoval.remove(self.service().parent(), self._vmid)
|
||||||
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')
|
|
||||||
|
|
||||||
self._queue = [opError]
|
self._queue = [opError]
|
||||||
self._reason = str(reason)
|
self._reason = str(reason)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user