828ad07854
pretty_inspect output makes it easier to read logs. Closes-Bug: #1352854 Implements blueprint: astute-pretty-logging Change-Id: Ibd931d1f31c0ef6a5747d081ac2bf0d2596ae8b2
78 lines
2.8 KiB
Ruby
78 lines
2.8 KiB
Ruby
# Copyright 2013 Mirantis, Inc.
|
|
#
|
|
# 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.
|
|
|
|
module Astute
|
|
class PrePatching < PreNodeAction
|
|
|
|
def process(deployment_info, context)
|
|
return unless deployment_info.first['openstack_version_prev']
|
|
|
|
# We should stop services with SIGTERM or even SIGKILL.
|
|
# StopOSTServices do this and should be run before.
|
|
|
|
remove_cmd = getremovepackage_cmd(deployment_info)
|
|
|
|
nodes = deployment_info.map { |n| n['uid'] }
|
|
|
|
Astute.logger.info "Starting removal of error-prone packages"
|
|
Astute.logger.info "Executing command #{remove_cmd}"
|
|
Astute.logger.info "On nodes\n#{nodes.pretty_inspect}"
|
|
|
|
response = run_shell_command(context, nodes, remove_cmd, 600)
|
|
|
|
if response[:data][:exit_code] != 0
|
|
Astute.logger.error "#{context.task_id}: Fail to remove packages, "\
|
|
"check the debugging output for details"
|
|
end
|
|
|
|
Astute.logger.info "#{context.task_id}: Finished pre-patching hook"
|
|
end #process
|
|
|
|
def getremovepackage_cmd(deployment_info)
|
|
os = deployment_info.first['cobbler']['profile']
|
|
case os
|
|
when /centos/i then "yum -y remove #{centos_packages}"
|
|
when /ubuntu/i then "aptitude -y remove #{ubuntu_packages}"
|
|
else
|
|
raise DeploymentEngineError, "Unknown system #{os}"
|
|
end
|
|
end
|
|
|
|
def centos_packages
|
|
packages = <<-Packages
|
|
python-oslo-messaging python-oslo-config openstack-heat-common
|
|
python-nova python-routes python-routes1.12 python-neutron
|
|
python-django-horizon murano-api sahara sahara-dashboard
|
|
python-ceilometer openstack-swift openstack-utils
|
|
python-glance python-glanceclient python-cinder
|
|
python-sqlalchemy python-testtools
|
|
Packages
|
|
packages.tr!("\n"," ")
|
|
end
|
|
|
|
def ubuntu_packages
|
|
packages = <<-Packages
|
|
python-oslo.messaging python-oslo.config python-heat python-nova
|
|
python-routes python-routes1.13 python-neutron python-django-horizon
|
|
murano-common murano-api sahara sahara-dashboard python-ceilometer
|
|
python-swift python-cinder python-keystoneclient python-neutronclient
|
|
python-novaclient python-swiftclient python-troveclient
|
|
python-sqlalchemy python-testtools
|
|
Packages
|
|
packages.tr!("\n"," ")
|
|
end
|
|
|
|
end #class
|
|
end
|