Hi Guys,<div><br></div><div>I also implemented something w/ JSR 223 - <a href="https://github.com/saturnism/infinispan/tree/jsr223-mr/core/src/main/java/org/infinispan/distexec/mapreduce">https://github.com/saturnism/infinispan/tree/jsr223-mr/core/src/main/java/org/infinispan/distexec/mapreduce</a></div>
<div><br></div><div>With tests that uses scripts like this:</div><div><a href="https://github.com/saturnism/infinispan/tree/jsr223-mr/core/src/test/resources/mapreduce">https://github.com/saturnism/infinispan/tree/jsr223-mr/core/src/test/resources/mapreduce</a><br>
<br><div class="gmail_quote">On Mon, Jan 28, 2013 at 6:53 AM, Ales Justin <span dir="ltr">&lt;<a href="mailto:ales.justin@gmail.com" target="_blank">ales.justin@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">&gt; M/R classes do have access to the cache so they can get a hold of the app&#39;s class loader.  But the tricky part is that the M/R tasks themselves need to be loaded from that class loader first…<br>
<br>
</div>This already seems to work -- as we use tasks extensively in CapeDwarf,<br>
and it seems to work OK; note: CapeDwarf runs in both ways - modular and embedded<br>
<span class="HOEnZb"><font color="#888888"><br>
-Ales<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
&gt; On 28 Jan 2013, at 14:01, Ales Justin &lt;<a href="mailto:ales.justin@gmail.com">ales.justin@gmail.com</a>&gt; wrote:<br>
&gt;<br>
&gt;&gt;&gt; Ales - how could we bundle something like this as an AS module and play nice with modular class loading there?<br>
&gt;&gt;<br>
&gt;&gt; Well, I would say we&#39;re back to that discussion with AdvancedCache::withClassloader. :-)<br>
&gt;&gt; Same thing with M/R -- can it tap into app&#39;s CL?<br>
&gt;&gt; Otherwise TCCL should do, in JEE env.<br>
&gt;&gt;<br>
&gt;&gt; Or perhaps some init(Cache cache) on M/R classes, where it can get a hold of Cache,<br>
&gt;&gt; which would then expose app&#39; CL, via AC::withClassloader?<br>
&gt;&gt;<br>
&gt;&gt; -Ales<br>
&gt;&gt;<br>
&gt;&gt;&gt; On 26 Jan 2013, at 21:55, Ales Justin &lt;<a href="mailto:ales.justin@gmail.com">ales.justin@gmail.com</a>&gt; wrote:<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; Would the thread context classloader be the right thing to use?<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; It depends how Infinispan&#39;s M/R code handles setting of TCCL.<br>
&gt;&gt;&gt;&gt; Specially in remote invocations.<br>
&gt;&gt;&gt;&gt; But I would expect it to work.<br>
&gt;&gt;&gt;&gt; Not the best, but good enough. :-)<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; Or, perhaps it can use ScriptEngine?<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; What&#39;s ScriptEngine?<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; -Ales<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt;&gt; infinispan-dev mailing list<br>
&gt;&gt;&gt;&gt; <a href="mailto:infinispan-dev@lists.jboss.org">infinispan-dev@lists.jboss.org</a><br>
&gt;&gt;&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/infinispan-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/infinispan-dev</a><br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; --<br>
&gt;&gt;&gt; Manik Surtani<br>
&gt;&gt;&gt; <a href="mailto:manik@jboss.org">manik@jboss.org</a><br>
&gt;&gt;&gt; <a href="http://twitter.com/maniksurtani" target="_blank">twitter.com/maniksurtani</a><br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Platform Architect, JBoss Data Grid<br>
&gt;&gt;&gt; <a href="http://red.ht/data-grid" target="_blank">http://red.ht/data-grid</a><br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt; infinispan-dev mailing list<br>
&gt;&gt;&gt; <a href="mailto:infinispan-dev@lists.jboss.org">infinispan-dev@lists.jboss.org</a><br>
&gt;&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/infinispan-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/infinispan-dev</a><br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; _______________________________________________<br>
&gt;&gt; infinispan-dev mailing list<br>
&gt;&gt; <a href="mailto:infinispan-dev@lists.jboss.org">infinispan-dev@lists.jboss.org</a><br>
&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/infinispan-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/infinispan-dev</a><br>
&gt;<br>
&gt; --<br>
&gt; Manik Surtani<br>
&gt; <a href="mailto:manik@jboss.org">manik@jboss.org</a><br>
&gt; <a href="http://twitter.com/maniksurtani" target="_blank">twitter.com/maniksurtani</a><br>
&gt;<br>
&gt; Platform Architect, JBoss Data Grid<br>
&gt; <a href="http://red.ht/data-grid" target="_blank">http://red.ht/data-grid</a><br>
&gt;<br>
&gt;<br>
&gt; _______________________________________________<br>
&gt; infinispan-dev mailing list<br>
&gt; <a href="mailto:infinispan-dev@lists.jboss.org">infinispan-dev@lists.jboss.org</a><br>
&gt; <a href="https://lists.jboss.org/mailman/listinfo/infinispan-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/infinispan-dev</a><br>
<br>
<br>
_______________________________________________<br>
infinispan-dev mailing list<br>
<a href="mailto:infinispan-dev@lists.jboss.org">infinispan-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/infinispan-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/infinispan-dev</a><br>
</div></div></blockquote></div><br></div>