|
Zbigniew Jędrzejewski-Szmek |
d66047 |
From dd186998dd408c54ffe30df1cc35422e645e0ca2 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
From: Lennart Poettering <lennart@poettering.net>
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
Date: Tue, 26 Nov 2013 18:58:44 +0100
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
Subject: [PATCH] journald: keep statistics on how of we hit/miss the mmap
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
cache
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
(cherry picked from commit bf807d4dbf27c783db8dfd7f4eca321ae4be5b00)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
src/journal/mmap-cache.c | 25 +++++++++++++++++++++++--
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
src/journal/mmap-cache.h | 3 +++
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
src/journal/sd-journal.c | 4 +++-
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
3 files changed, 29 insertions(+), 3 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
diff --git a/src/journal/mmap-cache.c b/src/journal/mmap-cache.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
index 03b57be..42a8a7d 100644
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
--- a/src/journal/mmap-cache.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+++ b/src/journal/mmap-cache.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
@@ -72,6 +72,9 @@ struct MMapCache {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
int n_ref;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
unsigned n_windows;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ unsigned n_hit, n_missed;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
Hashmap *fds;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
Hashmap *contexts;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
@@ -542,13 +545,19 @@ int mmap_cache_get(
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
/* Check whether the current context is the right one already */
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
r = try_context(m, fd, prot, context, keep_always, offset, size, ret);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
- if (r != 0)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ if (r != 0) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ m->n_hit ++;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
return r;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
/* Search for a matching mmap */
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
r = find_mmap(m, fd, prot, context, keep_always, offset, size, ret);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
- if (r != 0)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ if (r != 0) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ m->n_hit ++;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
return r;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ m->n_missed++;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
/* Create a new mmap */
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
return add_mmap(m, fd, prot, context, keep_always, offset, size, st, ret);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
@@ -578,3 +587,15 @@ void mmap_cache_close_context(MMapCache *m, unsigned context) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
context_free(c);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+unsigned mmap_cache_get_hit(MMapCache *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ assert(m);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ return m->n_hit;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+unsigned mmap_cache_get_missed(MMapCache *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ assert(m);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ return m->n_missed;
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
diff --git a/src/journal/mmap-cache.h b/src/journal/mmap-cache.h
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
index 0c42fb8..912336d 100644
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
--- a/src/journal/mmap-cache.h
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+++ b/src/journal/mmap-cache.h
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
@@ -34,3 +34,6 @@ MMapCache* mmap_cache_unref(MMapCache *m);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
int mmap_cache_get(MMapCache *m, int fd, int prot, unsigned context, bool keep_always, uint64_t offset, size_t size, struct stat *st, void **ret);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
void mmap_cache_close_fd(MMapCache *m, int fd);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
void mmap_cache_close_context(MMapCache *m, unsigned context);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+unsigned mmap_cache_get_hit(MMapCache *m);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+unsigned mmap_cache_get_missed(MMapCache *m);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
diff --git a/src/journal/sd-journal.c b/src/journal/sd-journal.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
index 9676f0f..52abbe9 100644
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
--- a/src/journal/sd-journal.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+++ b/src/journal/sd-journal.c
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
@@ -1831,8 +1831,10 @@ _public_ void sd_journal_close(sd_journal *j) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
if (j->inotify_fd >= 0)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
close_nointr_nofail(j->inotify_fd);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
- if (j->mmap)
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ if (j->mmap) {
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ log_debug("mmap cache statistics: %u hit, %u miss", mmap_cache_get_hit(j->mmap), mmap_cache_get_missed(j->mmap));
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
mmap_cache_unref(j->mmap);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
free(j->path);
|
|
Zbigniew Jędrzejewski-Szmek |
d66047 |
free(j->unique_field);
|