<p dir="ltr">Excellent! A happy customer! :-)</p>
<p dir="ltr">/mrg<br>
</p>
<div class="gmail_quote">On Dec 16, 2015 23:43, "Jeff McCullough" <<a href="mailto:jeffmc@berkeley.edu">jeffmc@berkeley.edu</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word">Thank you. Splitting the queues was it. Both queues were processed in no time, 3 min, which is congruent with your experience. Both queues were emptied about the same time.<div><br></div><div>Jeff</div><div><br><div><blockquote type="cite"><div>On Dec 16, 2015, at 8:09 PM, Michael Gettes <<a href="mailto:gettes@gmail.com" target="_blank">gettes@gmail.com</a>> wrote:</div><br><div><p dir="ltr">+10000</p><p dir="ltr">And please don't get hung up on the notion of running an additional queue and processor is expensive. It isn't! Just do it. :-)</p><p dir="ltr">/mrg<br>
</p>
<div class="gmail_quote">On Dec 16, 2015 22:16, "Jeffrey Eaton via Identity-services-gap" <<a href="mailto:identity-services-gap@lists.andrew.cmu.edu" target="_blank">identity-services-gap@lists.andrew.cmu.edu</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I would strongly recommend splitting the isMemberOf and group member entries into two different ActiveMQ queues, and running two parallel copies of the GAP code - one against each queue. The group member queue will run much faster because the gap process can look ahead in the queue to batch up multiple changes to the same group object. The isMemberOf queue will still be slower, but should not be unreasonably so.<br>
<br>
-jeaton<br>
<br>
<br>
> On Dec 16, 2015, at 9:43 PM, Jeff McCullough via Identity-services-gap <<a href="mailto:identity-services-gap@lists.andrew.cmu.edu" target="_blank">identity-services-gap@lists.andrew.cmu.edu</a>> wrote:<br>
><br>
> Hi Michael,<br>
><br>
> Okay. Some new data. An old email you wrote:<br>
><br>
>> Folks - we have been running with this code in production. This matches up with prior email about getting large groups into LDAP very quickly. We see it taking about 5 min to create a group of 25,000 members (for static group objects) if conditions are right. LDAP is no longer the limiting factor but how fast one gets the data out of grouper is now the issue. of course, performing 25000 mods for isMemberOf takes longer but group objects and isMemberOf are separate processes.<br>
><br>
> I just added 17k members to a group. It took about 50 min to finish. The amq queue (includes addmember and addIsMemberOf entries) was being processed around 24 / sec to begin and around 5 / sec by the end. The limiting factor seems to be the group searches to determine if the member already exists. As the group grows the searches take longer. Alternately, doing a full sync on a group is very, very fast because the entries are batched. There may still be something we can optimize, but just want to get some clarity on your data. When you say you created a group of 25k members in 5 min, that it would need to be the fullSync batching style rather than individual adds as I saw in the logs?<br>
><br>
> Thanks,<br>
> Jeff<br>
><br>
<br>
_______________________________________________<br>
Identity-services-gap mailing list<br>
<a href="mailto:Identity-services-gap@lists.andrew.cmu.edu" target="_blank">Identity-services-gap@lists.andrew.cmu.edu</a><br>
<a href="https://lists.andrew.cmu.edu/mailman/listinfo/identity-services-gap" rel="noreferrer" target="_blank">https://lists.andrew.cmu.edu/mailman/listinfo/identity-services-gap</a><br>
</blockquote></div>
</div></blockquote></div><br></div></div></blockquote></div>