2020-10-16 08:42:00 +08:00
|
|
|
# Copyright 2020, 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.
|
|
|
|
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
|
|
|
|
ANSIBLE_METADATA = {
|
|
|
|
'metadata_version': '1.1',
|
|
|
|
'status': ['preview'],
|
|
|
|
'supported_by': 'community'
|
|
|
|
}
|
|
|
|
|
|
|
|
DOCUMENTATION = '''
|
|
|
|
---
|
|
|
|
module: cephadm_bootstrap
|
|
|
|
short_description: Bootstrap a Ceph cluster via cephadm
|
|
|
|
version_added: "2.8"
|
|
|
|
description:
|
|
|
|
- Bootstrap a Ceph cluster via cephadm
|
|
|
|
options:
|
|
|
|
mon_ip:
|
|
|
|
description:
|
|
|
|
- Ceph monitor IP address.
|
|
|
|
required: true
|
|
|
|
image:
|
|
|
|
description:
|
|
|
|
- Ceph container image.
|
|
|
|
required: false
|
|
|
|
docker:
|
|
|
|
description:
|
|
|
|
- Use docker instead of podman.
|
|
|
|
required: false
|
|
|
|
fsid:
|
|
|
|
description:
|
|
|
|
- Ceph FSID.
|
|
|
|
required: false
|
|
|
|
pull:
|
|
|
|
description:
|
|
|
|
- Pull the Ceph container image.
|
|
|
|
required: false
|
|
|
|
default: true
|
|
|
|
dashboard:
|
|
|
|
description:
|
|
|
|
- Deploy the Ceph dashboard.
|
|
|
|
required: false
|
|
|
|
default: true
|
|
|
|
dashboard_user:
|
|
|
|
description:
|
|
|
|
- Ceph dashboard user.
|
|
|
|
required: false
|
|
|
|
dashboard_password:
|
|
|
|
description:
|
|
|
|
- Ceph dashboard password.
|
|
|
|
required: false
|
|
|
|
monitoring:
|
|
|
|
description:
|
|
|
|
- Deploy the monitoring stack.
|
|
|
|
required: false
|
|
|
|
default: true
|
|
|
|
firewalld:
|
|
|
|
description:
|
|
|
|
- Manage firewall rules with firewalld.
|
|
|
|
required: false
|
|
|
|
default: true
|
2021-10-10 06:52:08 +08:00
|
|
|
ssh_user:
|
|
|
|
description:
|
|
|
|
- SSH user used for cephadm ssh to the hosts
|
|
|
|
required: false
|
|
|
|
ssh_config:
|
|
|
|
description:
|
|
|
|
- SSH config file path for cephadm ssh client
|
|
|
|
required: false
|
2020-10-16 08:42:00 +08:00
|
|
|
author:
|
|
|
|
- Dimitri Savineau <dsavinea@redhat.com>
|
|
|
|
'''
|
|
|
|
|
|
|
|
EXAMPLES = '''
|
|
|
|
- name: bootstrap a cluster via cephadm (with default values)
|
|
|
|
cephadm_bootstrap:
|
|
|
|
mon_ip: 192.168.42.1
|
|
|
|
|
|
|
|
- name: bootstrap a cluster via cephadm (with custom values)
|
|
|
|
cephadm_bootstrap:
|
|
|
|
mon_ip: 192.168.42.1
|
|
|
|
fsid: 3c9ba63a-c7df-4476-a1e7-317dfc711f82
|
|
|
|
image: quay.ceph.io/ceph/daemon-base:latest-master-devel
|
|
|
|
dashboard: false
|
|
|
|
monitoring: false
|
|
|
|
firewalld: false
|
|
|
|
|
|
|
|
- name: bootstrap a cluster via cephadm with custom image via env var
|
|
|
|
cephadm_bootstrap:
|
|
|
|
mon_ip: 192.168.42.1
|
|
|
|
environment:
|
|
|
|
CEPHADM_IMAGE: quay.ceph.io/ceph/daemon-base:latest-master-devel
|
|
|
|
'''
|
|
|
|
|
|
|
|
RETURN = '''# '''
|
|
|
|
|
|
|
|
|
|
|
|
def exit_module(module, out, rc, cmd, err, startd, changed=False):
|
|
|
|
endd = datetime.datetime.now()
|
|
|
|
delta = endd - startd
|
|
|
|
|
|
|
|
result = dict(
|
|
|
|
cmd=cmd,
|
|
|
|
start=str(startd),
|
|
|
|
end=str(endd),
|
|
|
|
delta=str(delta),
|
|
|
|
rc=rc,
|
|
|
|
stdout=out.rstrip("\r\n"),
|
|
|
|
stderr=err.rstrip("\r\n"),
|
|
|
|
changed=changed,
|
|
|
|
)
|
|
|
|
module.exit_json(**result)
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
module = AnsibleModule(
|
|
|
|
argument_spec=dict(
|
|
|
|
mon_ip=dict(type='str', required=True),
|
|
|
|
image=dict(type='str', required=False),
|
|
|
|
docker=dict(type='bool', required=False, default=False),
|
|
|
|
fsid=dict(type='str', required=False),
|
|
|
|
pull=dict(type='bool', required=False, default=True),
|
|
|
|
dashboard=dict(type='bool', required=False, default=True),
|
|
|
|
dashboard_user=dict(type='str', required=False),
|
|
|
|
dashboard_password=dict(type='str', required=False, no_log=True),
|
|
|
|
monitoring=dict(type='bool', required=False, default=True),
|
|
|
|
firewalld=dict(type='bool', required=False, default=True),
|
2021-10-10 06:52:08 +08:00
|
|
|
ssh_user=dict(type='str', required=False),
|
|
|
|
ssh_config=dict(type='str', required=False),
|
2020-10-16 08:42:00 +08:00
|
|
|
),
|
|
|
|
supports_check_mode=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
mon_ip = module.params.get('mon_ip')
|
|
|
|
docker = module.params.get('docker')
|
|
|
|
image = module.params.get('image')
|
|
|
|
fsid = module.params.get('fsid')
|
|
|
|
pull = module.params.get('pull')
|
|
|
|
dashboard = module.params.get('dashboard')
|
|
|
|
dashboard_user = module.params.get('dashboard_user')
|
|
|
|
dashboard_password = module.params.get('dashboard_password')
|
|
|
|
monitoring = module.params.get('monitoring')
|
|
|
|
firewalld = module.params.get('firewalld')
|
2021-10-10 06:52:08 +08:00
|
|
|
ssh_user = module.params.get('ssh_user')
|
|
|
|
ssh_config = module.params.get('ssh_config')
|
2020-10-16 08:42:00 +08:00
|
|
|
|
|
|
|
startd = datetime.datetime.now()
|
|
|
|
|
|
|
|
cmd = ['cephadm']
|
|
|
|
|
|
|
|
if docker:
|
|
|
|
cmd.append('--docker')
|
|
|
|
|
|
|
|
if image:
|
|
|
|
cmd.extend(['--image', image])
|
|
|
|
|
|
|
|
cmd.extend(['bootstrap', '--mon-ip', mon_ip])
|
|
|
|
|
|
|
|
if fsid:
|
|
|
|
cmd.extend(['--fsid', fsid])
|
|
|
|
|
|
|
|
if not pull:
|
|
|
|
cmd.append('--skip-pull')
|
|
|
|
|
|
|
|
if dashboard:
|
|
|
|
if dashboard_user:
|
|
|
|
cmd.extend(['--initial-dashboard-user', dashboard_user])
|
|
|
|
if dashboard_password:
|
|
|
|
cmd.extend(['--initial-dashboard-password', dashboard_password])
|
|
|
|
else:
|
|
|
|
cmd.append('--skip-dashboard')
|
|
|
|
|
|
|
|
if not monitoring:
|
|
|
|
cmd.append('--skip-monitoring-stack')
|
|
|
|
|
|
|
|
if not firewalld:
|
|
|
|
cmd.append('--skip-firewalld')
|
|
|
|
|
2021-10-10 06:52:08 +08:00
|
|
|
if ssh_user:
|
|
|
|
cmd.extend(['--ssh-user', ssh_user])
|
|
|
|
|
|
|
|
if ssh_config:
|
|
|
|
cmd.extend(['--ssh-config', ssh_config])
|
|
|
|
|
2020-10-16 08:42:00 +08:00
|
|
|
if module.check_mode:
|
|
|
|
exit_module(
|
|
|
|
module=module,
|
|
|
|
out='',
|
|
|
|
rc=0,
|
|
|
|
cmd=cmd,
|
|
|
|
err='',
|
|
|
|
startd=startd,
|
|
|
|
changed=False
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
rc, out, err = module.run_command(cmd)
|
|
|
|
exit_module(
|
|
|
|
module=module,
|
|
|
|
out=out,
|
|
|
|
rc=rc,
|
|
|
|
cmd=cmd,
|
|
|
|
err=err,
|
|
|
|
startd=startd,
|
|
|
|
changed=True
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|