You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have noticed on my server (Arch) that not a single malicious IP has been blocked.
I debugged the code and notices that the sd_journal_next call always returns 0. So the while loop is always skipped (and no journal message will ever get parsed). I found this discussion systemd/systemd#26577 which describes that a sd_journal_previous call directly after sd_journal_seek_tail is necessary to pull out journal messages with sd_journal_next.
So I applied this patch and tallow started working again.
diff --git a/src/tallow.c b/src/tallow.c
index 58e0fb4..2c9fc85 100644
--- a/src/tallow.c+++ b/src/tallow.c@@ -371,6 +371,7 @@ int main(void)
/* go to the tail and wait */
r = sd_journal_seek_tail(j);
+ sd_journal_previous(j);
sd_journal_wait(j, (uint64_t) 0);
dbg("sd_journal_seek_tail() returned %d\n", r);
while (sd_journal_next(j) != 0)
@@ -387,6 +388,7 @@ int main(void)
if (r == SD_JOURNAL_INVALIDATE) {
fprintf(stderr, "Journal was rotated, resetting\n");
sd_journal_seek_tail(j);
+ sd_journal_previous(j);
} else if (r == SD_JOURNAL_NOP) {
dbg("Timeout reached, waiting again\n");
continue;
Don't know if Clear Linux is also affected by this strange journal behavior.
The text was updated successfully, but these errors were encountered:
Our journald API usage was incorrect causing our tail pointer to stick
after the last received entry, causing us to receive no additional
events at all.
The `sd_journal_next` API states that we should always assume that we
reset to the previous entry after `sd_journal_seek_tail` and this
corrects the behavior that many are seeing where tallow just isn't doing
anything at all.
This addresses clearlinux#25 from clearlinux/tallow. Tested on F41.
Signed-off-by: Auke Kok <[email protected]>
I have noticed on my server (Arch) that not a single malicious IP has been blocked.
I debugged the code and notices that the
sd_journal_next
call always returns 0. So the while loop is always skipped (and no journal message will ever get parsed). I found this discussion systemd/systemd#26577 which describes that asd_journal_previous
call directly aftersd_journal_seek_tail
is necessary to pull out journal messages withsd_journal_next
.So I applied this patch and tallow started working again.
Don't know if Clear Linux is also affected by this strange journal behavior.
The text was updated successfully, but these errors were encountered: