hosts.name as host,
shares.name as share,
backups.num as num,
- inc_size
+ inc_size,
+ parts
from backups
join shares on backups.hostid = shares.hostid
and shares.id = backups.shareid
$sth->execute();
-my $sth_inc_size = $dbh->prepare(qq{ update backups set inc_size = ? where id = ? });
+my $sth_inc_size = $dbh->prepare(qq{ update backups set inc_size = ?, parts = ? where id = ? });
my $sth_inc_deleted = $dbh->prepare(qq{ update backups set inc_deleted = ? where id = ? });
%BackupPC::SearchLib::Conf = %Conf;
# re-create archive?
if ($row->{'inc_size'} == -1 || $size == -1 || $row->{'inc_size'} != $size) {
- my $cmd = qq{$tarIncCreate -h "$row->{'host'}" -s "$row->{'share'}" -n $row->{'num'} | gzip -9 > $tar_dir/$tar_file};
+ my $cmd = qq{rm -Rf $tar_dir/$tar_file && $tarIncCreate -h "$row->{'host'}" -s "$row->{'share'}" -n $row->{'num'} | gzip -9 > $tar_dir/$tar_file};
print STDERR "## $cmd\n" if ($debug);
system($cmd) == 0 or die "failed: $?";
if ($size > 45) {
my $max_size = $Conf{'MaxArchiveSize'} || die "problem with MaxArchieSize parametar";
+ $max_size *= 1024; # convert to bytes
+
+ my $parts = int( ($size + $max_size - 1) / $max_size );
+
+ if (-d "$tar_dir/$tar_file" && $parts != $row->{'parts'}) {
+ print " join";
+
+ my $in = my $out = "$tar_dir/$tar_file";
+ $out .= '.tmp';
+
+ # FIXME I should really order parts manually!
+ system("cat $in/part* > $out && rm -Rf $in && mv $out $in") == 0 or die "can't join $in: $?";
+ }
if ($size > $max_size && ! -d "$tar_dir/$tar_file") {
- print " split";
+ print " split/$parts";
my $in = my $out = "$tar_dir/$tar_file";
$out .= '.tmp';
rename $in, $out || die "can't rename $in: $!";
mkdir $in || die "can't mkdir $in: $!";
- system("split -d -b $max_size $out $in/part") == 0 or die "can't split $out: $!";
+
+ my $suffix_len = length("$parts");
+ system("split -d -b $max_size -a $suffix_len $out $in/part") == 0 or die "can't split $out: $?";
unlink $out || die "can't unlink $out: $!";
}
- $sth_inc_size->execute($size, $row->{'backup_id'});
+ $sth_inc_size->execute($size, $parts, $row->{'backup_id'});
$sth_inc_deleted->execute(0, $row->{'backup_id'});
printf(" %1.2f MB", ($size / 1024 / 1024));
size bigint not null,
inc_size bigint not null default -1,
inc_deleted boolean default false,
+ parts integer not null default 1,
PRIMARY KEY(id)
);
create table archive_burned (
archive_id int references archive(id),
date date default now(),
- iso_size int default -1
+ iso_size bigint default -1
);
});