On 31 Aug 2013, at 13:47, Stéphane Ducasse <stephane.duca...@inria.fr> wrote:

> Sabine 
> what we could do is to propose a "subclass of UUID" and to group several UUID 
> generators.
> Like that with a couple of classes, we could get a better eco system where 
> people can pick the one they want.
> 
> stef

I just made my own, called NeoUUIDGenerator, 
http://www.smalltalkhub.com/#!/~SvenVanCaekenberghe/Neo/packages/Neo-UUID

@Sabine

IMHO what I think a local counter does not, is give you uniques over different 
machines, images, instances - that is why there is also the concept of node 
identification.

In my implementation I combine the millisecond clock, a small random number, a 
counter and a node id. The node id is based on several elements, it should be 
different when running multiple images.

This is a hack, not something that I can prove mathematically. But it can't be 
worse than pure random. I think the speed is also acceptable:

| generator |
generator := NeoUUIDGenerator new.
[ generator next ] bench. '408,000 per second.'

| generator |
generator := UUIDGenerator new.
[ generator generateBytes: UUID nilUUID forVersion: 4 ] bench. '13,300 per 
second.'

Sven

> On Aug 31, 2013, at 11:49 AM, Sabine Knöfel <sabine.knoe...@gmail.com> wrote:
> 
>> Hi Esteban,
>> 
>> yes, Mongo is not very communicative ;-)
>> 
>> I replaced OID>>nextOID  with my own RKAOIDGenerator 
>> 
>> nextOID
>>      ^self value: (RKAOIDGenerator getNextOID)
>> 
>> instead of
>> 
>> nextOID
>>      ^self value: (UUIDGenerator default makeSeed)
>> 
>> 
>> RKAOIDGenerator uses Time>>primMillisecondClock at startup and adds +1 each 
>> time I getNextOID as you suggested.
>> 
>> This works fine. It seems to be much much much faster than the existing 
>> solution.
>> 
>> [4000 timesRepeat: [UUIDGenerator default makeSeed]] timeToRun    ==>> 5817
>> [4000 timesRepeat: [RKAOIDGenerator getNextOID]] timeToRun     ==> 1 (!!)
>> 
>> Perhaps a solution like this would be a better solution for all because it 
>> is faster and guarantees unique IDs?
>> 
>> Sabine
>> 
>> 
>> 
>> 
>> 
>> On Fri, Aug 30, 2013 at 5:58 PM, EstebanLM [via Smalltalk] <[hidden email]> 
>> wrote:
>> Hi, 
>> 
>> One idea (not sure if it will work) 
>> 
>> You can take 
>> 
>> Time primUTCMicrosecondsClock 
>> 
>> when system start, then increase it sequentially. 
>> most probably that will ensure uniqueness while providing fast ids. 
>> 
>> but of course, that depends, you need to check in your system. 
>> 
>> I'm thinking on provide different ID generators for Voyage, and let people 
>> plug what is more convenient for them. 
>> 
>> (all of this happens because, unlike other db drivers, mongo does not answer 
>> the inserted id :( ) 
>> 
>> Esteban 
>> 
>> On Aug 30, 2013, at 5:41 PM, Sabine Knöfel <[hidden email]> wrote: 
>> 
>> > So, I will wait and till then, use the solution of Jan. 
>> > Thank you, Jan for the file in. 
>> > Sabine 
>> > 
>> > 
>> > 
>> > -- 
>> > View this message in context: 
>> > http://forum.world.st/voyage-mongo-randomly-wrong-OIDs-tp4705396p4705821.html
>> 
>> > Sent from the Pharo Smalltalk Users mailing list archive at Nabble.com. 
>> >
>> 
>> 
>> 
>> 
>> If you reply to this email, your message will be added to the discussion 
>> below:
>> http://forum.world.st/voyage-mongo-randomly-wrong-OIDs-tp4705396p4705827.html
>> To unsubscribe from voyage/mongo randomly wrong OIDs, click here.
>> NAML
>> 
>> 
>> View this message in context: Re: voyage/mongo randomly wrong OIDs
>> Sent from the Pharo Smalltalk Users mailing list archive at Nabble.com.
> 


Reply via email to