From: Sage Weil Date: Wed, 30 May 2012 18:14:26 +0000 (-0700) Subject: filestore: log about syncfs(2) etc support X-Git-Tag: v0.48argonaut~155^2~16 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=07498d66233f388807a458554640cb77424114c0;p=ceph.git filestore: log about syncfs(2) etc support Fixes: #2479 Signed-off-by: Sage Weil --- diff --git a/src/os/FileStore.cc b/src/os/FileStore.cc index da0dea094da80..7ed55dbf91602 100644 --- a/src/os/FileStore.cc +++ b/src/os/FileStore.cc @@ -1471,6 +1471,25 @@ int FileStore::_detect_fs() btrfs = false; } +#ifdef HAVE_SYS_SYNCFS + if (syncfs(fd) == 0) { + dout(0) << "mount syncfs(2) syscall fully supported (by glibc and kernel)" << dendl; + } else { + dout(0) << "mount syncfs(2) syscall supported by glibc BUT NOT the kernel" << dendl; + } else +#endif + { + if (btrfs) { + dout(0) << "mount syncfs(2) syscall not support by glibc, but the btrfs SYNC ioctl will suffice" << dendl; + } else if (m_filestore_fsync_flushes_journal_data) { + dout(0) << "mount syncfs(2) syscall not support by glibc, but 'filestore fsync flushes journal data = true', so fsync will suffice." << dendl; + } else { + dout(0) << "mount syncfs(2) syscall not support by glibc; must use sync(2)." << dendl; + dout(0) << "mount WARNING: multiple ceph-osd daemons on the same host will be slow" << dendl; + } + } + + TEMP_FAILURE_RETRY(::close(fd)); return 0; }