[systemd-devel] bug #64614 and journal seeking woes

Zbigniew Jędrzejewski-Szmek zbyszek at in.waw.pl
Tue Jun 25 15:59:53 PDT 2013


Hi,
I was looking at https://bugs.freedesktop.org/show_bug.cgi?id=64614

tl;dr: doing
   sd_journal_seek_tail()
   sd_journal_next()
   sd_journal_next()
   sd_journal_next()
   sd_journal_next()
returns 1 (success) each time, and random entries.

Likewise, doing
   sd_journal_seek_head()
   sd_journal_previous()...
returns 1 (success) and random entries.

Those specific cases could be changed to behave differently, but I
think that there's a more general problem.

According to sd_journal_seek_tail(3), this function positions the journal
"on the last entry". sd_j_seek_head positions the journal on the oldest
entry. It is important that journal is *on* the first/last entry, which
suggests that it is in a valid location. Nevertheless,
   sd_journal_get_cursor()
returns -EADDRNOTAVAIL, as if the journal was *before* or *after* the last
entry.

Also, doing sd_j_seek_tail() + sd_j_previous() moves to the *last* entry,
which seems inconsistent with the description in the man pages (if we
were *at* the last entry, and we move back, we should be at the next to
last entry).

Also, doing sd_j_seek_tail(), waiting a bit while the journal file grows,
and doing sd_j_previous() lands as at the *current* last entry, which
is a bit strange.

I'd like to change:
1. sd_j_seek_tail() to seek to a concrete entry, the last at a specific time,
2. sd_j_seek_head() likewise,
3. allow sd_j_get_cursor() after such a seek
4. make sd_j_seek_tail() + sd_j_next() return 0 (if the file hasn't grown),
   or the first new entry if it has grown meanwhile
5. likewise make sd_j_seek_head() + sd_j_previous() return 0

Thoughts, comments, shrugs?

Zbyszek


More information about the systemd-devel mailing list