Back to Ceph

FreeBSD Implementation details

doc/dev/freebsd.rst

21.0.01.3 KB
Original Source

============================== FreeBSD Implementation details

Disk layout

Current implementation works on ZFS pools

  • created in /var/lib/ceph

  • One ZFS pool per OSD, like::

    gpart create -s GPT ada1 gpart add -t freebsd-zfs -l osd1 ada1 zpool create -o mountpoint=/var/lib/ceph/osd/osd.1 osd

  • Maybe add some cache and log (ZIL)? Assuming that ada2 is an SSD::

    gpart create -s GPT ada2 gpart add -t freebsd-zfs -l osd1-log -s 1G ada2 zpool add osd1 log gpt/osd1-log gpart add -t freebsd-zfs -l osd1-cache -s 10G ada2 zpool add osd1 log gpt/osd1-cache

  • Note: UFS2 does not allow large xattribs

Configuration

As per FreeBSD default parts of extra software go into /usr/local/. Which means that for /etc/ceph.conf the default location is /usr/local/etc/ceph/ceph.conf. Smartest thing to do is to create a softlink from /etc/ceph to /usr/local/etc/ceph::

ln -s /usr/local/etc/ceph /etc/ceph

A sample file is provided in /usr/local/share/doc/ceph/sample.ceph.conf

MON creation

Monitors are created by following the manual creation steps on::

https://docs.ceph.com/en/latest/install/manual-freebsd-deployment/

OSD creation

OSDs can be manually created only, see :ref:freebsd_adding_osds