Re: Shared WAL/DB device partition for multiple OSDs?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Aug 23, 2018 at 5:42 AM, Hervé Ballans
<herve.ballans@xxxxxxxxxxxxx> wrote:
> Hello all,
>
> I would like to continue a thread that dates back to last May (sorry if this
> is not a good practice ?..)
>
> Thanks David for your usefil tips on this thread.
> In my side, I created my OSDs with ceph-deploy (in place of ceph-volume)
> [1], but this is exactly the same context as this mentioned on this thread
> (hdd  drive for OSDs and wal/db partitions on NVMe device).
>
> The problem I encounter is that the script that fixes block.db partitions by
> their UUID works very well in live but does not resist to the reboot of the
> OSD node. If I restart the server, the symbolic links of block.db
> automatically go up with the device name /dev/nvme...
> The problem gets worse when we have 2 NVMe devices on the same node beacuse
> in this case, it happens that the paths to the block.db partitions are
> reversed and obviously OSDs don't start !

You didn't mention what versions of ceph-deploy and Ceph you are
using. Since you brought up partitions and OSDs that are not coming
up, it seems
that is related to using ceph-disk and ceph-deploy 1.5.X

I would suggest trying out the newer version of ceph-deploy (2.0.X)
and use ceph-volume, the one caveat being if you need a separate
block.db on the NVMe device
you would need to create the LV yourself.

Some of the manual steps are covered in the bluestore config
reference: http://docs.ceph.com/docs/master/rados/configuration/bluestore-config-ref/#block-and-block-db
>
> As I'm not yet in production, I can probably recreate all my OSDs by forcing
> the path to the block.db partitions with UUID, but I would like to know if
> there was a way to "freeze" the configuration of block.db paths by their
> UUID ("a posteriori") ?
>
> Or maybe (but this is more a system administration issue) that there is a
> way on Linux system to force an NVMe disk to be mounted with a fixed device
> name ? (I specify here that my NVMe partitions do not have a filesystem).
>
> Thanks for your help,
> Hervé
>
> [1] from admin node
> ceph-deploy osd create --debug --bluestore --data $hdd --block-db $db
> $osdnode
>
> Le 11/05/2018 à 18:46, David Turner a écrit :
>
> # Create the OSD
> echo "/dev/sdb /dev/nvme0n1p2
> /dev/sdc /dev/nvme0n1p3" | while read hdd db; do
>   ceph-volume lvm create --bluestore --data $hdd --block.db $db
> done
>
> # Fix the OSDs to look for the block.db partition by UUID instead of its
> device name.
> for db in /var/lib/ceph/osd/*/block.db; do
>   dev=$(readlink $db | grep -Eo nvme[[:digit:]]+n[[:digit:]]+p[[:digit:]]+
> || echo false)
>   if [[ "$dev" != false ]]; then
>     uuid=$(ls -l /dev/disk/by-partuuid/ | awk '/'${dev}'$/ {print $9}')
>     ln -sf /dev/disk/by-partuuid/$uuid $db
>   fi
> done
> systemctl restart ceph-osd.target
>
>
>
> _______________________________________________
> ceph-users mailing list
> ceph-users@xxxxxxxxxxxxxx
> http://lists.ceph.com/listinfo.cgi/ceph-users-ceph.com
>
_______________________________________________
ceph-users mailing list
ceph-users@xxxxxxxxxxxxxx
http://lists.ceph.com/listinfo.cgi/ceph-users-ceph.com




[Index of Archives]     [Information on CEPH]     [Linux Filesystem Development]     [Ceph Development]     [Ceph Large]     [Ceph Dev]     [Linux USB Development]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [xfs]


  Powered by Linux