From 9a21f56f8a0f4e57ecfe03ed3ecde3ddac58be28 Mon Sep 17 00:00:00 2001 From: Remi Bergsma Date: Sat, 7 May 2016 18:56:58 +0200 Subject: [PATCH] Speedup vm start by making vm_passwd saving much faster - do not keep passwords in databag (/etc/cloudstack/vmpasswd.json) - process only the password we get in (vm_password.json) from mgt server - lookup the correct passwd server instead of adding passwd to all of them Example: - 4 tiers and 199 VMs running - Start vm 200 would cause new passwd from vm_password.json (1) to be merged with /etc/cloudstack/vmpasswd.json (199) - A curl command was exected foreach password (200) foreach tier (4) resulting in 800 calls - In fact, since passwds are never cleaned it could very well be even more as the ip address was the key in the json file so until the ip address was reused the original password would remain and be sent to passwd server every time another vm starts. - This took ~40 seconds Now we just figure out the right tier and only process the new password resulting in a single curl call. - takes 0,03 seconds! --- .../config/opt/cloud/bin/cs/CsVmPassword.py | 45 +++++++++++++++++++ .../debian/config/opt/cloud/bin/cs_vmp.py | 27 ----------- 2 files changed, 45 insertions(+), 27 deletions(-) create mode 100644 systemvm/patches/debian/config/opt/cloud/bin/cs/CsVmPassword.py delete mode 100755 systemvm/patches/debian/config/opt/cloud/bin/cs_vmp.py diff --git a/systemvm/patches/debian/config/opt/cloud/bin/cs/CsVmPassword.py b/systemvm/patches/debian/config/opt/cloud/bin/cs/CsVmPassword.py new file mode 100644 index 00000000000..279d21d3298 --- /dev/null +++ b/systemvm/patches/debian/config/opt/cloud/bin/cs/CsVmPassword.py @@ -0,0 +1,45 @@ +#!/usr/bin/python +# -- coding: utf-8 -- + +import CsHelper +from CsProcess import CsProcess +from netaddr import IPNetwork, IPAddress +import logging + + +class CsPassword: + + TOKEN_FILE="/tmp/passwdsrvrtoken" + + def __init__(self, dbag): + self.dbag = dbag + self.process() + + def process(self): + self.__update(self.dbag['ip_address'], self.dbag['password']) + + def __update(self, vm_ip, password): + token = "" + try: + tokenFile = open(self.TOKEN_FILE) + token = tokenFile.read() + except IOError: + logging.debug("File %s does not exist" % self.TOKEN_FILE) + + logging.debug("Got VM '%s' and password '%s'" % (vm_ip, password)) + get_cidrs_cmd = "ip addr show | grep inet | grep -v secondary | awk '{print $2}'" + cidrs = CsHelper.execute(get_cidrs_cmd) + logging.debug("Found these CIDRs: %s" % cidrs) + for cidr in cidrs: + logging.debug("Processing CIDR '%s'" % cidr) + if IPAddress(vm_ip) in IPNetwork(cidr): + ip = cidr.split('/')[0] + logging.debug("Cidr %s matches vm ip address %s so adding passwd to passwd server at %s" % (cidr, vm_ip, ip)) + proc = CsProcess(['/opt/cloud/bin/passwd_server_ip.py', ip]) + if proc.find(): + update_command = 'curl --header "DomU_Request: save_password" "http://{SERVER_IP}:8080/" -F "ip={VM_IP}" -F "password={PASSWORD}" ' \ + '-F "token={TOKEN}" --interface 127.0.0.1 >/dev/null 2>/dev/null &'.format(SERVER_IP=ip, VM_IP=vm_ip, PASSWORD=password, TOKEN=token) + result = CsHelper.execute(update_command) + logging.debug("Update password server result ==> %s" % result) + else: + logging.debug("Update password server skipped because we didn't find a passwd server process for %s (makes sense on backup routers)" % ip) diff --git a/systemvm/patches/debian/config/opt/cloud/bin/cs_vmp.py b/systemvm/patches/debian/config/opt/cloud/bin/cs_vmp.py deleted file mode 100755 index 3a8e06ed719..00000000000 --- a/systemvm/patches/debian/config/opt/cloud/bin/cs_vmp.py +++ /dev/null @@ -1,27 +0,0 @@ -# Licensed to the Apache Software Foundation (ASF) under one -# or more contributor license agreements. See the NOTICE file -# distributed with this work for additional information -# regarding copyright ownership. The ASF licenses this file -# to you 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. - -from pprint import pprint -from netaddr import * - - -def merge(dbag, data): - """ - Track vm passwords - """ - dbag[data['ip_address']] = data['password'] - return dbag