summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPablo Neira Ayuso <pablo@netfilter.org>2011-02-15 01:51:11 +0100
committerPablo Neira Ayuso <pablo@netfilter.org>2011-02-15 01:51:11 +0100
commitc2acb11453fc75519862240298e106ac79274780 (patch)
treee5c9c645a9ea86c8316fa502ae907c03c0e8d9fc /src
parent98756c2608f0879a2322919c7441973216565272 (diff)
downloadconntrack-tools-c2acb11453fc75519862240298e106ac79274780.tar.gz
conntrack-tools-c2acb11453fc75519862240298e106ac79274780.zip
cache: log if we received a commit request while already one in progress
This patch improves the case in which we receive a commit request but we are already performing one. This behaviour is suspicious since the HA manager should not trigger a double master transition. Otherwise, something probably is not configured appropriately. This improves 98756c2608f0879a2322919c7441973216565272 "cache: close commit request if we already have one in progress". Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src')
-rw-r--r--src/cache_iterators.c17
-rw-r--r--src/external_cache.c5
2 files changed, 13 insertions, 9 deletions
diff --git a/src/cache_iterators.c b/src/cache_iterators.c
index 2707366..3248c70 100644
--- a/src/cache_iterators.c
+++ b/src/cache_iterators.c
@@ -175,7 +175,7 @@ static int do_commit_master(void *data, void *n)
return 0;
}
-void cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
+int cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
{
unsigned int commit_ok, commit_fail;
struct __commit_container tmp = {
@@ -184,11 +184,11 @@ void cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
};
struct timeval commit_stop, res;
- /* we already have one commit in progress, close this request. */
- if (clientfd && STATE_SYNC(commit).clientfd != -1) {
- close(clientfd);
- return;
- }
+ /* we already have one commit in progress, skip this. The clientfd
+ * descriptor has to be closed by the caller. */
+ if (clientfd && STATE_SYNC(commit).clientfd != -1)
+ return 0;
+
switch(STATE_SYNC(commit).state) {
case COMMIT_STATE_INACTIVE:
gettimeofday(&STATE_SYNC(commit).stats.start, NULL);
@@ -205,7 +205,7 @@ void cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
STATE_SYNC(commit).state = COMMIT_STATE_MASTER;
/* give it another step as soon as possible */
write_evfd(STATE_SYNC(commit).evfd);
- return;
+ return 1;
}
STATE_SYNC(commit).current = 0;
STATE_SYNC(commit).state = COMMIT_STATE_RELATED;
@@ -219,7 +219,7 @@ void cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
STATE_SYNC(commit).state = COMMIT_STATE_RELATED;
/* give it another step as soon as possible */
write_evfd(STATE_SYNC(commit).evfd);
- return;
+ return 1;
}
/* calculate the time that commit has taken */
gettimeofday(&commit_stop, NULL);
@@ -248,6 +248,7 @@ void cache_commit(struct cache *c, struct nfct_handle *h, int clientfd)
close(STATE_SYNC(commit).clientfd);
STATE_SYNC(commit).clientfd = -1;
}
+ return 1;
}
static int do_flush(void *data, void *n)
diff --git a/src/external_cache.c b/src/external_cache.c
index c1181dc..59c706a 100644
--- a/src/external_cache.c
+++ b/src/external_cache.c
@@ -90,7 +90,10 @@ static void external_cache_dump(int fd, int type)
static int external_cache_commit(struct nfct_handle *h, int fd)
{
- cache_commit(external, h, fd);
+ if (!cache_commit(external, h, fd)) {
+ dlog(LOG_NOTICE, "commit already in progress, skipping");
+ return LOCAL_RET_OK;
+ }
/* Keep the client socket open, we want synchronous commits. */
return LOCAL_RET_STOLEN;
}