Merge "New post-deploy task for astute for multi HV support"
This commit is contained in:
commit
5956f0be54
@ -42,3 +42,12 @@
|
||||
puppet_modules: /etc/puppet/modules
|
||||
timeout: 3600
|
||||
cwd: /
|
||||
|
||||
- id: vcenter_compute_zones_create
|
||||
type: shell
|
||||
role: [primary-controller]
|
||||
stage: post_deployment
|
||||
condition: "settings:common.use_vcenter.value == true"
|
||||
parameters:
|
||||
cmd: /usr/bin/python /etc/puppet/modules/osnailyfacter/modular/astute/vcenter_compute_zones.py
|
||||
timeout: 180
|
||||
|
@ -0,0 +1,76 @@
|
||||
#!/usr/bin/python
|
||||
import os
|
||||
import sys
|
||||
import json
|
||||
import subprocess
|
||||
from novaclient.client import Client
|
||||
|
||||
|
||||
def get_data_from_hiera(key):
|
||||
cmd_data = subprocess.Popen("hiera " + key, shell=True,
|
||||
stdout=subprocess.PIPE).stdout.read(). \
|
||||
replace('=>', ':').replace('nil', '"null"')
|
||||
try:
|
||||
data = json.loads(cmd_data)
|
||||
except:
|
||||
data = {key: cmd_data.strip()}
|
||||
return data
|
||||
|
||||
|
||||
def check_availability_zones(nova_client, compute):
|
||||
nova_zones = nova_client.availability_zones.list()
|
||||
nova_aggregates = nova_client.aggregates.list()
|
||||
compute_zone = compute['availability_zone_name']
|
||||
a = next((az for az in nova_zones if az.to_dict()['zoneName'] ==
|
||||
compute_zone), None)
|
||||
b = next((az for az in nova_aggregates
|
||||
if az.to_dict()['availability_zone'] == compute_zone), None)
|
||||
if not (a or b):
|
||||
print "Zone " + compute_zone + " is missing, creating it."
|
||||
nova_client.aggregates.create(compute_zone, compute_zone)
|
||||
else:
|
||||
print "Zone " + compute_zone + " already present."
|
||||
|
||||
|
||||
def check_host_in_zone(nova_client, compute):
|
||||
nova_zones = nova_client.availability_zones.list()
|
||||
nova_aggregates = nova_client.aggregates.list()
|
||||
compute_zone = compute['availability_zone_name']
|
||||
compute_host = compute_zone + "-" + compute['service_name']
|
||||
|
||||
for aggregate in nova_aggregates:
|
||||
if aggregate.to_dict()['name'] == compute_zone:
|
||||
host_aggregate = aggregate
|
||||
|
||||
c = next((az for az in nova_zones if compute_host in
|
||||
az.to_dict()['hosts'] and az.to_dict()['zoneName'] ==
|
||||
compute_zone), None)
|
||||
if c is None:
|
||||
print "Compute service " + compute['service_name'] + " not in " + \
|
||||
compute_zone + " zone. " + "Adding."
|
||||
nova_client.aggregates.add_host(host_aggregate, compute_host)
|
||||
else:
|
||||
print "Compute service " + compute['service_name'] + " already in " + \
|
||||
compute_zone + " zone."
|
||||
|
||||
use_vcenter = get_data_from_hiera('use_vcenter')
|
||||
if use_vcenter is not True:
|
||||
sys.exit(0)
|
||||
|
||||
credentials = get_data_from_hiera('access')
|
||||
USERNAME = credentials['user']
|
||||
PASSWORD = credentials['password']
|
||||
PROJECT_ID = credentials['tenant']
|
||||
VERSION = 2
|
||||
IP = get_data_from_hiera('management_vip')['management_vip']
|
||||
AUTH_URL = "http://" + IP + ":5000/v2.0/"
|
||||
|
||||
nova = Client(VERSION, USERNAME, PASSWORD, PROJECT_ID, AUTH_URL)
|
||||
vcenter_settings = get_data_from_hiera('vcenter')
|
||||
|
||||
for compute in vcenter_settings['computes']:
|
||||
print "---Start of Compute service " + compute['service_name'] + \
|
||||
" zone creation.---"
|
||||
check_availability_zones(nova, compute)
|
||||
check_host_in_zone(nova, compute)
|
||||
print "----End of Compute service " + compute['service_name'] + "----\n"
|
Loading…
Reference in New Issue
Block a user