From 3a9238f6709b54a8d3c9a168c2488569198ed790 Mon Sep 17 00:00:00 2001 From: Unrud Date: Tue, 22 Dec 2015 06:55:17 +0100 Subject: [PATCH] Check and create PID file in a race-free manner --- radicale/__main__.py | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/radicale/__main__.py b/radicale/__main__.py index b2f39db..879603b 100644 --- a/radicale/__main__.py +++ b/radicale/__main__.py @@ -99,13 +99,20 @@ def run(): # Fork if Radicale is launched as daemon if config.getboolean("server", "daemon"): - if os.path.exists(config.get("server", "pid")): - raise OSError("PID file exists: %s" % config.get("server", "pid")) + # Check and create PID file in a race-free manner + if config.get("server", "pid"): + try: + pid_fd = os.open(config.get("server", "pid"), + os.O_CREAT | os.O_EXCL | os.O_WRONLY) + except: + raise OSError("PID file exists: %s" % + config.get("server", "pid")) pid = os.fork() if pid: sys.exit() - elif config.get("server", "pid"): - with open(config.get("server", "pid"), "w") as pid_file: + # Write PID + if config.get("server", "pid"): + with os.fdopen(pid_fd, "w") as pid_file: pid_file.write(str(os.getpid())) sys.stdout = sys.stderr = open(os.devnull, "w")