diff options
author | ivan <ivan> | 2011-03-15 21:26:02 +0000 |
---|---|---|
committer | ivan <ivan> | 2011-03-15 21:26:02 +0000 |
commit | 5af9611527ddcda51c778eabcabed8516b414614 (patch) | |
tree | af887fa24fa5de0bac62a81c69b7f1a2914ddd5b | |
parent | 90c85ed3e1baaf7eed459cc9d5bd587d5b90b3bc (diff) |
recover better from mysql's deadlock stupidity, grr, RT#10574
-rw-r--r-- | FS/bin/freeside-torrus-srvderive | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/FS/bin/freeside-torrus-srvderive b/FS/bin/freeside-torrus-srvderive index b4113b714..0441c4704 100644 --- a/FS/bin/freeside-torrus-srvderive +++ b/FS/bin/freeside-torrus-srvderive @@ -55,7 +55,7 @@ my $sql = " my $orderlimit = " ORDER BY srv_date, srv_time - LIMIT 100 + LIMIT 50 "; @@ -130,7 +130,12 @@ while (1) { if $DEBUG > 2; my $isth = dbh->prepare($isql) or die $DBI::errstr; #better recovery? - $isth->execute( @param ) or die $isth->errstr; + + #stupid mysql deadlocks all the time here, so we need to recover + $isth->execute( @param ) or do { + warn "Error inserting data for $serviceid$dir (restarting): ". + $isth->errstr; + } } |