close DBI_PWD or warn "close DBI_pwd: $!";
chomp $DBI_pwd;
-my $DBI=DBI->connect_cached("DBI:mysql:database=$DBI_database;host=","$DBI_user",$DBI_pwd,{
+my $DBI;
+sub DBI
+{
+ return $DBI if $DBI;
+ $DBI=DBI->connect("DBI:mysql:database=$DBI_database;host=","$DBI_user",$DBI_pwd,{
"PrintError"=>0, # handled by "RaiseError" below
"RaiseError"=>1,
"ShowErrorStatement"=>1,
"AutoCommit"=>1,
}) or confess "Failed DBI->connect(): $!";
+ return $DBI;
+}
# $name,@$cols
sub create_table
{
my($name,$cols)=@_;
- eval { $DBI->do("drop table $name"); };
- $DBI->do("create table $name (".join(",",@$cols).")");
+ eval { DBI()->do("drop table $name"); };
+ DBI()->do("create table $name (".join(",",@$cols).")");
}
sub initdb
"retries int null default 0", # null=>done, 0=not yet tried to submit
],
);
- $DBI->do("alter table $DB_table add index (retries,id)");
+ DBI()->do("alter table $DB_table add index (retries,id)");
print "done.\n";
exit 0;
}
"message"=>$message,
# assume "retries"=>0,
);
- my $prep=$DBI->prepare_cached("insert into $DB_table (".join(",",keys(%row)).")"
+ my $prep=DBI()->prepare("insert into $DB_table (".join(",",keys(%row)).")"
." values (".join(",",map("?",keys(%row))).")");
$prep->execute(values(%row));
print $prep->{"mysql_insertid"}."\n";
{
my $pid=fork();
confess if !defined $pid;
+ $DBI=undef(); # Prevent: Server has gone away
exit 0 if $pid; # parent
# child
}
print "LOCKED\n";
exit 0;
}
- my $sth=$DBI->prepare("select id,message from $DB_table where retries is not null"
+ my $sth=DBI()->prepare("select id,message from $DB_table where retries is not null"
# process only non-problematic mails during rerun
.($submitonce_run==1 ? "" : " and retries=0")
." order by retries asc,id asc");
autoflush STDOUT 1;
my $sock;
while (my $row=$sth->fetchrow_hashref()) {
- $DBI->do("update $DB_table set retries=retries+1 where id=".$row->{"id"});
+ DBI()->do("update $DB_table set retries=retries+1 where id=".$row->{"id"});
if (!$sock) {
$sock=IO::Socket::INET->new(
"PeerAddr"=>$PeerAddr,
undef $sock;
}
else {
- $DBI->do("update $DB_table set retries=null where id=".$row->{"id"});
+ DBI()->do("update $DB_table set retries=null where id=".$row->{"id"});
}
print $progresschar.$row->{"id"}.($got eq "1" ? "" : "=FAIL");
$progresschar=",";
{
my($cond)=@_;
- my $sth=$DBI->prepare("select message from $DB_table $cond order by id");
+ my $sth=DBI()->prepare("select message from $DB_table $cond order by id");
$sth->execute();
while (my $row=$sth->fetchrow_hashref()) {
print $row->{"message"},"\n";
my($keyword,$interval)=@_;
# FIXME: SQL "now()" is raced against the block above
- my $sth=$DBI->prepare("select id,time,retries from $DB_table where time>now()");
+ my $sth=DBI()->prepare("select id,time,retries from $DB_table where time>now()");
$sth->execute();
while (my $row=$sth->fetchrow_hashref()) {
warn "Message time in future: ".join(",",map(
my $sec=0;
$sec+=$1 while s/(\d+)s//g;
die "Interval parse error; left \"$_\", parsed: $interval" if $_ ne "";
- $sth=$DBI->prepare(($print ? "select id" : "delete")
+ $sth=DBI()->prepare(($print ? "select id" : "delete")
." from $DB_table where retries is null and time<from_unixtime(unix_timestamp()-$sec)");
$sth->execute();
if (!$print) {