summaryrefslogtreecommitdiff
path: root/src/journal/journal-vacuum.c
Commit message (Collapse)AuthorAgeFilesLines
* tree-wide: drop license boilerplateZbigniew Jędrzejewski-Szmek2018-04-061-13/+0
| | | | | | | | | | Files which are installed as-is (any .service and other unit files, .conf files, .policy files, etc), are left as is. My assumption is that SPDX identifiers are not yet that well known, so it's better to retain the extended header to avoid any doubt. I also kept any copyright lines. We can probably remove them, but it'd nice to obtain explicit acks from all involved authors before doing that.
* tree-wide: use TAKE_PTR() and TAKE_FD() macrosYu Watanabe2018-04-051-2/+1
|
* coredump,journal: when vacuuming use new unlinkat_deallocate() callsLennart Poettering2018-02-121-6/+9
| | | | | | | | | This ensures that clients can't keep all files pinned interfering with our vacuuming logic. This should fix the last issue pointed out in #7998 and #8032 Fixes: #7998
* Add SPDX license identifiers to source files under the LGPLZbigniew Jędrzejewski-Szmek2017-11-191-0/+1
| | | | | This follows what the kernel is doing, c.f. https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=5fd54ace4721fc5ce2bb5aef6318fcf17f421460.
* journalctl: say in which directory we vacuum stuffLennart Poettering2016-10-121-1/+1
| | | | Fixes: #4060
* tree-wide: make ++/-- usage consistent WRT spacingVito Caputo2016-02-221-4/+4
| | | | | | Throughout the tree there's spurious use of spaces separating ++ and -- operators from their respective operands. Make ++ and -- operator consistent with the majority of existing uses; discard the spaces.
* tree-wide: remove Emacs lines from all filesDaniel Mack2016-02-101-2/+0
| | | | | This should be handled fine now by .dir-locals.el, so need to carry that stuff in every file.
* util-lib: split out allocation calls into alloc-util.[ch]Lennart Poettering2015-10-271-0/+1
|
* util-lib: split xattr-related calls into xattr-util.[ch]Lennart Poettering2015-10-271-0/+1
|
* util-lib: introduce dirent-util.[ch] for directory entry callsLennart Poettering2015-10-271-0/+1
| | | | Also, move a couple of more path-related functions to path-util.c.
* util-lib: split string parsing related calls from util.[ch] into parse-util.[ch]Lennart Poettering2015-10-271-0/+1
|
* util-lib: split out fd-related operations into fd-util.[ch]Lennart Poettering2015-10-251-2/+2
| | | | | There are more than enough to deserve their own .c file, hence move them over.
* util-lib: split our string related calls from util.[ch] into its own file ↵Lennart Poettering2015-10-241-2/+5
| | | | | | | | | | | | | | string-util.[ch] There are more than enough calls doing string manipulations to deserve its own files, hence do something about it. This patch also sorts the #include blocks of all files that needed to be updated, according to the sorting suggestions from CODING_STYLE. Since pretty much every file needs our string manipulation functions this effectively means that most files have sorted #include blocks now. Also touches a few unrelated include files.
* journal: fix bad memory freeingLennart Poettering2015-10-191-3/+0
|
* journal: rework vacuuming logicLennart Poettering2015-10-021-38/+60
| | | | | | | | | | | | | | | Implement a maximum limit on number of journal files to keep around. Enforcing a limit is useful on this since our performance when viewing pays a heavy penalty for each journal file to interleve. This setting is turned on now by default, and set to 100. Also, actully implement what 348ced909724a1331b85d57aede80a102a00e428 promised: use whatever we find on disk at startup as lower bound on how much disk space we can use. That commit introduced some provisions to implement this, but actually never did. This also adds "journalctl --vacuum-files=" to vacuum files on disk by their number explicitly.
* journal: don't affect atime of journal files when vacuumingLennart Poettering2015-10-021-3/+7
| | | | | | Let's try to use O_NOATIME if we can when vacuuming old journal files, if we have the permissions for it, so that vacuuming doesn't count as proper journal read access.
* journal: port over to fd_getcrtime_at()Lennart Poettering2015-10-021-12/+4
| | | | | Let's use fd_getcrtime_at(), since that *at() family of calls is how we read the rest of the file metadata, too.
* tree-wide: do not use _cleanup_free_ on const pointersDaniel Mack2015-07-241-1/+1
| | | | | | free() cannot be used with const pointers. However, our _cleanup_free_ handler features cast logic that hides that qualifier, so we don't get a warning.
* fix gcc warnings about uninitialized variablesHarald Hoyer2015-03-271-1/+1
| | | | | | | | | | | | | like: src/shared/install.c: In function ‘unit_file_lookup_state’: src/shared/install.c:1861:16: warning: ‘r’ may be used uninitialized in this function [-Wmaybe-uninitialized] return r < 0 ? r : state; ^ src/shared/install.c:1796:13: note: ‘r’ was declared here int r; ^
* remove unused includesThomas Hindoe Paaboel Andersen2015-02-231-3/+0
| | | | | | This patch removes includes that are not used. The removals were found with include-what-you-use which checks if any of the symbols from a header is in use.
* util: make creation time xattr logic more genericLennart Poettering2014-12-241-6/+3
|
* treewide: use log_*_errno whenever %m is in the format stringMichal Schmidt2014-11-281-2/+2
| | | | | | | | | | | If the format string contains %m, clearly errno must have a meaningful value, so we might as well use log_*_errno to have ERRNO= logged. Using: find . -name '*.[ch]' | xargs sed -r -i -e \ 's/log_(debug|info|notice|warning|error|emergency)\((".*%m.*")/log_\1_errno(errno, \2/' Plus some whitespace, linewrap, and indent adjustments.
* journald: fix memory leak on error pathLennart Poettering2014-11-031-1/+5
|
* journald: also check journal file size to deduce if it is emptyLennart Poettering2014-11-031-7/+15
|
* journalctl: add new --vacuum-size= and --vacuum-time= commands to clean up ↵Lennart Poettering2014-11-031-9/+8
| | | | | | | journal files based on a size/time limit This is equivalent to the effect of SystemMaxUse= and RetentionSec=, however can be invoked directly instead of implicitly.
* time-util: add and use USEC/NSEC_INFINIYKay Sievers2014-07-291-3/+3
|
* journald: invoking fstatvfs() is now redundant in the vacuuming codeLennart Poettering2014-06-271-7/+0
|
* build-sys: use glibc's xattr support instead of requiring libattrKay Sievers2014-05-281-9/+1
|
* journal: downgrade vaccuum message to debug levelLennart Poettering2014-02-231-1/+1
| | | | https://bugzilla.redhat.com/show_bug.cgi?id=1047148
* journald: do not free space when disk space runs lowZbigniew Jędrzejewski-Szmek2014-01-111-4/+2
| | | | | | | | | | | | | | | | | | | | | | | | | Before, journald would remove journal files until both MaxUse= and KeepFree= settings would be satisfied. The first one depends (if set automatically) on the size of the file system and is constant. But the second one depends on current use of the file system, and a spike in disk usage would cause journald to delete journal files, trying to reach usage which would leave 15% of the disk free. This behaviour is surprising for the user who doesn't expect his logs to be purged when disk usage goes above 85%, which on a large disk could be some gigabytes from being full. In addition attempting to keep 15% free provides an attack vector where filling the disk sufficiently disposes of almost all logs. Instead, obey KeepFree= only as a limit on adding additional files. When replacing old files with new, ignore KeepFree=. This means that if journal disk usage reached some high point that at some later point start to violate the KeepFree= constraint, journald will not add files to go above this point, but it will stay (slightly) below it. When journald is restarted, it forgets the previous maximum usage value, and sets the limit based on the current usage, so if disk remains to be filled, journald might use one journal-file-size less on each restart, if restarts happen just after rotation. This seems like a reasonable compromise between implementation complexity and robustness.
* journal/vacuum: replace readdir_r with readdirFlorian Weimer2013-12-211-5/+4
|
* Never call qsort on potentially NULL arraysZbigniew Jędrzejewski-Szmek2013-10-131-2/+1
| | | | | | This extends 62678ded 'efi: never call qsort on potentially NULL arrays' to all other places where qsort is used and it is not obvious that the count is non-zero.
* journald: fix minor memory leakLennart Poettering2013-10-091-0/+2
|
* journald: be a bit more verbose when vacuumingZbigniew Jędrzejewski-Szmek2013-09-101-6/+14
| | | | | | | | Vacuuming behaviour is a bit confusing, and/or we have some bugs, so those additional messages should help to find out what's going on. Also, rotation of journal files shouldn't be happening too often, so the level of the messages is bumped to info, so that they'll be logged under normal operation.
* journald: fix fd leak in journal_file_emptyGeorge McCollister2013-09-061-1/+2
| | | | | | | | | | | Before my previous patch, journal_file_empty wasn't be called with the correct filename. Now that it's being called with the correct filename it leaks file descriptors. This patch closes the file descriptors before returning. Signed-off-by: George McCollister <george.mccollister@gmail.com> [Edit harald@redhat.com: make use of _cleanup_close_ instead]
* journald: fix vacuuming of archived journalsGeorge McCollister2013-09-061-5/+5
| | | | | | | | d_name is modified on line 227 so if the entire journal name is needed again p must be used. Before this change when journal_file_empty was called on archived journals it would always return with -2. Signed-off-by: George McCollister <george.mccollister@gmail.com>
* journald: always vacuum empty offline filesZbigniew Jędrzejewski-Szmek2013-06-241-0/+29
| | | | | | | | | | | | Corrupted empty files are relatively common. I think they are created when a coredump for a user who never logged anything before is attempted to be written, but the write does not succeed because the coredump is too big, but there are probably other ways to create those, especially if the machine crashes at the right time. Non-corrupted empty files can also happen, e.g. if a journal file is opened, but nothing is ever successfully written to it and it is rotated because of MaxFileSec=. Either way, each "empty" journal file costs around 3 MB, and there's little point in keeping them around.
* journal/vacuum: cleanupZbigniew Jędrzejewski-Szmek2013-06-241-19/+4
|
* Fix vacuum logic errorJan Alexander Steffens (heftig)2013-03-211-2/+2
| | | | | | | | | The vacuum code used to stop vacuuming after one deletion, even when max_use was still exceeded. Also make usage a uint64_t, as the code already pretends it is one. Signed-off-by: Jan Alexander Steffens (heftig) <jan.steffens@gmail.com>
* journal: fix potential integer overflowLennart Poettering2012-10-171-1/+7
|
* journal: implement time-based rotation/vacuumingLennart Poettering2012-10-161-5/+86
| | | | | This also enables time-based rotation (but not vacuuming) after 1month, so that not more one month of journal is lost at a time per vacuuming.
* util: define union dirent_storage and make use of it everywhereLennart Poettering2012-09-191-2/+3
| | | | | | Make sure to allocate enough space for readdir_r(). https://bugzilla.redhat.com/show_bug.cgi?id=858754
* journald: avoid logging to kmsg in the normal pathsLennart Poettering2012-09-061-1/+1
|
* journal: split up journal-file.cLennart Poettering2012-08-161-0/+230