<html><head><style type="text/css"><!-- DIV {margin:0px;} --></style></head><body><div style="font-family:times new roman, new york, times, serif;font-size:12pt"><div>I sent this to the list but it gets bounced because I attached the code in a zip file.&nbsp; How do I send code through without checking it in because it is still orthogonal to the codebase?<br><br>Michael<br>----<br><br>Well, I have code that works for multi-threading infrastructure so I
would like to know if it is worth continuing with this or not.<br><br>As for ROLLUP/CUBE my thoughts are:<br>1)
Either we keep the codebase simple by sticking to a standard (SQL2003)
even if this standard is not yet implemented widely and certain
databases have better special features than others, or we allow a
per-database SQL generation system.&nbsp; The argument for the second makes
sense only if the developer resources to write and maintain each
dialect comes from the database vendor or their community.&nbsp; Mondrian is
probably at a stage that such discussions can be undertaken with the
database vendors.<br>2) Architecturally this implies loading multiple
Aggregations from one SQL query.&nbsp; That requires a rethink of the way
the cell cache loading is done because at the moment an Aggregation is
loaded one at a time and in a synchronized block on the Aggregation.&nbsp;
Similar concerns have to be dealt with for in-memory rollups.&nbsp; I think
that synchronized is too forceful.&nbsp; We need something more like a Lock
from java.util.concurrent so we can do tryLock().&nbsp; Look at the TxLock
idea I have in the code I'm attaching.<br><br>As for multi-threading:<br>I
have only written most of the base infrastructure, not the cell
loading.&nbsp; To integrate would require a significant amount of work in
Mondrian's code to pass all interaction with Mondrian through
TxSystem.runWithTx().&nbsp; <br><br>Basic concerns are:<br>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">1)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">Threads should be able to share data
 related to the request across the threads.</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">2)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">A
Thread should be loaned to a request and returned in a way that is
well-nigh fail-safe (i.e. the thread shouldn’t keep running of the
request fails in some way).</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">3)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">We should be able in a parameter of some sort decide to NOT use threads at all.</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">4)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">The number of threads should be configurable.</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">5)<span style="font-style: normal;
 font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">There should be an independence from the rest of the code base.</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">6)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch: normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">We should be able to make use of custom thread pools or use managed thread pools from the application server.</span></div>  <div class="MsoNormal" style="margin-left: 36pt; text-indent: -18pt;"><span style=""><span style="">7)<span style="font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal; font-size-adjust: none; font-stretch:
 normal;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span style="">Then there is a relatively minor issue with read-consistency for near-real-time data that turns out to be a real head-ache.<span style="">&nbsp; </span>This can be done by either: using the transaction semantics of the underlying data store <u>or</u> modifying all SQL requests and cache interactions with a timestamp and/or transaction id of some sort.<span style="">&nbsp; </span>E.g.
when an MDX requests begins it asks the underlying data store for the
id of the last completed transaction that modified data and keeps this
in a request-scope available to all threads.<span style="">&nbsp; </span>Then it appends “changedTxId &lt;= ${lastTxIdWhenFirstEntered}” to each WHERE clause.<span style="">&nbsp; </span>If however we use the underlying data store’s transactions then we must keep open the JDBC Connection for
 the duration of the request reusing it on the same thread for each interaction with that data store.</span></div>    <div class="MsoNormal"><span style="">Now,
I think that the best way to take advantage of multiple threads in the
storage system is NOT launching multiple SQLs on the same star schema
but different aggregations but rather to use <u>partitioning</u> of data.<span style="">&nbsp; </span>That is to segment the cell data (and maybe dimension data) based on values of certain columns.<span style="">&nbsp; </span>For example year&lt;2007 and year=2007 in<span style="">&nbsp; </span>two different partitions.<span style="">&nbsp; </span>This can be introduced slowly by simply making a RolapStar one Partition for the moment.<span style="">&nbsp; </span>Having said that aggregation tables are also a type of Partition and hitting two of them at once should be quite easy.</span></div>  So the design I am introducing has the following features:<br>1)
A scope for "request" or "interaction" that is larger than the Thread
that begins it.&nbsp; Since this is similar to a transaction I've called it
a Tx.&nbsp; See the mondrian.tx package.&nbsp; Each sub-system in Mondrian can
enlist a representation of itself in the Tx.<br>2)
Break up the different tasks performed into Task objects that can be
run potentially in parallel.&nbsp; Allow a set of Tasks to be tied to the
same Thread so that the same JDBC Connection can be used for all of
them for read-consistency and cleaned up at the end of the Tx.&nbsp; This is
done declaratively so the implementation can be changed easily.&nbsp; The
implementation can also ensure that the J2EE context is passed onto
separate threads (JNDI, context class loader etc).<br>3) A system of fail-quick locks at the Tx scope rather than just Thread scope.&nbsp; <br><br>If this is worth persuing as a design for the next version then good.&nbsp; If not I'll stop now.<br><br>Michael</div></div><br>
                <hr size="1"> 
Découvrez une nouvelle façon d'obtenir des réponses à toutes vos questions ! 
Profitez des connaissances, des opinions et des expériences des internautes sur <a href="http://fr.rd.yahoo.com/evt=42054/*http://fr.answers.yahoo.com">Yahoo! Questions/Réponses</a>.</body></html>