Commit 0471cbd6 authored by Hanno Schlichting's avatar Hanno Schlichting

Actually nest the queryplan on the catalog id as well

parent a370d541
...@@ -883,15 +883,18 @@ class ZCatalog(Folder, Persistent, Implicit): ...@@ -883,15 +883,18 @@ class ZCatalog(Folder, Persistent, Implicit):
security.declareProtected(manage_zcatalog_entries, 'getCatalogPlan') security.declareProtected(manage_zcatalog_entries, 'getCatalogPlan')
def getCatalogPlan(self): def getCatalogPlan(self):
"""Get a string representation of a query plan""" """Get a string representation of a query plan"""
plan = PriorityMap.get_plan() pmap = PriorityMap.get_value()
output = [] output = []
output.append('# query plan dumped at %r\n' % time.asctime()) output.append('# query plan dumped at %r\n' % time.asctime())
output.append('queryplan = {') output.append('queryplan = {')
for querykey, details in sorted(plan.items()): for cid, plan in sorted(pmap.items()):
output.append(' %s: {' % repr(querykey)) output.append(' %s: {' % repr(cid))
for indexname, benchmark in sorted(details.items()): for querykey, details in sorted(plan.items()):
tuplebench = repr(tuple(benchmark)) output.append(' %s: {' % repr(querykey))
output.append(' %r:\n %s,' % (indexname, tuplebench)) for indexname, benchmark in sorted(details.items()):
tuplebench = repr(tuple(benchmark))
output.append(' %r:\n %s,' % (indexname, tuplebench))
output.append(' },')
output.append(' },') output.append(' },')
output.append('}') output.append('}')
return '\n'.join(output) return '\n'.join(output)
......
...@@ -35,59 +35,8 @@ Report = namedtuple('Report', ['hits', 'duration', 'last']) ...@@ -35,59 +35,8 @@ Report = namedtuple('Report', ['hits', 'duration', 'last'])
logger = getLogger('Products.ZCatalog') logger = getLogger('Products.ZCatalog')
class PriorityMap(object): class NestedDict(object):
"""This holds a query key to Benchmark mapping.""" """Holds a structure of two nested dicts."""
lock = allocate_lock()
value = {}
@classmethod
def get_plan(cls):
return cls.value.copy()
@classmethod
def get(cls, key):
return cls.value.get(key, None)
@classmethod
def set(cls, key, value):
with cls.lock:
cls.value[key] = value
@classmethod
def clear(cls):
with cls.lock:
cls.value = {}
@classmethod
def load_default(cls):
location = environ.get('ZCATALOGQUERYPLAN')
if location:
try:
pmap = resolve(location)
logger.info('loaded priority %d map(s) from %s',
len(pmap), location)
# Convert simple benchmark tuples to namedtuples
new_plan = {}
for querykey, details in pmap.items():
new_plan[querykey] = {}
for indexname, benchmark in details.items():
new_plan[querykey][indexname] = Benchmark(*benchmark)
with cls.lock:
cls.value = new_plan
except ImportError:
logger.warning('could not load priority map from %s', location)
class Reports(object):
"""This holds a structure of nested dicts.
The outer dict is a mapping of catalog id to reports. The inner dict holds
a query key to Report mapping.
"""
lock = allocate_lock()
value = {}
@classmethod @classmethod
def get(cls, key): def get(cls, key):
...@@ -127,6 +76,54 @@ class Reports(object): ...@@ -127,6 +76,54 @@ class Reports(object):
cls.set(key, {}) cls.set(key, {})
class PriorityMap(NestedDict):
"""This holds a structure of nested dicts.
The outer dict is a mapping of catalog id to plans. The inner dict holds
a query key to Benchmark mapping.
"""
lock = allocate_lock()
value = {}
@classmethod
def get_value(cls):
return cls.value.copy()
@classmethod
def load_default(cls):
location = environ.get('ZCATALOGQUERYPLAN')
if location:
try:
pmap = resolve(location)
logger.info('loaded priority %d map(s) from %s',
len(pmap), location)
# Convert the simple benchmark tuples to namedtuples
new_plan = {}
for cid, plan in pmap.items():
new_plan[cid] = {}
for querykey, details in plan.items():
new_plan[cid][querykey] = {}
for indexname, benchmark in details.items():
new_plan[cid][querykey][indexname] = \
Benchmark(*benchmark)
with cls.lock:
cls.value = new_plan
except ImportError:
logger.warning('could not load priority map from %s', location)
class Reports(NestedDict):
"""This holds a structure of nested dicts.
The outer dict is a mapping of catalog id to reports. The inner dict holds
a query key to Report mapping.
"""
lock = allocate_lock()
value = {}
class ValueIndexes(object): class ValueIndexes(object):
"""Holds a set of index names considered to have an uneven value """Holds a set of index names considered to have an uneven value
distribution. distribution.
...@@ -239,7 +236,7 @@ class CatalogPlan(object): ...@@ -239,7 +236,7 @@ class CatalogPlan(object):
self.duration = None self.duration = None
def plan(self): def plan(self):
benchmark = PriorityMap.get(self.key) benchmark = PriorityMap.get_entry(self.cid, self.key)
if not benchmark: if not benchmark:
return None return None
...@@ -290,7 +287,7 @@ class CatalogPlan(object): ...@@ -290,7 +287,7 @@ class CatalogPlan(object):
def stop(self): def stop(self):
self.end_time = time.time() self.end_time = time.time()
self.duration = self.end_time - self.start_time self.duration = self.end_time - self.start_time
PriorityMap.set(self.key, self.benchmark) PriorityMap.set_entry(self.cid, self.key, self.benchmark)
self.log() self.log()
def log(self): def log(self):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment