2014-03-04 02:08:51 +08:00
|
|
|
---
|
|
|
|
# Variables here are applicable to all host groups NOT roles
|
|
|
|
|
2016-02-29 23:35:07 +08:00
|
|
|
# This sample file generated by generate_group_vars_sample.sh
|
|
|
|
|
|
|
|
# Dummy variable to avoid error because ansible does not recognize the
|
|
|
|
# file as a good configuration file when no variable in it.
|
2014-06-25 23:03:29 +08:00
|
|
|
dummy:
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
# Variables here are applicable to all host groups NOT roles
|
|
|
|
|
|
|
|
# This sample file generated by generate_group_vars_sample.sh
|
|
|
|
|
|
|
|
# Dummy variable to avoid error because ansible does not recognize the
|
|
|
|
# file as a good configuration file when no variable in it.
|
|
|
|
#dummy:
|
|
|
|
|
2016-02-29 23:35:07 +08:00
|
|
|
# You can override default vars defined in defaults/main.yml here,
|
|
|
|
# but I would advice to use host or group vars instead
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
|
2015-08-27 18:42:01 +08:00
|
|
|
###########
|
|
|
|
# GENERAL #
|
|
|
|
###########
|
|
|
|
|
|
|
|
#fetch_directory: fetch/
|
|
|
|
|
2016-02-25 19:10:45 +08:00
|
|
|
# Even though OSD nodes should not have the admin key
|
|
|
|
# at their disposal, some people might want to have it
|
|
|
|
# distributed on OSD nodes. Setting 'copy_admin_key' to 'true'
|
|
|
|
# will copy the admin key to the /etc/ceph/ directory
|
|
|
|
#copy_admin_key: false
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
|
2015-01-09 01:27:43 +08:00
|
|
|
####################
|
|
|
|
# OSD CRUSH LOCATION
|
|
|
|
####################
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
# /!\
|
|
|
|
#
|
|
|
|
# BE EXTREMELY CAREFUL WITH THIS OPTION
|
|
|
|
# DO NOT USE IT UNLESS YOU KNOW WHAT YOU ARE DOING
|
|
|
|
#
|
|
|
|
# /!\
|
|
|
|
#
|
|
|
|
# It is probably best to keep this option to 'false' as the default
|
|
|
|
# suggests it. This option should only be used while doing some complex
|
|
|
|
# CRUSH map. It allows you to force a specific location for a set of OSDs.
|
|
|
|
#
|
2015-01-09 01:27:43 +08:00
|
|
|
# The following options will build a ceph.conf with OSD sections
|
|
|
|
# Example:
|
|
|
|
# [osd.X]
|
|
|
|
# osd crush location = "root=location"
|
|
|
|
#
|
|
|
|
# This works with your inventory file
|
|
|
|
# To match the following 'osd_crush_location' option the inventory must look like:
|
2015-01-07 05:47:49 +08:00
|
|
|
#
|
2015-01-09 01:27:43 +08:00
|
|
|
# [osds]
|
|
|
|
# osd0 ceph_crush_root=foo ceph_crush_rack=bar
|
|
|
|
|
2016-02-29 23:35:07 +08:00
|
|
|
#crush_location: false
|
2017-03-16 21:25:15 +08:00
|
|
|
#osd_crush_location: "\"root={{ ceph_crush_root }} rack={{ ceph_crush_rack }} host={{ ansible_hostname }}\""
|
2015-01-09 01:27:43 +08:00
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
|
2015-01-09 01:27:43 +08:00
|
|
|
##############
|
|
|
|
# CEPH OPTIONS
|
|
|
|
##############
|
2015-01-07 05:47:49 +08:00
|
|
|
|
2016-02-29 23:35:07 +08:00
|
|
|
# ACTIVATE THE FSID VARIABLE FOR NON-VAGRANT DEPLOYMENT
|
|
|
|
#fsid: "{{ cluster_uuid.stdout }}"
|
2015-01-07 05:47:49 +08:00
|
|
|
#cephx: true
|
|
|
|
|
2014-03-04 02:08:51 +08:00
|
|
|
# Devices to be used as OSDs
|
2014-03-06 18:12:25 +08:00
|
|
|
# You can pre-provision disks that are not present yet.
|
|
|
|
# Ansible will just skip them. Newly added disk will be
|
|
|
|
# automatically configured during the next run.
|
|
|
|
#
|
2014-03-04 02:08:51 +08:00
|
|
|
|
2014-03-07 21:04:25 +08:00
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
# Declare devices to be used as OSDs
|
|
|
|
# All scenario(except 3rd) inherit from the following device declaration
|
2014-03-07 21:04:25 +08:00
|
|
|
|
2015-01-07 05:47:49 +08:00
|
|
|
#devices:
|
|
|
|
# - /dev/sdb
|
|
|
|
# - /dev/sdc
|
2016-10-06 17:54:58 +08:00
|
|
|
# - /dev/sdd
|
|
|
|
# - /dev/sde
|
2015-01-07 05:47:49 +08:00
|
|
|
|
2016-10-10 21:16:03 +08:00
|
|
|
#devices: []
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
|
|
|
|
#'osd_auto_discovery' mode prevents you from filling out the 'devices' variable above.
|
|
|
|
# You can use this option with First and Forth and Fifth OSDS scenario.
|
2015-01-07 05:47:49 +08:00
|
|
|
# Device discovery is based on the Ansible fact 'ansible_devices'
|
|
|
|
# which reports all the devices on a system. If chosen all the disks
|
|
|
|
# found will be passed to ceph-disk. You should not be worried on using
|
|
|
|
# this option since ceph-disk has a built-in check which looks for empty devices.
|
|
|
|
# Thus devices with existing partition tables will not be used.
|
|
|
|
#
|
|
|
|
#osd_auto_discovery: false
|
2014-03-07 21:04:25 +08:00
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
|
|
|
|
# !! WARNING !!
|
|
|
|
# #
|
|
|
|
# # /!\ ENABLE ONLY ONE SCENARIO AT A TIME /!\
|
|
|
|
# #
|
|
|
|
# # !! WARNING !!
|
|
|
|
#
|
|
|
|
|
2014-03-07 21:04:25 +08:00
|
|
|
# I. First scenario: journal and osd_data on the same device
|
|
|
|
# Use 'true' to enable this scenario
|
|
|
|
# This will collocate both journal and data on the same disk
|
2014-03-04 02:08:51 +08:00
|
|
|
# creating a partition at the beginning of the device
|
2016-10-06 17:54:58 +08:00
|
|
|
# List devices under 'devices' variable above or choose 'osd_auto_discovery'
|
|
|
|
|
2015-01-07 05:47:49 +08:00
|
|
|
|
2015-07-04 00:38:30 +08:00
|
|
|
#journal_collocation: false
|
2014-03-07 21:04:25 +08:00
|
|
|
|
|
|
|
|
2016-10-06 17:54:58 +08:00
|
|
|
# II. Second scenario: N journal devices for N OSDs
|
|
|
|
# Use 'true' for 'raw_multi_journal' to enable this scenario
|
2017-03-16 21:25:15 +08:00
|
|
|
# List devices under 'devices' variable above and
|
2016-10-06 17:54:58 +08:00
|
|
|
# write journal devices for those under 'raw_journal_devices'
|
2014-03-07 21:04:25 +08:00
|
|
|
# In the following example:
|
2016-10-06 17:54:58 +08:00
|
|
|
# * sdb and sdc will get sdf as a journal
|
|
|
|
# * sdd and sde will get sdg as a journal
|
|
|
|
|
2014-03-07 21:04:25 +08:00
|
|
|
# While starting you have 2 options:
|
|
|
|
# 1. Pre-allocate all the devices
|
|
|
|
# 2. Progressively add new devices
|
2014-06-25 22:51:28 +08:00
|
|
|
#raw_multi_journal: false
|
2015-01-07 05:47:49 +08:00
|
|
|
#raw_journal_devices:
|
2016-10-06 17:54:58 +08:00
|
|
|
# - /dev/sdf
|
|
|
|
# - /dev/sdf
|
|
|
|
# - /dev/sdg
|
|
|
|
# - /dev/sdg
|
2017-02-08 05:00:53 +08:00
|
|
|
#
|
|
|
|
# NOTE(leseb):
|
|
|
|
# On a containerized scenario we only support A SINGLE journal
|
|
|
|
# for all the OSDs on a given machine. If you don't, bad things will happen
|
|
|
|
# This is a limitation we plan to fix at some point.
|
2016-10-25 02:37:28 +08:00
|
|
|
#raw_journal_devices: []
|
2016-02-29 23:35:07 +08:00
|
|
|
|
2014-07-03 21:30:49 +08:00
|
|
|
|
2016-07-19 23:55:57 +08:00
|
|
|
# IV. This will partition disks for BlueStore
|
2016-03-25 21:15:29 +08:00
|
|
|
# Use 'true' to enable this scenario
|
|
|
|
#bluestore: false
|
|
|
|
|
|
|
|
|
2016-07-19 23:55:57 +08:00
|
|
|
# V. Encrypt osd data and/or journal devices with dm-crypt.
|
|
|
|
# Keys are stored into the monitors k/v store
|
|
|
|
# Use 'true' to enable this scenario
|
|
|
|
# Both journal and data are stored on the same dm-crypt encrypted device
|
2016-08-10 16:34:23 +08:00
|
|
|
#dmcrypt_journal_collocation: false
|
2016-07-19 23:55:57 +08:00
|
|
|
|
|
|
|
|
|
|
|
# VI. Encrypt osd data and/or journal devices with dm-crypt.
|
2016-07-19 23:53:21 +08:00
|
|
|
# Keys are stored into the monitors k/v store
|
|
|
|
# Use 'true' to enable this scenario
|
2016-07-19 23:55:57 +08:00
|
|
|
# Journal and osd data are separated, each with their own dm-crypt device
|
|
|
|
# You must use raw_journal_devices and set your journal devices
|
|
|
|
#dmcrypt_dedicated_journal: false
|
2016-07-19 23:53:21 +08:00
|
|
|
|
|
|
|
|
2015-06-24 21:51:54 +08:00
|
|
|
##########
|
|
|
|
# DOCKER #
|
|
|
|
##########
|
|
|
|
|
2015-10-22 05:18:22 +08:00
|
|
|
#osd_containerized_deployment: false
|
2016-03-29 18:47:46 +08:00
|
|
|
#osd_containerized_deployment_with_kv: false
|
|
|
|
#kv_type: etcd
|
|
|
|
#kv_endpoint: 127.0.0.1
|
2016-07-12 18:15:22 +08:00
|
|
|
#kv_port: 4001
|
2017-02-18 21:48:18 +08:00
|
|
|
#ceph_docker_image: "ceph/daemon"
|
|
|
|
#ceph_docker_image_tag: latest
|
|
|
|
#ceph_config_keys: [] # DON'T TOUCH ME
|
|
|
|
#ceph_docker_on_openstack: false
|
2017-02-08 05:00:53 +08:00
|
|
|
|
2017-02-18 21:48:18 +08:00
|
|
|
# PREPARE DEVICE
|
|
|
|
# Make sure you only pass a single device to raw_journal_devices, otherwise this will fail horribly.
|
|
|
|
# This is why we use [0] in the example.
|
2017-02-08 05:00:53 +08:00
|
|
|
#
|
2017-02-18 21:48:18 +08:00
|
|
|
# WARNING /!\ DMCRYPT scenario ONLY works with Docker version 1.12.5 and above
|
|
|
|
#
|
|
|
|
# Examples:
|
|
|
|
# Journal collocated: ceph_osd_docker_prepare_env: -e CLUSTER={{ cluster }} -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_FORCE_ZAP=1
|
|
|
|
# Dedicated journal: ceph_osd_docker_prepare_env: -e CLUSTER={{ cluster }} -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_FORCE_ZAP=1 -e OSD_JOURNAL={{ raw_journal_devices[0] }}
|
|
|
|
# Encrypted OSD: ceph_osd_docker_prepare_env: -e CLUSTER={{ cluster }} -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_FORCE_ZAP=1 -e OSD_DMCRYPT=1
|
|
|
|
# Encrypted OSD with dedicated journal: ceph_osd_docker_prepare_env: -e CLUSTER={{ cluster }} -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_FORCE_ZAP=1 -e OSD_DMCRYPT=1 -e OSD_JOURNAL={{ raw_journal_devices[0] }}
|
|
|
|
#
|
|
|
|
#ceph_osd_docker_devices: "{{ devices }}"
|
2016-12-15 04:22:13 +08:00
|
|
|
#ceph_osd_docker_prepare_env: -e CLUSTER={{ cluster }} -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_FORCE_ZAP=1
|
2017-02-18 21:48:18 +08:00
|
|
|
|
|
|
|
# ACTIVATE DEVICE
|
|
|
|
# Examples:
|
|
|
|
# Journal collocated or Dedicated journal: ceph_osd_docker_extra_env: -e CLUSTER={{ cluster }} -e CEPH_DAEMON=OSD_CEPH_DISK_ACTIVATE -e OSD_JOURNAL_SIZE={{ journal_size }}
|
|
|
|
# Encrypted OSD or Encrypted OSD with dedicated journal: ceph_osd_docker_extra_env: -e CLUSTER={{ cluster }} -e CEPH_DAEMON=OSD_CEPH_DISK_ACTIVATE -e OSD_JOURNAL_SIZE={{ journal_size }} -e OSD_DMCRYPT=1
|
|
|
|
#
|
2016-12-16 21:53:14 +08:00
|
|
|
#ceph_osd_docker_extra_env: -e CLUSTER={{ cluster }} -e CEPH_DAEMON=OSD_CEPH_DISK_ACTIVATE -e OSD_JOURNAL_SIZE={{ journal_size }}
|
2017-02-18 21:48:18 +08:00
|
|
|
#ceph_osd_docker_run_script_path: "/usr/share" # script called by systemd to run the docker command
|
2016-02-29 23:35:07 +08:00
|
|
|
|