mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 18:53:23 -03:00
Merge #18700: Fix locking on WSL using flock instead of fcntl
e8fa0a3d20
Fix WSL file locking by using flock instead of fcntl (Samuel Dobson) Pull request description: Fixes #18622 A bug in WSL means that fcntl does not exclusively lock files, allowing multiple instances of bitcoin to use the same datadir. If we instead use flock, it works correctly. Passes Travis, but testing on some OS variety would be sensible. From what I can tell, flock and fcntl don't work with each other on linux, so it would still be possible to run a node with this code change and a node before it with the same datadir (this isn't true for Mac/FreeBSD). flock also doesn't support NFS on MacOS and linux<2.6.12 while fcntl did. See here for example: https://gavv.github.io/articles/file-locks/ If changing to flock for all systems is inadvisable, it would also be possible to just detect WSL and use flock when on that platform to avoid the bug. ACKs for top commit: laanwj: Code review ACKe8fa0a3d20
Tree-SHA512: ca1009e171970101f1dc2332c5e998717aee00eebc80bb586b826927a74bd0d4c94712e46d1396821bc30533d76deac391b6e1c406c406865661f57fa062c702
This commit is contained in:
commit
ea3e9e0b84
1 changed files with 29 additions and 8 deletions
21
src/fs.cpp
21
src/fs.cpp
|
@ -6,6 +6,9 @@
|
||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#include <string>
|
||||||
|
#include <sys/file.h>
|
||||||
|
#include <sys/utsname.h>
|
||||||
#else
|
#else
|
||||||
#ifndef NOMINMAX
|
#ifndef NOMINMAX
|
||||||
#define NOMINMAX
|
#define NOMINMAX
|
||||||
|
@ -47,11 +50,27 @@ FileLock::~FileLock()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool IsWSL()
|
||||||
|
{
|
||||||
|
struct utsname uname_data;
|
||||||
|
return uname(&uname_data) == 0 && std::string(uname_data.version).find("Microsoft") != std::string::npos;
|
||||||
|
}
|
||||||
|
|
||||||
bool FileLock::TryLock()
|
bool FileLock::TryLock()
|
||||||
{
|
{
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Exclusive file locking is broken on WSL using fcntl (issue #18622)
|
||||||
|
// This workaround can be removed once the bug on WSL is fixed
|
||||||
|
static const bool is_wsl = IsWSL();
|
||||||
|
if (is_wsl) {
|
||||||
|
if (flock(fd, LOCK_EX | LOCK_NB) == -1) {
|
||||||
|
reason = GetErrorReason();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
struct flock lock;
|
struct flock lock;
|
||||||
lock.l_type = F_WRLCK;
|
lock.l_type = F_WRLCK;
|
||||||
lock.l_whence = SEEK_SET;
|
lock.l_whence = SEEK_SET;
|
||||||
|
@ -61,6 +80,8 @@ bool FileLock::TryLock()
|
||||||
reason = GetErrorReason();
|
reason = GetErrorReason();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
|
Loading…
Add table
Reference in a new issue