8 |
use BackupPC::View; |
use BackupPC::View; |
9 |
use Data::Dumper; |
use Data::Dumper; |
10 |
use Time::HiRes qw/time/; |
use Time::HiRes qw/time/; |
|
use File::Pid; |
|
11 |
use POSIX qw/strftime/; |
use POSIX qw/strftime/; |
12 |
use BackupPC::SearchLib; |
use BackupPC::SearchLib; |
13 |
use Cwd qw/abs_path/; |
use Cwd qw/abs_path/; |
63 |
backups.id as backup_id, |
backups.id as backup_id, |
64 |
hosts.name as host, |
hosts.name as host, |
65 |
shares.name as share, |
shares.name as share, |
66 |
backups.num as num |
backups.num as num, |
67 |
|
inc_size |
68 |
from backups |
from backups |
69 |
join shares on backups.hostid = shares.hostid |
join shares on backups.hostid = shares.hostid |
70 |
and shares.id = backups.shareid |
and shares.id = backups.shareid |
71 |
join hosts on shares.hostid = hosts.id |
join hosts on shares.hostid = hosts.id |
72 |
where inc_size < 0 and not inc_deleted |
where not inc_deleted |
73 |
order by backups.date |
order by backups.date |
74 |
|
|
75 |
} ); |
} ); |
83 |
|
|
84 |
while (my $row = $sth->fetchrow_hashref) { |
while (my $row = $sth->fetchrow_hashref) { |
85 |
my $tar_file = BackupPC::SearchLib::getGzipName($row->{'host'}, $row->{'share'}, $row->{'num'}); |
my $tar_file = BackupPC::SearchLib::getGzipName($row->{'host'}, $row->{'share'}, $row->{'num'}); |
|
print curr_time, sprintf(" %s:%s %-3d ", $row->{'host'}, $row->{'share'}, $row->{'num'}), " -> $tar_file "; |
|
86 |
|
|
87 |
my $t = time(); |
# this will return -1 if file doesn't exist |
88 |
|
my $size = BackupPC::SearchLib::get_tgz_size_by_name($tar_file); |
89 |
|
|
90 |
my $cmd = qq{$tarIncCreate -h "$row->{'host'}" -s "$row->{'share'}" -n $row->{'num'} | gzip -9 > $tar_dir/$tar_file}; |
print curr_time, " ", $row->{'host'}, ":", $row->{'share'}, " #", $row->{'num'}, " -> $tar_file"; |
|
print STDERR "## $cmd\n" if ($debug); |
|
91 |
|
|
92 |
system($cmd) == 0 or die "failed: $?"; |
my $t = time(); |
93 |
|
|
94 |
my $size = (stat( "$tar_dir/$tar_file" ))[7]; |
# re-create archive? |
95 |
|
if ($row->{'inc_size'} == -1 || $size == -1 || $row->{'inc_size'} != $size) { |
96 |
|
my $cmd = qq{$tarIncCreate -h "$row->{'host'}" -s "$row->{'share'}" -n $row->{'num'} | gzip -9 > $tar_dir/$tar_file}; |
97 |
|
print STDERR "## $cmd\n" if ($debug); |
98 |
|
|
99 |
print " dur: ",fmt_time(time() - $t)," $size bytes"; |
system($cmd) == 0 or die "failed: $?"; |
100 |
|
|
101 |
|
$size = (stat( "$tar_dir/$tar_file" ))[7]; |
102 |
|
} |
103 |
|
|
104 |
if ($size > 45) { |
if ($size > 45) { |
105 |
|
|
106 |
|
my $max_size = $Conf{'MaxArchiveSize'} || die "problem with MaxArchieSize parametar"; |
107 |
|
|
108 |
|
if ($size > $max_size && ! -d "$tar_dir/$tar_file") { |
109 |
|
print " split"; |
110 |
|
my $in = my $out = "$tar_dir/$tar_file"; |
111 |
|
$out .= '.tmp'; |
112 |
|
rename $in, $out || die "can't rename $in: $!"; |
113 |
|
mkdir $in || die "can't mkdir $in: $!"; |
114 |
|
system("split -d -b $max_size $out $in/part") == 0 or die "can't split $out: $!"; |
115 |
|
unlink $out || die "can't unlink $out: $!"; |
116 |
|
} |
117 |
|
|
118 |
$sth_inc_size->execute($size, $row->{'backup_id'}); |
$sth_inc_size->execute($size, $row->{'backup_id'}); |
119 |
$sth_inc_deleted->execute(0, $row->{'backup_id'}); |
$sth_inc_deleted->execute(0, $row->{'backup_id'}); |
120 |
|
|
121 |
|
printf(" %1.2f MB", ($size / 1024 / 1024)); |
122 |
|
|
123 |
} else { |
} else { |
124 |
$sth_inc_deleted->execute(1, $row->{'backup_id'}); |
$sth_inc_deleted->execute(1, $row->{'backup_id'}); |
125 |
unlink "$tar_dir/$tar_file" || die "can't delete $tar_dir/$tar_file: $!\n"; |
unlink "$tar_dir/$tar_file" || die "can't delete $tar_dir/$tar_file: $!\n"; |
126 |
print " EMPTY"; |
print " EMPTY"; |
127 |
} |
} |
128 |
print "\n"; |
print ", dur: ",fmt_time(time() - $t), "\n"; |
129 |
|
|
130 |
$dbh->commit; |
$dbh->commit; |
131 |
|
|