|
|
872084 |
From 4553ec1bed2a65dbeb5f2f93f23d5332e6750522 Mon Sep 17 00:00:00 2001
|
|
|
872084 |
From: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
872084 |
Date: Thu, 13 Sep 2018 16:25:42 +0200
|
|
|
872084 |
Subject: [PATCH] dd: log lock warning only once not x times per sec
|
|
|
872084 |
|
|
|
872084 |
Related to #1588272
|
|
|
872084 |
|
|
|
872084 |
Signed-off-by: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
872084 |
|
|
|
872084 |
Conflicts:
|
|
|
872084 |
src/lib/dump_dir.c
|
|
|
872084 |
---
|
|
|
872084 |
src/include/dump_dir.h | 3 ++-
|
|
|
872084 |
src/lib/dump_dir.c | 19 ++++++++++++++-----
|
|
|
872084 |
2 files changed, 16 insertions(+), 6 deletions(-)
|
|
|
872084 |
|
|
|
872084 |
diff --git a/src/include/dump_dir.h b/src/include/dump_dir.h
|
|
|
872084 |
index 84cabbf8..690695a0 100644
|
|
|
872084 |
--- a/src/include/dump_dir.h
|
|
|
872084 |
+++ b/src/include/dump_dir.h
|
|
|
872084 |
@@ -37,7 +37,8 @@ extern "C" {
|
|
|
872084 |
|
|
|
872084 |
/* Utility function */
|
|
|
872084 |
int create_symlink_lockfile(const char *filename, const char *pid_str);
|
|
|
872084 |
-int create_symlink_lockfile_at(int dir_fd, const char *filename, const char *pid_str);
|
|
|
872084 |
+int create_symlink_lockfile_at(int dir_fd, const char *filename,
|
|
|
872084 |
+ const char *pid_str, bool log_all_warnings);
|
|
|
872084 |
|
|
|
872084 |
/* Opens filename for reading relatively to a directory represented by dir_fd.
|
|
|
872084 |
* The function fails if the file is symbolic link, directory or hard link.
|
|
|
872084 |
diff --git a/src/lib/dump_dir.c b/src/lib/dump_dir.c
|
|
|
872084 |
index acc5e561..c0117380 100644
|
|
|
872084 |
--- a/src/lib/dump_dir.c
|
|
|
872084 |
+++ b/src/lib/dump_dir.c
|
|
|
872084 |
@@ -231,7 +231,8 @@ static time_t parse_time_file_at(int dir_fd, const char *filename)
|
|
|
872084 |
* 0: failed to lock (someone else has it locked)
|
|
|
872084 |
* 1: success
|
|
|
872084 |
*/
|
|
|
872084 |
-int create_symlink_lockfile_at(int dir_fd, const char* lock_file, const char* pid)
|
|
|
872084 |
+int create_symlink_lockfile_at(int dir_fd, const char* lock_file,
|
|
|
872084 |
+ const char* pid, bool log_all_warnings)
|
|
|
872084 |
{
|
|
|
872084 |
while (symlinkat(pid, dir_fd, lock_file) != 0)
|
|
|
872084 |
{
|
|
|
872084 |
@@ -272,7 +273,8 @@ int create_symlink_lockfile_at(int dir_fd, const char* lock_file, const char* pi
|
|
|
872084 |
snprintf(pid_str, sizeof(pid_str), "/proc/%s", pid_buf);
|
|
|
872084 |
if (access(pid_str, F_OK) == 0)
|
|
|
872084 |
{
|
|
|
872084 |
- log("Lock file '%s' is locked by process %s", lock_file, pid_buf);
|
|
|
872084 |
+ if (log_all_warnings)
|
|
|
872084 |
+ log_warning("Lock file '%s' is locked by process %s. Waiting...", lock_file, pid_buf);
|
|
|
872084 |
return 0;
|
|
|
872084 |
}
|
|
|
872084 |
log("Lock file '%s' was locked by process %s, but it crashed?", lock_file, pid_buf);
|
|
|
872084 |
@@ -292,7 +294,7 @@ int create_symlink_lockfile_at(int dir_fd, const char* lock_file, const char* pi
|
|
|
872084 |
|
|
|
872084 |
int create_symlink_lockfile(const char *filename, const char *pid_str)
|
|
|
872084 |
{
|
|
|
872084 |
- return create_symlink_lockfile_at(AT_FDCWD, filename, pid_str);
|
|
|
872084 |
+ return create_symlink_lockfile_at(AT_FDCWD, filename, pid_str, true);
|
|
|
872084 |
}
|
|
|
872084 |
|
|
|
872084 |
static const char *dd_check(struct dump_dir *dd)
|
|
|
872084 |
@@ -333,10 +335,16 @@ static int dd_lock(struct dump_dir *dd, unsigned sleep_usec, int flags)
|
|
|
872084 |
|
|
|
872084 |
unsigned count = NO_TIME_FILE_COUNT;
|
|
|
872084 |
|
|
|
872084 |
- retry:
|
|
|
872084 |
+ retry: ;
|
|
|
872084 |
+ /* If the file is locked by another process, warning "Lock file '.lock' is
|
|
|
872084 |
+ * locked by process $PID" is logged every $sleep_usec usec and fill up log
|
|
|
872084 |
+ * file.
|
|
|
872084 |
+ * rhbz#1588272
|
|
|
872084 |
+ */
|
|
|
872084 |
+ bool log_all_warnings = true;
|
|
|
872084 |
while (1)
|
|
|
872084 |
{
|
|
|
872084 |
- int r = create_symlink_lockfile_at(dd->dd_fd, ".lock", pid_buf);
|
|
|
872084 |
+ int r = create_symlink_lockfile_at(dd->dd_fd, ".lock", pid_buf, log_all_warnings);
|
|
|
872084 |
if (r < 0)
|
|
|
872084 |
return r; /* error */
|
|
|
872084 |
if (r > 0)
|
|
|
872084 |
@@ -348,6 +356,7 @@ static int dd_lock(struct dump_dir *dd, unsigned sleep_usec, int flags)
|
|
|
872084 |
}
|
|
|
872084 |
/* Other process has the lock, wait for it to go away */
|
|
|
872084 |
usleep(sleep_usec);
|
|
|
872084 |
+ log_all_warnings = false;
|
|
|
872084 |
}
|
|
|
872084 |
|
|
|
872084 |
/* Are we called by dd_opendir (as opposed to dd_create)? */
|
|
|
872084 |
--
|
|
|
872084 |
2.17.2
|
|
|
872084 |
|