summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTim Laszlo <tim.laszlo@gmail.com>2010-07-26 15:30:51 +0000
committerSol Jerome <sol.jerome@gmail.com>2010-07-30 11:53:15 -0500
commit368f9c770c0eadc8a4cf4b54255ee8d51b55c95b (patch)
tree0dd911f42bea05304dd13a1b3d430aa3b1a6d07d
parentbf3fe01ce7c139e1afe8b6addc8cd4c6c819c4a9 (diff)
downloadbcfg2-368f9c770c0eadc8a4cf4b54255ee8d51b55c95b.tar.gz
bcfg2-368f9c770c0eadc8a4cf4b54255ee8d51b55c95b.tar.bz2
bcfg2-368f9c770c0eadc8a4cf4b54255ee8d51b55c95b.zip
DBStats: Fix random mysql errors
Occasionally importing ping data would fail with "Commands out of sync; you can't run this command now". Improved logging and error handling for imports. Fixed indentation error in GetCurrentEntry git-svn-id: https://svn.mcs.anl.gov/repos/bcfg/trunk/bcfg2@5992 ce84e21b-d406-0410-9b95-82705330c041
-rw-r--r--src/lib/Server/Plugins/DBStats.py21
-rwxr-xr-xsrc/lib/Server/Reports/importscript.py23
2 files changed, 26 insertions, 18 deletions
diff --git a/src/lib/Server/Plugins/DBStats.py b/src/lib/Server/Plugins/DBStats.py
index fe357fc40..2712cd45f 100644
--- a/src/lib/Server/Plugins/DBStats.py
+++ b/src/lib/Server/Plugins/DBStats.py
@@ -5,6 +5,11 @@ import lxml.etree
import platform
import time
+try:
+ from django.core.exceptions import MultipleObjectsReturned
+except ImportError:
+ pass
+
import Bcfg2.Server.Plugin
import Bcfg2.Server.Reports.importscript
from Bcfg2.Server.Reports.reports.models import Client
@@ -53,15 +58,19 @@ class DBStats(Bcfg2.Server.Plugin.Plugin,
logger,
True,
platform.node())
+ logger.info("Imported data for %s in %s seconds" \
+ % (metadata.hostname, time.time() - start))
+ return
+ except MultipleObjectsReturned, e:
+ logger.error("DBStats: MultipleObjectsReturned while handling %s: %s" % \
+ (metadata.hostname, e))
+ logger.error("DBStats: Data is inconsistent")
break
except:
logger.error("DBStats: Failed to write to db (lock); retrying",
exc_info=1)
- if i == 3:
- logger.error("DBStats: Retry limit failed; aborting operation")
- return
- logger.info("Imported data in the reason fast path in %s second" \
- % (time.time() - start))
+ logger.error("DBStats: Retry limit failed for %s; aborting operation" \
+ % metadata.hostname)
def GetExtra(self, client):
c_inst = Client.objects.filter(name=client)[0]
@@ -95,7 +104,7 @@ class DBStats(Bcfg2.Server.Plugin.Plugin,
entry.reason.current_diff.split('\n'), 1)))
elif entry.reason.is_binary:
# If len is zero the object was too large to store
- raise Bcfg2.Server.Plugin.PluginExecutionError
+ raise Bcfg2.Server.Plugin.PluginExecutionError
else:
ret.append(None)
return ret
diff --git a/src/lib/Server/Reports/importscript.py b/src/lib/Server/Reports/importscript.py
index 016098cc8..cdfd8079c 100755
--- a/src/lib/Server/Reports/importscript.py
+++ b/src/lib/Server/Reports/importscript.py
@@ -63,12 +63,9 @@ def build_reason_kwargs(r_ent):
def load_stats(cdata, sdata, vlevel, logger, quick=False, location=''):
- cursor = connection.cursor()
clients = {}
[clients.__setitem__(c.name, c) \
for c in Client.objects.all()]
- #[clients.__setitem__(c['name'], c['id']) \
- # for c in Client.objects.values('name', 'id')]
pingability = {}
[pingability.__setitem__(n.get('name'), n.get('pingable', default='N')) \
@@ -169,16 +166,18 @@ def load_stats(cdata, sdata, vlevel, logger, quick=False, location=''):
for key in pingability.keys():
if key not in clients:
- #print "Ping Save Problem with client %s" % name
continue
- pmatch = Ping.objects.filter(client=clients[key]).order_by('-endtime')
- if pmatch and pmatch[0].status == pingability[key]:
- pmatch[0].endtime = datetime.now()
- pmatch[0].save()
- else:
- Ping(client=clients[key], status=pingability[key],
- starttime=datetime.now(),
- endtime=datetime.now()).save()
+ try:
+ pmatch = Ping.objects.filter(client=clients[key]).order_by('-endtime')[0]
+ if pmatch.status == pingability[key]:
+ pmatch.endtime = datetime.now()
+ pmatch.save()
+ continue
+ except IndexError:
+ pass
+ Ping(client=clients[key], status=pingability[key],
+ starttime=datetime.now(),
+ endtime=datetime.now()).save()
if vlevel > 1:
logger.info("---------------PINGDATA SYNCED---------------------")