7e4aca45fa
When podman dropped the journald log-driver we rushed to move to the supported k8s-file driver. This had the side effect of us losing the stdout logs of the HA containers. In fact previously we were easily able to troubleshoot haproxy startup failures just by looking in the journal. These days instead if haproxy fails to start we have no traces whatsoever in the logs, because when a container fails it gets stopped by pacemaker (and consequently removed) and no logs on the system are available any longer. Tested as follows: 1) Redeploy a previously deployed overcloud that did not have the patch and observe that we now log the startup of HA bundles in /var/log/containers/stdouts/*bundle.log [root@controller-0 stdouts]# ls -l *bundle.log |grep -v -e init -e restart -rw-------. 1 root root 16032 Apr 14 14:13 openstack-cinder-volume.log -rw-------. 1 root root 19515 Apr 14 14:00 haproxy-bundle.log -rw-------. 1 root root 10509 Apr 14 14:03 ovn-dbs-bundle.log -rw-------. 1 root root 6451 Apr 14 14:00 redis-bundle.log 2) Deploy a composable HA overcloud from scratch with the patch above and observe that we obtain the stdout on disk. Note that most HA containers log to their usual on-host files just fine, we are mainly missing haproxy logs and/or the kolla startup only of the HA containers. Closes-Bug: #1872734 NB: Cherry-picks had some context change in manifests/profile/pacemaker/cinder/volume_bundle.pp manifests/profile/pacemaker/rabbitmq_bundle.pp manifests/profile/pacemaker/manila/share_bundle.pp Change-Id: I4270b398366e90206adffe32f812632b50df615b (cherry picked from commit 06c4aa7446073022b86c1f034a0c5406f2675ddb)
125 lines
4.5 KiB
Ruby
125 lines
4.5 KiB
Ruby
#
|
|
# Copyright (C) 2018 Red Hat, 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.
|
|
#
|
|
|
|
require 'spec_helper'
|
|
|
|
describe 'tripleo::profile::pacemaker::cinder::backup_bundle' do
|
|
shared_examples_for 'tripleo::profile::pacemaker::cinder::backup_bundle' do
|
|
before :each do
|
|
facts.merge!({ :step => params[:step] })
|
|
end
|
|
|
|
context 'with step less than 2' do
|
|
let(:params) { { :step => 1 } }
|
|
|
|
it 'should do nothing' do
|
|
is_expected.to contain_class('tripleo::profile::base::cinder::backup')
|
|
end
|
|
end
|
|
|
|
context 'with step 2 on bootstrap node' do
|
|
let(:params) { {
|
|
:step => 2,
|
|
} }
|
|
|
|
it 'should create pacemaker properties' do
|
|
is_expected.to contain_pacemaker__property('cinder-backup-role-node.example.com')
|
|
is_expected.to_not contain_pacemaker__property('cinder-backup-role-c-bak-2')
|
|
end
|
|
end
|
|
|
|
context 'with step 2 not on bootstrap node' do
|
|
let(:params) { {
|
|
:step => 2,
|
|
:bootstrap_node => 'other.example.com',
|
|
} }
|
|
|
|
it 'should not create pacemaker properties' do
|
|
is_expected.to_not contain_pacemaker__property('cinder-backup-role-node.example.com')
|
|
is_expected.to_not contain_pacemaker__property('cinder-backup-role-c-bak-2')
|
|
end
|
|
end
|
|
|
|
context 'with step 5' do
|
|
let(:params) { {
|
|
:step => 5,
|
|
:cinder_backup_docker_image => 'c-bak-docker-image',
|
|
:log_driver => 'journald',
|
|
} }
|
|
|
|
context 'with default inputs' do
|
|
it 'should create default cinder-backup resource bundle' do
|
|
is_expected.to contain_pacemaker__resource__bundle('openstack-cinder-backup').with(
|
|
:image => 'c-bak-docker-image',
|
|
:options => '--ipc=host --privileged=true --user=root --log-driver=journald -e KOLLA_CONFIG_STRATEGY=COPY_ALWAYS',
|
|
)
|
|
# The default list of storage_maps is rather long, and this
|
|
# just does a spot-check of a few key entries. The point is
|
|
# to verify the default list is used when the docker_volumes
|
|
# input parameter isn't specified.
|
|
storage_maps = catalogue.resource(
|
|
'Pacemaker::Resource::Bundle', 'openstack-cinder-backup').send(:parameters)[:storage_maps]
|
|
expect(storage_maps).to include('cinder-backup-cfg-files', 'cinder-backup-cfg-data')
|
|
end
|
|
end
|
|
|
|
context 'with docker volumes and environment inputs' do
|
|
before :each do
|
|
params.merge!({
|
|
:docker_volumes => ['/src/1:/tgt/1', '/src/2:/tgt/2:ro', '/src/3:/tgt/3:ro,z'],
|
|
:docker_environment => ['RIGHT=LEFT', 'UP=DOWN'],
|
|
:log_driver => 'k8s-file',
|
|
:log_file => '/var/log/containers/stdouts/cinder_backup.log'
|
|
})
|
|
end
|
|
it 'should create custom cinder-backup resource bundle' do
|
|
is_expected.to contain_pacemaker__resource__bundle('openstack-cinder-backup').with(
|
|
:image => 'c-bak-docker-image',
|
|
:options => '--ipc=host --privileged=true --user=root --log-driver=k8s-file --log-opt path=/var/log/containers/stdouts/cinder_backup.log -e RIGHT=LEFT -e UP=DOWN',
|
|
:storage_maps => {
|
|
'cinder-backup-src-1' => {
|
|
'source-dir' => '/src/1',
|
|
'target-dir' => '/tgt/1',
|
|
'options' => 'rw',
|
|
},
|
|
'cinder-backup-src-2' => {
|
|
'source-dir' => '/src/2',
|
|
'target-dir' => '/tgt/2',
|
|
'options' => 'ro',
|
|
},
|
|
'cinder-backup-src-3' => {
|
|
'source-dir' => '/src/3',
|
|
'target-dir' => '/tgt/3',
|
|
'options' => 'ro,z',
|
|
},
|
|
},
|
|
)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
on_supported_os.each do |os, facts|
|
|
context "on #{os}" do
|
|
let(:facts) do
|
|
facts.merge({ :hostname => 'node.example.com' })
|
|
end
|
|
|
|
it_behaves_like 'tripleo::profile::pacemaker::cinder::backup_bundle'
|
|
end
|
|
end
|
|
end
|