]> git.proxmox.com Git - proxmox-backup.git/commitdiff
fix #2871: close FDs when scanning backup group
authorFabian Grünbichler <f.gruenbichler@proxmox.com>
Tue, 21 Jul 2020 13:03:36 +0000 (15:03 +0200)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Wed, 22 Jul 2020 07:19:29 +0000 (09:19 +0200)
otherwise we leak those descriptors and run into EMFILE when a backup
group contains many snapshots.

fcntl::openat and Dir::openat are not the same ;)

Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
src/backup/backup_info.rs

index 352d81e40417e8b7ab0c8254f3f5132aad799d3f..f8ea11bd7148e1b3a31ec32273bf33fd546a3e99 100644 (file)
@@ -106,7 +106,11 @@ impl BackupGroup {
 
             use nix::fcntl::{openat, OFlag};
             match openat(l2_fd, &manifest_path, OFlag::O_RDONLY, nix::sys::stat::Mode::empty()) {
-                Ok(_) => { /* manifest exists --> assume backup was successful */ },
+                Ok(rawfd) => {
+                    /* manifest exists --> assume backup was successful */
+                    /* close else this leaks! */
+                    nix::unistd::close(rawfd)?;
+                },
                 Err(nix::Error::Sys(nix::errno::Errno::ENOENT)) => { return Ok(()); }
                 Err(err) => {
                     bail!("last_successful_backup: unexpected error - {}", err);