jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 1 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 2 | ============ |
| 3 | Ceph formula |
| 4 | ============ |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 5 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 6 | Ceph provides extraordinary data storage scalability. Thousands of client |
| 7 | hosts or KVMs accessing petabytes to exabytes of data. Each one of your |
| 8 | applications can use the object, block or file system interfaces to the same |
| 9 | RADOS cluster simultaneously, which means your Ceph storage system serves as a |
| 10 | flexible foundation for all of your data storage needs. |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 11 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 12 | Use salt-formula-linux for initial disk partitioning. |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 13 | |
| 14 | |
Tomáš Kukrál | d2b8297 | 2017-08-29 12:45:45 +0200 | [diff] [blame] | 15 | Daemons |
| 16 | -------- |
| 17 | |
| 18 | Ceph uses several daemons to handle data and cluster state. Each daemon type requires different computing capacity and hardware optimization. |
| 19 | |
| 20 | These daemons are currently supported by formula: |
| 21 | |
| 22 | * MON (`ceph.mon`) |
| 23 | * OSD (`ceph.osd`) |
| 24 | * RGW (`ceph.radosgw`) |
| 25 | |
| 26 | |
| 27 | Architecture decisions |
| 28 | ----------------------- |
| 29 | |
| 30 | Please refer to upstream achritecture documents before designing your cluster. Solid understanding of Ceph principles is essential for making architecture decisions described bellow. |
| 31 | http://docs.ceph.com/docs/master/architecture/ |
| 32 | |
| 33 | * Ceph version |
| 34 | |
| 35 | There is 3 or 4 stable releases every year and many of nighty/dev release. You should decide which version will be used since the only stable releases are recommended for production. Some of the releases are marked LTS (Long Term Stable) and these releases receive bugfixed for longer period - usually until next LTS version is released. |
| 36 | |
| 37 | * Number of MON daemons |
| 38 | |
| 39 | Use 1 MON daemon for testing, 3 MONs for smaller production clusters and 5 MONs for very large production cluster. There is no need to have more than 5 MONs in normal environment because there isn't any significant benefit in running more than 5 MONs. Ceph require MONS to form quorum so you need to heve more than 50% of the MONs up and running to have fully operational cluster. Every I/O operation will stop once less than 50% MONs is availabe because they can't form quorum. |
| 40 | |
| 41 | * Number of PGs |
| 42 | |
| 43 | Placement groups are providing mappping between stored data and OSDs. It is necessary to calculate number of PGs because there should be stored decent amount of PGs on each OSD. Please keep in mind *decreasing number of PGs* isn't possible and *increading* can affect cluster performance. |
| 44 | |
| 45 | http://docs.ceph.com/docs/master/rados/operations/placement-groups/ |
| 46 | http://ceph.com/pgcalc/ |
| 47 | |
| 48 | * Daemon colocation |
| 49 | |
| 50 | It is recommended to dedicate nodes for MONs and RWG since colocation can have and influence on cluster operations. Howerver, small clusters can be running MONs on OSD node but it is critical to have enough of resources for MON daemons because they are the most important part of the cluster. |
| 51 | |
| 52 | Installing RGW on node with other daemons isn't recommended because RGW daemon usually require a lot of bandwith and it harm cluster health. |
| 53 | |
Tomáš Kukrál | d2b8297 | 2017-08-29 12:45:45 +0200 | [diff] [blame] | 54 | * Store type (Bluestore/Filestore) |
| 55 | |
| 56 | Recent version of Ceph support Bluestore as storage backend and backend should be used if available. |
| 57 | |
| 58 | http://docs.ceph.com/docs/master/rados/configuration/bluestore-config-ref/ |
| 59 | |
Jiri Broulik | cc0d775 | 2017-11-18 18:58:21 +0100 | [diff] [blame] | 60 | * Block.db location for Bluestore |
| 61 | |
| 62 | There are two ways to setup block.db: |
| 63 | * **Colocated** block.db partition is created on the same disk as partition for the data. This setup is easier for installation and it doesn't require any other disk to be used. However, colocated setup is significantly slower than dedicated) |
| 64 | * **Dedicate** block.db is placed on different disk than data (or into partition). This setup can deliver much higher performance than colocated but it require to have more disks in servers. Block.db drives should be carefully selected because high I/O and durability is required. |
| 65 | |
| 66 | * Block.wal location for Bluestore |
| 67 | |
| 68 | There are two ways to setup block.wal - stores just the internal journal (write-ahead log): |
| 69 | * **Colocated** block.wal uses free space of the block.db device. |
| 70 | * **Dedicate** block.wal is placed on different disk than data (better put into partition as the size can be small) and possibly block.db device. This setup can deliver much higher performance than colocated but it require to have more disks in servers. Block.wal drives should be carefully selected because high I/O and durability is required. |
| 71 | |
| 72 | * Journal location for Filestore |
| 73 | |
| 74 | There are two ways to setup journal: |
| 75 | * **Colocated** journal is created on the same disk as partition for the data. This setup is easier for installation and it doesn't require any other disk to be used. However, colocated setup is significantly slower than dedicated) |
| 76 | * **Dedicate** journal is placed on different disk than data (or into partition). This setup can deliver much higher performance than colocated but it require to have more disks in servers. Journal drives should be carefully selected because high I/O and durability is required. |
| 77 | |
Tomáš Kukrál | d2b8297 | 2017-08-29 12:45:45 +0200 | [diff] [blame] | 78 | * Cluster and public network |
| 79 | |
Mateusz Los | 4dd8c4f | 2017-12-01 09:53:02 +0100 | [diff] [blame] | 80 | Ceph cluster is accessed using network and thus you need to have decend capacity to handle all the client. There are two networks required for cluster: **public** network and cluster network. Public network is used for client connections and MONs and OSDs are listening on this network. Second network ic called **cluster** networks and this network is used for communication between OSDs. |
Tomáš Kukrál | d2b8297 | 2017-08-29 12:45:45 +0200 | [diff] [blame] | 81 | |
| 82 | Both networks should have dedicated interfaces, bonding interfaces and dedicating vlans on bonded interfaces isn't allowed. Good practise is dedicate more throughput for the cluster network because cluster traffic is more important than client traffic. |
| 83 | |
| 84 | * Pool parameters (size, min_size, type) |
| 85 | |
| 86 | You should setup each pool according to it's expected usage, at least `min_size` and `size` and pool type should be considered. |
| 87 | |
| 88 | * Cluster monitoring |
| 89 | |
| 90 | * Hardware |
| 91 | |
| 92 | Please refer to upstream hardware recommendation guide for general information about hardware. |
| 93 | |
| 94 | Ceph servers are required to fulfil special requirements becauce load generated by Ceph can be diametrically opposed to common load. |
| 95 | |
| 96 | http://docs.ceph.com/docs/master/start/hardware-recommendations/ |
| 97 | |
| 98 | |
| 99 | Basic management commands |
| 100 | ------------------------------ |
| 101 | |
| 102 | Cluster |
| 103 | ******** |
| 104 | |
| 105 | - :code:`ceph health` - check if cluster is healthy (:code:`ceph health detail` can provide more information) |
| 106 | |
| 107 | |
| 108 | .. code-block:: bash |
| 109 | |
| 110 | root@c-01:~# ceph health |
| 111 | HEALTH_OK |
| 112 | |
| 113 | - :code:`ceph status` - shows basic information about cluster |
| 114 | |
| 115 | |
| 116 | .. code-block:: bash |
| 117 | |
| 118 | root@c-01:~# ceph status |
| 119 | cluster e2dc51ae-c5e4-48f0-afc1-9e9e97dfd650 |
| 120 | health HEALTH_OK |
| 121 | monmap e1: 3 mons at {1=192.168.31.201:6789/0,2=192.168.31.202:6789/0,3=192.168.31.203:6789/0} |
| 122 | election epoch 38, quorum 0,1,2 1,2,3 |
| 123 | osdmap e226: 6 osds: 6 up, 6 in |
| 124 | pgmap v27916: 400 pgs, 2 pools, 21233 MB data, 5315 objects |
| 125 | 121 GB used, 10924 GB / 11058 GB avail |
| 126 | 400 active+clean |
| 127 | client io 481 kB/s rd, 132 kB/s wr, 185 op/ |
| 128 | |
| 129 | MON |
| 130 | **** |
| 131 | |
| 132 | http://ceph.com/docs/master/rados/troubleshooting/troubleshooting-mon/ |
| 133 | |
| 134 | OSD |
| 135 | **** |
| 136 | |
| 137 | http://ceph.com/docs/master/rados/troubleshooting/troubleshooting-osd/ |
| 138 | |
| 139 | - :code:`ceph osd tree` - show all OSDs and it's state |
| 140 | |
| 141 | .. code-block:: bash |
| 142 | |
| 143 | root@c-01:~# ceph osd tree |
| 144 | ID WEIGHT TYPE NAME UP/DOWN REWEIGHT PRIMARY-AFFINITY |
| 145 | -4 0 host c-04 |
| 146 | -1 10.79993 root default |
| 147 | -2 3.59998 host c-01 |
| 148 | 0 1.79999 osd.0 up 1.00000 1.00000 |
| 149 | 1 1.79999 osd.1 up 1.00000 1.00000 |
| 150 | -3 3.59998 host c-02 |
| 151 | 2 1.79999 osd.2 up 1.00000 1.00000 |
| 152 | 3 1.79999 osd.3 up 1.00000 1.00000 |
| 153 | -5 3.59998 host c-03 |
| 154 | 4 1.79999 osd.4 up 1.00000 1.00000 |
| 155 | 5 1.79999 osd.5 up 1.00000 1.00000 |
| 156 | |
| 157 | - :code:`ceph osd pools ls` - list of pool |
| 158 | |
| 159 | .. code-block:: bash |
| 160 | |
| 161 | root@c-01:~# ceph osd lspools |
| 162 | 0 rbd,1 test |
| 163 | |
| 164 | PG |
| 165 | *** |
| 166 | |
| 167 | http://ceph.com/docs/master/rados/troubleshooting/troubleshooting-pg |
| 168 | |
| 169 | - :code:`ceph pg ls` - list placement groups |
| 170 | |
| 171 | .. code-block:: bash |
| 172 | |
| 173 | root@c-01:~# ceph pg ls | head -n 4 |
| 174 | pg_stat objects mip degr misp unf bytes log disklog state state_stamp v reported up up_primary acting acting_primary last_scrub scrub_stamp last_deep_scrub deep_scrub_stamp |
| 175 | 0.0 11 0 0 0 0 46137344 3044 3044 active+clean 2015-07-02 10:12:40.603692 226'10652 226:1798 [4,2,0] 4 [4,2,0] 4 0'0 2015-07-01 18:38:33.126953 0'0 2015-07-01 18:17:01.904194 |
| 176 | 0.1 7 0 0 0 0 25165936 3026 3026 active+clean 2015-07-02 10:12:40.585833 226'5808 226:1070 [2,4,1] 2 [2,4,1] 2 0'0 2015-07-01 18:38:32.352721 0'0 2015-07-01 18:17:01.904198 |
| 177 | 0.2 18 0 0 0 0 75497472 3039 3039 active+clean 2015-07-02 10:12:39.569630 226'17447 226:3213 [3,1,5] 3 [3,1,5] 3 0'0 2015-07-01 18:38:34.308228 0'0 2015-07-01 18:17:01.904199 |
| 178 | |
| 179 | - :code:`ceph pg map 1.1` - show mapping between PG and OSD |
| 180 | |
| 181 | .. code-block:: bash |
| 182 | |
| 183 | root@c-01:~# ceph pg map 1.1 |
| 184 | osdmap e226 pg 1.1 (1.1) -> up [5,1,2] acting [5,1,2] |
| 185 | |
| 186 | |
| 187 | |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 188 | Sample pillars |
| 189 | ============== |
| 190 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 191 | Common metadata for all nodes/roles |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 192 | |
| 193 | .. code-block:: yaml |
| 194 | |
| 195 | ceph: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 196 | common: |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 197 | version: luminous |
Jiri Broulik | 4255205 | 2018-02-15 15:23:29 +0100 | [diff] [blame] | 198 | cluster_name: ceph |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 199 | config: |
| 200 | global: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 201 | param1: value1 |
| 202 | param2: value1 |
| 203 | param3: value1 |
| 204 | pool_section: |
| 205 | param1: value2 |
| 206 | param2: value2 |
| 207 | param3: value2 |
| 208 | fsid: a619c5fc-c4ed-4f22-9ed2-66cf2feca23d |
| 209 | members: |
| 210 | - name: cmn01 |
| 211 | host: 10.0.0.1 |
| 212 | - name: cmn02 |
| 213 | host: 10.0.0.2 |
| 214 | - name: cmn03 |
| 215 | host: 10.0.0.3 |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 216 | keyring: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 217 | admin: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 218 | caps: |
| 219 | mds: "allow *" |
| 220 | mgr: "allow *" |
| 221 | mon: "allow *" |
| 222 | osd: "allow *" |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 223 | bootstrap-osd: |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 224 | caps: |
| 225 | mon: "allow profile bootstrap-osd" |
| 226 | |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 227 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 228 | Optional definition for cluster and public networks. Cluster network is used |
| 229 | for replication. Public network for front-end communication. |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 230 | |
| 231 | .. code-block:: yaml |
| 232 | |
| 233 | ceph: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 234 | common: |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 235 | version: luminous |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 236 | fsid: a619c5fc-c4ed-4f22-9ed2-66cf2feca23d |
| 237 | .... |
| 238 | public_network: 10.0.0.0/24, 10.1.0.0/24 |
| 239 | cluster_network: 10.10.0.0/24, 10.11.0.0/24 |
| 240 | |
| 241 | |
| 242 | Ceph mon (control) roles |
| 243 | ------------------------ |
| 244 | |
| 245 | Monitors: A Ceph Monitor maintains maps of the cluster state, including the |
| 246 | monitor map, the OSD map, the Placement Group (PG) map, and the CRUSH map. |
| 247 | Ceph maintains a history (called an “epoch”) of each state change in the Ceph |
| 248 | Monitors, Ceph OSD Daemons, and PGs. |
| 249 | |
| 250 | .. code-block:: yaml |
| 251 | |
| 252 | ceph: |
| 253 | common: |
| 254 | config: |
| 255 | mon: |
| 256 | key: value |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 257 | mon: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 258 | enabled: true |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 259 | keyring: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 260 | mon: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 261 | caps: |
| 262 | mon: "allow *" |
| 263 | admin: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 264 | caps: |
| 265 | mds: "allow *" |
| 266 | mgr: "allow *" |
| 267 | mon: "allow *" |
| 268 | osd: "allow *" |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 269 | |
Ondrej Smola | 91c8316 | 2017-09-12 16:40:02 +0200 | [diff] [blame] | 270 | Ceph mgr roles |
| 271 | ------------------------ |
| 272 | |
| 273 | The Ceph Manager daemon (ceph-mgr) runs alongside monitor daemons, to provide additional monitoring and interfaces to external monitoring and management systems. Since the 12.x (luminous) Ceph release, the ceph-mgr daemon is required for normal operations. The ceph-mgr daemon is an optional component in the 11.x (kraken) Ceph release. |
| 274 | |
| 275 | By default, the manager daemon requires no additional configuration, beyond ensuring it is running. If there is no mgr daemon running, you will see a health warning to that effect, and some of the other information in the output of ceph status will be missing or stale until a mgr is started. |
| 276 | |
| 277 | |
| 278 | .. code-block:: yaml |
| 279 | |
| 280 | ceph: |
| 281 | mgr: |
| 282 | enabled: true |
| 283 | dashboard: |
| 284 | enabled: true |
| 285 | host: 10.103.255.252 |
| 286 | port: 7000 |
| 287 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 288 | |
| 289 | Ceph OSD (storage) roles |
| 290 | ------------------------ |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 291 | |
| 292 | .. code-block:: yaml |
| 293 | |
| 294 | ceph: |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 295 | common: |
Jiri Broulik | ec62dec | 2017-10-10 13:45:15 +0200 | [diff] [blame] | 296 | version: luminous |
| 297 | fsid: a619c5fc-c4ed-4f22-9ed2-66cf2feca23d |
| 298 | public_network: 10.0.0.0/24, 10.1.0.0/24 |
| 299 | cluster_network: 10.10.0.0/24, 10.11.0.0/24 |
| 300 | keyring: |
| 301 | bootstrap-osd: |
| 302 | caps: |
| 303 | mon: "allow profile bootstrap-osd" |
| 304 | .... |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 305 | osd: |
| 306 | enabled: true |
Jiri Broulik | ec62dec | 2017-10-10 13:45:15 +0200 | [diff] [blame] | 307 | crush_parent: rack01 |
| 308 | journal_size: 20480 (20G) |
| 309 | bluestore_block_db_size: 10073741824 (10G) |
| 310 | bluestore_block_wal_size: 10073741824 (10G) |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 311 | bluestore_block_size: 807374182400 (800G) |
| 312 | backend: |
| 313 | filestore: |
| 314 | disks: |
| 315 | - dev: /dev/sdm |
| 316 | enabled: false |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 317 | journal: /dev/ssd |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 318 | journal_partition: 5 |
| 319 | data_partition: 6 |
| 320 | lockbox_partition: 7 |
| 321 | data_partition_size: 12000 (MB) |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 322 | class: bestssd |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 323 | weight: 1.666 |
Jiri Broulik | 58ff84b | 2017-11-21 14:23:51 +0100 | [diff] [blame] | 324 | dmcrypt: true |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 325 | journal_dmcrypt: false |
| 326 | - dev: /dev/sdf |
| 327 | journal: /dev/ssd |
| 328 | journal_dmcrypt: true |
| 329 | class: bestssd |
| 330 | weight: 1.666 |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 331 | - dev: /dev/sdl |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 332 | journal: /dev/ssd |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 333 | class: bestssd |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 334 | weight: 1.666 |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 335 | bluestore: |
| 336 | disks: |
| 337 | - dev: /dev/sdb |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 338 | - dev: /dev/sdf |
| 339 | block_db: /dev/ssd |
| 340 | block_wal: /dev/ssd |
| 341 | block_db_dmcrypt: true |
| 342 | block_wal_dmcrypt: true |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 343 | - dev: /dev/sdc |
| 344 | block_db: /dev/ssd |
| 345 | block_wal: /dev/ssd |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 346 | data_partition: 1 |
| 347 | block_partition: 2 |
| 348 | lockbox_partition: 5 |
| 349 | block_db_partition: 3 |
| 350 | block_wal_partition: 4 |
Jiri Broulik | c2be93b | 2017-10-03 14:20:00 +0200 | [diff] [blame] | 351 | class: ssd |
| 352 | weight: 1.666 |
Jiri Broulik | 58ff84b | 2017-11-21 14:23:51 +0100 | [diff] [blame] | 353 | dmcrypt: true |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 354 | block_db_dmcrypt: false |
| 355 | block_wal_dmcrypt: false |
Jiri Broulik | d572904 | 2017-09-19 20:07:22 +0200 | [diff] [blame] | 356 | - dev: /dev/sdd |
| 357 | enabled: false |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 358 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 359 | |
Jiri Broulik | c2be93b | 2017-10-03 14:20:00 +0200 | [diff] [blame] | 360 | Ceph client roles - ...Deprecated - use ceph:common instead |
| 361 | -------------------------------------------------------- |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 362 | |
| 363 | Simple ceph client service |
Simon Pasquier | f8e6f9e | 2017-07-03 10:15:20 +0200 | [diff] [blame] | 364 | |
| 365 | .. code-block:: yaml |
| 366 | |
| 367 | ceph: |
| 368 | client: |
| 369 | config: |
| 370 | global: |
| 371 | mon initial members: ceph1,ceph2,ceph3 |
| 372 | mon host: 10.103.255.252:6789,10.103.255.253:6789,10.103.255.254:6789 |
| 373 | keyring: |
| 374 | monitoring: |
| 375 | key: 00000000000000000000000000000000000000== |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 376 | |
| 377 | At OpenStack control settings are usually located at cinder-volume or glance- |
| 378 | registry services. |
| 379 | |
| 380 | .. code-block:: yaml |
| 381 | |
| 382 | ceph: |
| 383 | client: |
| 384 | config: |
| 385 | global: |
| 386 | fsid: 00000000-0000-0000-0000-000000000000 |
| 387 | mon initial members: ceph1,ceph2,ceph3 |
| 388 | mon host: 10.103.255.252:6789,10.103.255.253:6789,10.103.255.254:6789 |
| 389 | osd_fs_mkfs_arguments_xfs: |
| 390 | osd_fs_mount_options_xfs: rw,noatime |
| 391 | network public: 10.0.0.0/24 |
| 392 | network cluster: 10.0.0.0/24 |
| 393 | osd_fs_type: xfs |
| 394 | osd: |
| 395 | osd journal size: 7500 |
| 396 | filestore xattr use omap: true |
| 397 | mon: |
| 398 | mon debug dump transactions: false |
| 399 | keyring: |
| 400 | cinder: |
| 401 | key: 00000000000000000000000000000000000000== |
| 402 | glance: |
| 403 | key: 00000000000000000000000000000000000000== |
| 404 | |
| 405 | |
| 406 | Ceph gateway |
| 407 | ------------ |
| 408 | |
| 409 | Rados gateway with keystone v2 auth backend |
| 410 | |
| 411 | .. code-block:: yaml |
| 412 | |
| 413 | ceph: |
| 414 | radosgw: |
| 415 | enabled: true |
| 416 | hostname: gw.ceph.lab |
| 417 | bind: |
| 418 | address: 10.10.10.1 |
| 419 | port: 8080 |
| 420 | identity: |
| 421 | engine: keystone |
| 422 | api_version: 2 |
| 423 | host: 10.10.10.100 |
| 424 | port: 5000 |
| 425 | user: admin |
| 426 | password: password |
| 427 | tenant: admin |
| 428 | |
| 429 | Rados gateway with keystone v3 auth backend |
| 430 | |
| 431 | .. code-block:: yaml |
| 432 | |
| 433 | ceph: |
cdodda | 9b8362c | 2018-04-19 18:06:41 -0500 | [diff] [blame] | 434 | common: |
| 435 | config: |
| 436 | rgw: |
| 437 | key: value |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 438 | radosgw: |
| 439 | enabled: true |
| 440 | hostname: gw.ceph.lab |
| 441 | bind: |
| 442 | address: 10.10.10.1 |
| 443 | port: 8080 |
| 444 | identity: |
| 445 | engine: keystone |
| 446 | api_version: 3 |
| 447 | host: 10.10.10.100 |
| 448 | port: 5000 |
| 449 | user: admin |
| 450 | password: password |
| 451 | project: admin |
| 452 | domain: default |
| 453 | |
| 454 | |
| 455 | Ceph setup role |
| 456 | --------------- |
| 457 | |
| 458 | Replicated ceph storage pool |
| 459 | |
| 460 | .. code-block:: yaml |
| 461 | |
| 462 | ceph: |
| 463 | setup: |
| 464 | pool: |
| 465 | replicated_pool: |
| 466 | pg_num: 256 |
| 467 | pgp_num: 256 |
| 468 | type: replicated |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 469 | crush_rule: sata |
| 470 | application: rbd |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 471 | |
Jiri Broulik | eaf4147 | 2017-10-18 09:56:33 +0200 | [diff] [blame] | 472 | .. note:: For Kraken and earlier releases please specify crush_rule as a ruleset number. |
| 473 | For Kraken and earlier releases application param is not needed. |
| 474 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 475 | Erasure ceph storage pool |
| 476 | |
| 477 | .. code-block:: yaml |
| 478 | |
| 479 | ceph: |
| 480 | setup: |
| 481 | pool: |
| 482 | erasure_pool: |
| 483 | pg_num: 256 |
| 484 | pgp_num: 256 |
| 485 | type: erasure |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 486 | crush_rule: ssd |
| 487 | application: rbd |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 488 | |
Jiri Broulik | d68e33a | 2017-10-24 10:54:43 +0200 | [diff] [blame] | 489 | |
Jiri Broulik | e4ba9f6 | 2017-11-08 11:33:00 +0100 | [diff] [blame] | 490 | Inline compression for Bluestore backend |
| 491 | |
| 492 | .. code-block:: yaml |
| 493 | |
| 494 | ceph: |
| 495 | setup: |
| 496 | pool: |
| 497 | volumes: |
| 498 | pg_num: 256 |
| 499 | pgp_num: 256 |
| 500 | type: replicated |
| 501 | crush_rule: hdd |
| 502 | application: rbd |
| 503 | compression_algorithm: snappy |
| 504 | compression_mode: aggressive |
| 505 | compression_required_ratio: .875 |
| 506 | ... |
| 507 | |
| 508 | |
Jiri Broulik | d68e33a | 2017-10-24 10:54:43 +0200 | [diff] [blame] | 509 | Ceph manage keyring keys |
| 510 | ------------------------ |
| 511 | |
| 512 | Keyrings are dynamically generated unless specified by the following pillar. |
| 513 | |
| 514 | .. code-block:: yaml |
| 515 | |
| 516 | ceph: |
| 517 | common: |
| 518 | manage_keyring: true |
| 519 | keyring: |
| 520 | glance: |
| 521 | name: images |
| 522 | key: AACf3ulZFFPNDxAAd2DWds3aEkHh4IklZVgIaQ== |
| 523 | caps: |
| 524 | mon: "allow r" |
| 525 | osd: "allow class-read object_prefix rdb_children, allow rwx pool=images" |
| 526 | |
| 527 | |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 528 | Generate CRUSH map - Recommended way |
| 529 | ----------------------------------- |
Tomáš Kukrál | 363d37d | 2017-08-17 13:40:20 +0200 | [diff] [blame] | 530 | |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 531 | It is required to define the `type` for crush buckets and these types must start with `root` (top) and end with `host`. OSD daemons will be assigned to hosts according to it's hostname. Weight of the buckets will be calculated according to weight of it's children. |
| 532 | |
| 533 | If the pools that are in use have size of 3 it is best to have 3 children of a specific type in the root CRUSH tree to replicate objects across (Specified in rule steps by 'type region'). |
Tomáš Kukrál | 363d37d | 2017-08-17 13:40:20 +0200 | [diff] [blame] | 534 | |
| 535 | .. code-block:: yaml |
| 536 | |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 537 | ceph: |
| 538 | setup: |
| 539 | crush: |
| 540 | enabled: True |
| 541 | tunables: |
| 542 | choose_total_tries: 50 |
| 543 | choose_local_tries: 0 |
| 544 | choose_local_fallback_tries: 0 |
| 545 | chooseleaf_descend_once: 1 |
| 546 | chooseleaf_vary_r: 1 |
| 547 | chooseleaf_stable: 1 |
| 548 | straw_calc_version: 1 |
| 549 | allowed_bucket_algs: 54 |
| 550 | type: |
| 551 | - root |
| 552 | - region |
| 553 | - rack |
| 554 | - host |
Jiri Broulik | eaf4147 | 2017-10-18 09:56:33 +0200 | [diff] [blame] | 555 | - osd |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 556 | root: |
| 557 | - name: root-ssd |
| 558 | - name: root-sata |
| 559 | region: |
| 560 | - name: eu-1 |
| 561 | parent: root-sata |
| 562 | - name: eu-2 |
| 563 | parent: root-sata |
| 564 | - name: eu-3 |
| 565 | parent: root-ssd |
| 566 | - name: us-1 |
| 567 | parent: root-sata |
| 568 | rack: |
| 569 | - name: rack01 |
| 570 | parent: eu-1 |
| 571 | - name: rack02 |
| 572 | parent: eu-2 |
| 573 | - name: rack03 |
| 574 | parent: us-1 |
| 575 | rule: |
| 576 | sata: |
| 577 | ruleset: 0 |
| 578 | type: replicated |
| 579 | min_size: 1 |
| 580 | max_size: 10 |
| 581 | steps: |
| 582 | - take take root-ssd |
| 583 | - chooseleaf firstn 0 type region |
| 584 | - emit |
| 585 | ssd: |
| 586 | ruleset: 1 |
| 587 | type: replicated |
| 588 | min_size: 1 |
| 589 | max_size: 10 |
| 590 | steps: |
| 591 | - take take root-sata |
| 592 | - chooseleaf firstn 0 type region |
| 593 | - emit |
| 594 | |
| 595 | |
| 596 | Generate CRUSH map - Alternative way |
| 597 | ------------------------------------ |
| 598 | |
| 599 | It's necessary to create per OSD pillar. |
| 600 | |
| 601 | .. code-block:: yaml |
| 602 | |
| 603 | ceph: |
| 604 | osd: |
| 605 | crush: |
| 606 | - type: root |
| 607 | name: root1 |
| 608 | - type: region |
| 609 | name: eu-1 |
| 610 | - type: rack |
| 611 | name: rack01 |
| 612 | - type: host |
| 613 | name: osd001 |
| 614 | |
Jiri Broulik | 8870b87 | 2018-01-24 18:04:25 +0100 | [diff] [blame] | 615 | Add OSDs with specific weight |
| 616 | ----------------------------- |
| 617 | |
| 618 | Add OSD device(s) with initial weight set specifically to certain value. |
| 619 | |
| 620 | .. code-block:: yaml |
| 621 | |
| 622 | ceph: |
| 623 | osd: |
| 624 | crush_initial_weight: 0 |
| 625 | |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 626 | |
| 627 | Apply CRUSH map |
| 628 | --------------- |
| 629 | |
| 630 | Before you apply CRUSH map please make sure that settings in generated file in /etc/ceph/crushmap are correct. |
| 631 | |
| 632 | .. code-block:: yaml |
| 633 | |
| 634 | ceph: |
| 635 | setup: |
| 636 | crush: |
| 637 | enforce: true |
| 638 | pool: |
| 639 | images: |
| 640 | crush_rule: sata |
| 641 | application: rbd |
| 642 | volumes: |
| 643 | crush_rule: sata |
| 644 | application: rbd |
| 645 | vms: |
| 646 | crush_rule: ssd |
| 647 | application: rbd |
| 648 | |
Jiri Broulik | eaf4147 | 2017-10-18 09:56:33 +0200 | [diff] [blame] | 649 | .. note:: For Kraken and earlier releases please specify crush_rule as a ruleset number. |
| 650 | For Kraken and earlier releases application param is not needed. |
| 651 | |
Jiri Broulik | 97af8ab | 2017-10-12 14:32:51 +0200 | [diff] [blame] | 652 | |
| 653 | Persist CRUSH map |
| 654 | -------------------- |
| 655 | |
| 656 | After the CRUSH map is applied to Ceph it's recommended to persist the same settings even after OSD reboots. |
| 657 | |
| 658 | .. code-block:: yaml |
| 659 | |
| 660 | ceph: |
| 661 | osd: |
| 662 | crush_update: false |
| 663 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 664 | |
| 665 | Ceph monitoring |
| 666 | --------------- |
| 667 | |
Jiri Broulik | 4457407 | 2017-11-14 12:27:39 +0100 | [diff] [blame] | 668 | By default monitoring is setup to collect information from MON and OSD nodes. To change the default values add the following pillar to MON nodes. |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 669 | |
| 670 | .. code-block:: yaml |
| 671 | |
| 672 | ceph: |
Simon Pasquier | f8e6f9e | 2017-07-03 10:15:20 +0200 | [diff] [blame] | 673 | monitoring: |
Jiri Broulik | 4457407 | 2017-11-14 12:27:39 +0100 | [diff] [blame] | 674 | space_used_warning_threshold: 0.75 |
| 675 | space_used_critical_threshold: 0.85 |
| 676 | apply_latency_threshold: 0.007 |
| 677 | commit_latency_threshold: 0.7 |
| 678 | pool_space_used_utilization_warning_threshold: 0.75 |
| 679 | pool_space_used_critical_threshold: 0.85 |
| 680 | pool_write_ops_threshold: 200 |
| 681 | pool_write_bytes_threshold: 70000000 |
| 682 | pool_read_bytes_threshold: 70000000 |
| 683 | pool_read_ops_threshold: 1000 |
Simon Pasquier | f8e6f9e | 2017-07-03 10:15:20 +0200 | [diff] [blame] | 684 | |
Mateusz Los | 4dd8c4f | 2017-12-01 09:53:02 +0100 | [diff] [blame] | 685 | Ceph monitor backups |
| 686 | -------------------- |
| 687 | |
| 688 | Backup client with ssh/rsync remote host |
| 689 | |
| 690 | .. code-block:: yaml |
| 691 | |
| 692 | ceph: |
| 693 | backup: |
| 694 | client: |
| 695 | enabled: true |
| 696 | full_backups_to_keep: 3 |
| 697 | hours_before_full: 24 |
| 698 | target: |
| 699 | host: cfg01 |
Jiri Broulik | 44feb04 | 2018-03-05 12:10:19 +0100 | [diff] [blame] | 700 | backup_dir: server-backup-dir |
Mateusz Los | 4dd8c4f | 2017-12-01 09:53:02 +0100 | [diff] [blame] | 701 | |
| 702 | Backup client with local backup only |
| 703 | |
| 704 | .. code-block:: yaml |
| 705 | |
| 706 | ceph: |
| 707 | backup: |
| 708 | client: |
| 709 | enabled: true |
| 710 | full_backups_to_keep: 3 |
| 711 | hours_before_full: 24 |
| 712 | |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 713 | |
| 714 | Backup client at exact times: |
| 715 | |
| 716 | ..code-block:: yaml |
| 717 | |
| 718 | ceph: |
| 719 | backup: |
| 720 | client: |
| 721 | enabled: true |
| 722 | full_backups_to_keep: 3 |
| 723 | incr_before_full: 3 |
| 724 | backup_times: |
Martin Polreich | fe1b390 | 2018-04-25 15:32:30 +0200 | [diff] [blame] | 725 | day_of_week: 0 |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 726 | hour: 4 |
| 727 | minute: 52 |
| 728 | compression: true |
| 729 | compression_threads: 2 |
| 730 | database: |
| 731 | user: user |
| 732 | password: password |
| 733 | target: |
| 734 | host: host01 |
| 735 | |
| 736 | .. note:: Parameters in ``backup_times`` section can be used to set up exact |
| 737 | time the cron job should be executed. In this example, the backup job |
| 738 | would be executed every Sunday at 4:52 AM. If any of the individual |
| 739 | ``backup_times`` parameters is not defined, the defalut ``*`` value will be |
| 740 | used. For example, if minute parameter is ``*``, it will run the backup every minute, |
| 741 | which is ususally not desired. |
Martin Polreich | fe1b390 | 2018-04-25 15:32:30 +0200 | [diff] [blame] | 742 | Available parameters are ``day_of_week``, ``day_of_month``, ``month``, ``hour`` and ``minute``. |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 743 | Please see the crontab reference for further info on how to set these parameters. |
| 744 | |
| 745 | .. note:: Please be aware that only ``backup_times`` section OR |
| 746 | ``hours_before_full(incr)`` can be defined. If both are defined, |
| 747 | the ``backup_times`` section will be peferred. |
| 748 | |
| 749 | .. note:: New parameter ``incr_before_full`` needs to be defined. This |
| 750 | number sets number of incremental backups to be run, before a full backup |
| 751 | is performed. |
| 752 | |
Mateusz Los | 4dd8c4f | 2017-12-01 09:53:02 +0100 | [diff] [blame] | 753 | Backup server rsync |
| 754 | |
| 755 | .. code-block:: yaml |
| 756 | |
| 757 | ceph: |
| 758 | backup: |
| 759 | server: |
| 760 | enabled: true |
| 761 | hours_before_full: 24 |
| 762 | full_backups_to_keep: 5 |
| 763 | key: |
| 764 | ceph_pub_key: |
| 765 | enabled: true |
| 766 | key: ssh_rsa |
| 767 | |
Jiri Broulik | 62892df | 2018-02-28 16:22:00 +0100 | [diff] [blame] | 768 | Backup server without strict client restriction |
| 769 | |
| 770 | .. code-block:: yaml |
| 771 | |
| 772 | ceph: |
| 773 | backup: |
| 774 | restrict_clients: false |
| 775 | |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 776 | Backup server at exact times: |
| 777 | |
| 778 | ..code-block:: yaml |
| 779 | |
| 780 | ceph: |
| 781 | backup: |
| 782 | server: |
| 783 | enabled: true |
| 784 | full_backups_to_keep: 3 |
| 785 | incr_before_full: 3 |
| 786 | backup_dir: /srv/backup |
| 787 | backup_times: |
Martin Polreich | fe1b390 | 2018-04-25 15:32:30 +0200 | [diff] [blame] | 788 | day_of_week: 0 |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 789 | hour: 4 |
| 790 | minute: 52 |
| 791 | key: |
| 792 | ceph_pub_key: |
| 793 | enabled: true |
| 794 | key: key |
| 795 | |
| 796 | .. note:: Parameters in ``backup_times`` section can be used to set up exact |
| 797 | time the cron job should be executed. In this example, the backup job |
| 798 | would be executed every Sunday at 4:52 AM. If any of the individual |
| 799 | ``backup_times`` parameters is not defined, the defalut ``*`` value will be |
| 800 | used. For example, if minute parameter is ``*``, it will run the backup every minute, |
| 801 | which is ususally not desired. |
Martin Polreich | fe1b390 | 2018-04-25 15:32:30 +0200 | [diff] [blame] | 802 | Available parameters are ``day_of_week``, ``day_of_month``, ``month``, ``hour`` and ``minute``. |
Martin Polreich | 8d37f28 | 2018-03-04 17:38:15 +0100 | [diff] [blame] | 803 | Please see the crontab reference for further info on how to set these parameters. |
| 804 | |
| 805 | .. note:: Please be aware that only ``backup_times`` section OR |
| 806 | ``hours_before_full(incr)`` can be defined. If both are defined, The |
| 807 | ``backup_times`` section will be peferred. |
| 808 | |
| 809 | .. note:: New parameter ``incr_before_full`` needs to be defined. This |
| 810 | number sets number of incremental backups to be run, before a full backup |
| 811 | is performed. |
| 812 | |
Jiri Broulik | 4255205 | 2018-02-15 15:23:29 +0100 | [diff] [blame] | 813 | Migration from Decapod to salt-formula-ceph |
| 814 | -------------------------------------------- |
| 815 | |
| 816 | The following configuration will run a python script which will generate ceph config and osd disk mappings to be put in cluster model. |
| 817 | |
| 818 | .. code-block:: yaml |
| 819 | |
| 820 | ceph: |
| 821 | decapod: |
| 822 | ip: 192.168.1.10 |
| 823 | user: user |
| 824 | password: psswd |
| 825 | deploy_config_name: ceph |
Mateusz Los | 4dd8c4f | 2017-12-01 09:53:02 +0100 | [diff] [blame] | 826 | |
Simon Pasquier | f8e6f9e | 2017-07-03 10:15:20 +0200 | [diff] [blame] | 827 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 828 | More information |
| 829 | ================ |
jpavlik | 8425d36 | 2015-06-09 15:23:27 +0200 | [diff] [blame] | 830 | |
| 831 | * https://github.com/cloud-ee/ceph-salt-formula |
| 832 | * http://ceph.com/ceph-storage/ |
jan kaufman | 4f7757b | 2015-06-12 10:49:00 +0200 | [diff] [blame] | 833 | * http://ceph.com/docs/master/start/intro/ |
Filip Pytloun | 32841d7 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 834 | |
Ondrej Smola | 81d1a19 | 2017-08-17 11:13:10 +0200 | [diff] [blame] | 835 | |
| 836 | Documentation and bugs |
Filip Pytloun | 32841d7 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 837 | ====================== |
| 838 | |
| 839 | To learn how to install and update salt-formulas, consult the documentation |
| 840 | available online at: |
| 841 | |
| 842 | http://salt-formulas.readthedocs.io/ |
| 843 | |
| 844 | In the unfortunate event that bugs are discovered, they should be reported to |
| 845 | the appropriate issue tracker. Use Github issue tracker for specific salt |
| 846 | formula: |
| 847 | |
| 848 | https://github.com/salt-formulas/salt-formula-ceph/issues |
| 849 | |
| 850 | For feature requests, bug reports or blueprints affecting entire ecosystem, |
| 851 | use Launchpad salt-formulas project: |
| 852 | |
| 853 | https://launchpad.net/salt-formulas |
| 854 | |
| 855 | You can also join salt-formulas-users team and subscribe to mailing list: |
| 856 | |
| 857 | https://launchpad.net/~salt-formulas-users |
| 858 | |
| 859 | Developers wishing to work on the salt-formulas projects should always base |
| 860 | their work on master branch and submit pull request against specific formula. |
| 861 | |
| 862 | https://github.com/salt-formulas/salt-formula-ceph |
| 863 | |
| 864 | Any questions or feedback is always welcome so feel free to join our IRC |
| 865 | channel: |
| 866 | |
| 867 | #salt-formulas @ irc.freenode.net |