Part 2 of 6: blueprint general-bare-metal-provisioning-framework In baremetal provisioning, one nova-compute manages multiple bare-metal machines. A bare-metal machine does not run openstack at all. Previously, bare-metal provisioning used text files to store information of bare-metal machines. In this patch, a MySQL database is used to store the information. We target only MySQL database. The DB is designed to support PXE/non-PXE booting methods, heterogeneous hypervisor types, and architectures. Using a MySQL database makes maintenance and upgrades easier than using text files. The DB for bare-metal machines is implemented as a separate DB from the main Nova DB. The DB can be on any machines/places. The location of the DB and its server needs to be specified as a flag in the nova.conf file (as in the case of glance). There are a couple of reasons for this approach. First, the information needed for bare-metal machines is different from that for non-bare-metal machines. With a separate database for bare-metal machines, the database can be customized without affecting the main Nova DB. Second, fault tolerance can be embedded in nova-compute. Since one nova-compute manages multiple bare-metal machines, fault tolerance of a nova-compute node is very important. With a separate DB for bare-metal machines, fault-tolerance can be achieved independently from the main Nova DB. Replication of the bare-metal DB and implementation of fault-tolerance are not part of this patch. The implementation models nova and its DB as much as possible. The bare-metal driver must be upgraded to use this DB. Change-Id: I7b7ba1903a672a50c567f95fc6554d119463b0c5 Co-authored-by: Mikyung Kang <mkkang@isi.edu> Co-authored-by: David Kang <dkang@isi.edu> Co-authored-by: Ken Igarashi <igarashik@nttdocomo.co.jp> Co-authored-by: Arata Notsu <notsu@virtualtech.jp>
82 lines
3.1 KiB
Python
82 lines
3.1 KiB
Python
# Copyright (c) 2012 NTT DOCOMO, INC.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
|
|
"""Bare-metal test utils."""
|
|
|
|
from nova import test
|
|
from nova.virt.baremetal.db.sqlalchemy import models as bm_models
|
|
|
|
|
|
def new_bm_node(**kwargs):
|
|
h = bm_models.BareMetalNode()
|
|
h.id = kwargs.pop('id', None)
|
|
h.service_host = kwargs.pop('service_host', None)
|
|
h.instance_uuid = kwargs.pop('instance_uuid', None)
|
|
h.cpus = kwargs.pop('cpus', 1)
|
|
h.memory_mb = kwargs.pop('memory_mb', 1024)
|
|
h.local_gb = kwargs.pop('local_gb', 64)
|
|
h.pm_address = kwargs.pop('pm_address', '192.168.1.1')
|
|
h.pm_user = kwargs.pop('pm_user', 'ipmi_user')
|
|
h.pm_password = kwargs.pop('pm_password', 'ipmi_password')
|
|
h.prov_mac_address = kwargs.pop('prov_mac_address', '12:34:56:78:90:ab')
|
|
h.registration_status = kwargs.pop('registration_status', 'done')
|
|
h.task_state = kwargs.pop('task_state', None)
|
|
h.prov_vlan_id = kwargs.pop('prov_vlan_id', None)
|
|
h.terminal_port = kwargs.pop('terminal_port', 8000)
|
|
if len(kwargs) > 0:
|
|
raise test.TestingException("unknown field: %s"
|
|
% ','.join(kwargs.keys()))
|
|
return h
|
|
|
|
|
|
def new_bm_pxe_ip(**kwargs):
|
|
x = bm_models.BareMetalPxeIp()
|
|
x.id = kwargs.pop('id', None)
|
|
x.address = kwargs.pop('address', None)
|
|
x.server_address = kwargs.pop('server_address', None)
|
|
x.bm_node_id = kwargs.pop('bm_node_id', None)
|
|
if len(kwargs) > 0:
|
|
raise test.TestingException("unknown field: %s"
|
|
% ','.join(kwargs.keys()))
|
|
return x
|
|
|
|
|
|
def new_bm_interface(**kwargs):
|
|
x = bm_models.BareMetalInterface()
|
|
x.id = kwargs.pop('id', None)
|
|
x.bm_node_id = kwargs.pop('bm_node_id', None)
|
|
x.address = kwargs.pop('address', None)
|
|
x.datapath_id = kwargs.pop('datapath_id', None)
|
|
x.port_no = kwargs.pop('port_no', None)
|
|
x.vif_uuid = kwargs.pop('vif_uuid', None)
|
|
if len(kwargs) > 0:
|
|
raise test.TestingException("unknown field: %s"
|
|
% ','.join(kwargs.keys()))
|
|
return x
|
|
|
|
|
|
def new_bm_deployment(**kwargs):
|
|
x = bm_models.BareMetalDeployment()
|
|
x.id = kwargs.pop('id', None)
|
|
x.key = kwargs.pop('key', None)
|
|
x.image_path = kwargs.pop('image_path', None)
|
|
x.pxe_config_path = kwargs.pop('pxe_config_path', None)
|
|
x.root_mb = kwargs.pop('root_mb', None)
|
|
x.swap_mb = kwargs.pop('swap_mb', None)
|
|
if len(kwargs) > 0:
|
|
raise test.TestingException("unknown field: %s"
|
|
% ','.join(kwargs.keys()))
|
|
return x
|