Reconfigure keystone service
Partially-implements: bp kolla-reconfig Change-Id: Ied293e59bf4531e88a0e5e5bf9a5f5f495d2a0e7
This commit is contained in:
parent
287e4faf99
commit
72ac7a5541
39
ansible/roles/keystone/tasks/do_reconfigure.yml
Normal file
39
ansible/roles/keystone/tasks/do_reconfigure.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
---
|
||||||
|
- include: config.yml
|
||||||
|
|
||||||
|
- name: Check the configs
|
||||||
|
command: docker exec keystone /usr/local/bin/kolla_set_configs --check
|
||||||
|
changed_when: false
|
||||||
|
failed_when: false
|
||||||
|
register: check_result
|
||||||
|
|
||||||
|
# NOTE(jeffrey4l): when config_strategy == 'COPY_ALWAYS'
|
||||||
|
# and container env['KOLLA_CONFIG_STRATEGY'] == 'COPY_ONCE',
|
||||||
|
# just remove the container and start again
|
||||||
|
- name: Container config strategy
|
||||||
|
command: docker exec keystone printenv KOLLA_CONFIG_STRATEGY
|
||||||
|
changed_when: false
|
||||||
|
failed_when: false
|
||||||
|
register: container_config_strategy
|
||||||
|
|
||||||
|
- name: Remove the keystone container
|
||||||
|
kolla_docker:
|
||||||
|
name: "keystone"
|
||||||
|
action: "remove_container"
|
||||||
|
when:
|
||||||
|
- config_strategy == "COPY_ONCE" or container_config_strategy.stdout == 'COPY_ONCE'
|
||||||
|
- check_result.rc == 1
|
||||||
|
|
||||||
|
- include: start.yml
|
||||||
|
when:
|
||||||
|
- config_strategy == "COPY_ONCE" or container_config_strategy.stdout == 'COPY_ONCE'
|
||||||
|
- check_result.rc == 1
|
||||||
|
|
||||||
|
- name: Restart keystone service
|
||||||
|
# TODO(jeffrey4l): move to the kolla_docker module when
|
||||||
|
# it has restart_container action
|
||||||
|
command: docker restart keystone
|
||||||
|
when:
|
||||||
|
- config_strategy == 'COPY_ALWAYS'
|
||||||
|
- container_config_strategy.stdout != 'COPY_ONCE'
|
||||||
|
- check_result.rc == 1
|
@ -1 +1,3 @@
|
|||||||
---
|
---
|
||||||
|
- include: do_reconfigure.yml
|
||||||
|
serial: "30%"
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
|
import argparse
|
||||||
import contextlib
|
import contextlib
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
@ -235,7 +236,10 @@ def load_config():
|
|||||||
|
|
||||||
LOG.info('Validating config file')
|
LOG.info('Validating config file')
|
||||||
validate_config(config)
|
validate_config(config)
|
||||||
|
return config
|
||||||
|
|
||||||
|
|
||||||
|
def copy_config(config):
|
||||||
if 'config_files' in config:
|
if 'config_files' in config:
|
||||||
LOG.info('Copying service configuration files')
|
LOG.info('Copying service configuration files')
|
||||||
for data in config['config_files']:
|
for data in config['config_files']:
|
||||||
@ -255,23 +259,66 @@ def load_config():
|
|||||||
def execute_config_strategy():
|
def execute_config_strategy():
|
||||||
config_strategy = os.environ.get("KOLLA_CONFIG_STRATEGY")
|
config_strategy = os.environ.get("KOLLA_CONFIG_STRATEGY")
|
||||||
LOG.info("Kolla config strategy set to: %s", config_strategy)
|
LOG.info("Kolla config strategy set to: %s", config_strategy)
|
||||||
|
config = load_config()
|
||||||
|
|
||||||
if config_strategy == "COPY_ALWAYS":
|
if config_strategy == "COPY_ALWAYS":
|
||||||
load_config()
|
copy_config(config)
|
||||||
elif config_strategy == "COPY_ONCE":
|
elif config_strategy == "COPY_ONCE":
|
||||||
if os.path.exists('/configured'):
|
if os.path.exists('/configured'):
|
||||||
LOG.info("The config strategy prevents copying new configs")
|
LOG.info("The config strategy prevents copying new configs")
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
else:
|
else:
|
||||||
load_config()
|
copy_config(config)
|
||||||
os.mknod('/configured')
|
os.mknod('/configured')
|
||||||
else:
|
else:
|
||||||
LOG.error('KOLLA_CONFIG_STRATEGY is not set properly')
|
LOG.error('KOLLA_CONFIG_STRATEGY is not set properly')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
|
def execute_config_check():
|
||||||
|
config = load_config()
|
||||||
|
for config_file in config.get('config_files', {}):
|
||||||
|
source = config_file.get('source')
|
||||||
|
dest = config_file.get('dest')
|
||||||
|
perm = config_file.get('perm')
|
||||||
|
owner = config_file.get('owner')
|
||||||
|
if not os.path.exists(dest):
|
||||||
|
LOG.error('Dest file not exist: %s', dest)
|
||||||
|
sys.exit(1)
|
||||||
|
# check content
|
||||||
|
with open(source) as fp1, open(dest) as fp2:
|
||||||
|
if fp1.read() != fp2.read():
|
||||||
|
LOG.error('The content of source file(%s) and'
|
||||||
|
' dest file(%s) are not equal.', source, dest)
|
||||||
|
sys.exit(1)
|
||||||
|
# check perm
|
||||||
|
file_stat = os.stat(dest)
|
||||||
|
actual_perm = oct(file_stat.st_mode)[-4:]
|
||||||
|
if perm != actual_perm:
|
||||||
|
LOG.error('Dest file does not have expected perm: %s, actual: %s',
|
||||||
|
perm, actual_perm)
|
||||||
|
sys.exit(1)
|
||||||
|
# check owner
|
||||||
|
actual_user = pwd.getpwuid(file_stat.st_uid)
|
||||||
|
if actual_user.pw_name != owner:
|
||||||
|
LOG.error('Dest file does not have expected user: %s, actual: %s ',
|
||||||
|
owner, actual_user.pw_name)
|
||||||
|
sys.exit(1)
|
||||||
|
LOG.info('The config files are in the expected state')
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
execute_config_strategy()
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument('--check',
|
||||||
|
action='store_true',
|
||||||
|
required=False,
|
||||||
|
help='Check whether the configs changed')
|
||||||
|
conf = parser.parse_args()
|
||||||
|
|
||||||
|
if conf.check:
|
||||||
|
execute_config_check()
|
||||||
|
else:
|
||||||
|
execute_config_strategy()
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,8 @@ class LoadFromFile(base.BaseTestCase):
|
|||||||
|
|
||||||
mo = mock.mock_open(read_data=in_config)
|
mo = mock.mock_open(read_data=in_config)
|
||||||
with mock.patch.object(set_configs, 'open', mo):
|
with mock.patch.object(set_configs, 'open', mo):
|
||||||
set_configs.load_config()
|
config = set_configs.load_config()
|
||||||
|
set_configs.copy_config(config)
|
||||||
self.assertEqual([
|
self.assertEqual([
|
||||||
mock.call('/var/lib/kolla/config_files/config.json'),
|
mock.call('/var/lib/kolla/config_files/config.json'),
|
||||||
mock.call().__enter__(),
|
mock.call().__enter__(),
|
||||||
@ -59,7 +60,8 @@ class LoadFromEnv(base.BaseTestCase):
|
|||||||
mo = mock.mock_open()
|
mo = mock.mock_open()
|
||||||
with mock.patch.object(set_configs, 'open', mo):
|
with mock.patch.object(set_configs, 'open', mo):
|
||||||
with mock.patch.dict('os.environ', {'KOLLA_CONFIG': in_config}):
|
with mock.patch.dict('os.environ', {'KOLLA_CONFIG': in_config}):
|
||||||
set_configs.load_config()
|
config = set_configs.load_config()
|
||||||
|
set_configs.copy_config(config)
|
||||||
self.assertEqual([mock.call('/run_command', 'w+'),
|
self.assertEqual([mock.call('/run_command', 'w+'),
|
||||||
mock.call().__enter__(),
|
mock.call().__enter__(),
|
||||||
mock.call().write(u'/bin/true'),
|
mock.call().write(u'/bin/true'),
|
||||||
|
Loading…
Reference in New Issue
Block a user