summaryrefslogtreecommitdiffstats
path: root/common/README.md
blob: 537c8eab0402b23dcfa8ded95b7d27eb3caba4c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<!---
Copyright 2015 Open Platform for NFV Project, Inc. and its contributors

    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.
-->
# Common
This directory contains those files which belong to the "OPNFV-Installation and Maintenance" phase of the installation process.

The OPNFV install process consists of two main phases:
* **BASE-INSTALLATION:** Installation of plain-vanilla VM-manager (for BGS, OpenStack will be used as VM-Manager)
 * (repeatable) install of a plain vanilla VM-manager (for BGS this is OpenStack) that deploys to bare metal and supports a HA-setup of the VM-manager
 * the installation is performed with an installer “i” that creates a system in state BASE(i).
 * Files which are specific to an installer process are found in the directory of the associated installer approach (e.g. "fuel", "foreman", "opensteak", etc.)
 * Once the installation of the plain vanilla environment is complete, the installer i is terminated. The system is left in state BASE(i) and handed over to the second phase.
* **OPNFV-INSTALLATION and MAINTENANCE:** Installation of OPNFV specific modules, maintenance of the overall OPNFV installation
 * the system state for this second phase is called OPNFV(x) - where x is determined by a particular OPNFV release item.
 * install deltas to state BASE(i) to reach the desired state OPNFV(x). Deltas would be defined as a set of scripts/manifests. Given that the state BASE(i) differs by installer used, the scripts could also be different. That said, it is a clear objective to make these scripts as generic and independent from the installer used as possible.
 * maintain the system in state OPNFV(x)
 * decouple device configuration from orchestration; allow for different tool chains to be used for device configuration and orchestration. I.e. rather than couple device config and orchestration with a single tool such as puppet in master-agent mode, enable a single tool to be focused on config (e.g. puppet in master-less mode) and another one for orchestration (e.g. Ansible/Salt driving upgrade of components, download of particular manifests to the nodes etc.
esource_inventory.resource_manager import ResourceManager from resource_inventory.models import ConfigState @shared_task def booking_poll(): def cleanup_resource_task(qs): for hostrelation in qs: hostrelation.config.state = ConfigState.CLEAN hostrelation.config.save() hostrelation.status = JobStatus.NEW hostrelation.save() def cleanup_software(qs): if qs.exists(): relation = qs.first() software = relation.config.opnfv software.clear_delta() software.save() relation.status = JobStatus.NEW relation.save() def cleanup_access(qs): for relation in qs: if "vpn" in relation.config.access_type.lower(): relation.config.set_revoke(True) relation.config.save() relation.status = JobStatus.NEW relation.save() cleanup_set = Booking.objects.filter(end__lte=timezone.now()).filter(job__complete=False) for booking in cleanup_set: if not booking.job.complete: job = booking.job cleanup_software(SoftwareRelation.objects.filter(job=job)) cleanup_resource_task(HostHardwareRelation.objects.filter(job=job)) cleanup_resource_task(HostNetworkRelation.objects.filter(job=job)) cleanup_access(AccessRelation.objects.filter(job=job)) job.complete = True job.save() NotificationHandler.notify_booking_end(booking) @shared_task def free_hosts(): """Free all hosts that should be freed.""" undone_statuses = [JobStatus.NEW, JobStatus.CURRENT, JobStatus.ERROR] undone_jobs = Job.objects.filter( hostnetworkrelation__status__in=undone_statuses, hosthardwarerelation__status__in=undone_statuses ) bookings = Booking.objects.exclude( job__in=undone_jobs ).filter( end__lt=timezone.now(), job__complete=True, resource__isnull=False ) for booking in bookings: ResourceManager.getInstance().releaseResourceBundle(booking.resource) @shared_task def query_vpn_users(): """ get active vpn users """ JobFactory.makeActiveUsersTask()