On 09/10/2012, at 01:46, z...@mac.com wrote:

> For 2. Can you use a NSNotification to fire and forget an unlock event?

Not really. The server can't send the notification back to the client. There's 
a RESTful web service between the client and the database.


> But are you merely querying the database, or do you have a facility to send 
> messages back to the GUI?

I'm querying the database only. I still can have the client poll the app server 
with a fair interval, but this can create overhead as more clients are added. I 
don't like polling at all...


> If there are messages back so, you can set up a message relayer that can hold 
> the current messages from the server and choose how to or when to relay them.

It would require something else for the client-server communication, like the 
protocols Jens Alfke suggested. Or talking to the database server directly, 
with something like BaseTen (only for PostgreSQL). Or going low-level (e.g., 
libpq), which goes beyond my skills.


Since I am not a dev-wizard like you guys, I have to stick to simple things! ;) 
Also, keep in mind this is an in-house project, never meant to be a commercial 
product. We can deal with some problems in ways that would not be desirable in 
commercial software. But, since I'm a Mac user, I want things to be as perfect 
as they can be....


Cheers,
Flavio

> ------Original Message------
> From: Flavio Donadio
> To: Alex Zavatone
> Cc: Cocoa List
> Subject: Re: Core Data Multiuser
> Sent: Oct 8, 2012 11:54 PM
> 
> On 08/10/2012, at 17:56, Alex Zavatone wrote:
> 
>> Thank you Flavio.  Out of curiosity, did you encounter pessimistic vs. 
>> optimistic locking performance/data reliability issue in having many clients 
>> writing to potentially the same places at once?  If so, how did each of the 
>> candidate solutions answer the problem that this poses? 
>> 
>> The problem being "if there are multiple users potentially writing to the 
>> same place at once, locking records during each write is too slow, but if 
>> you don't do this, you end up with the potential of two (or more) people 
>> writing to a record at once".
>> 
>> An example of this in real life is if both of us try to book a ticket for 
>> the last seat on a plane at the same time.  
> 
> I don't think I'll have performance problems. I'll never have more than, say, 
> 20 users at any given time and these "race conditions" will be rare. The 
> database server can handle this easily, *in my case*. The real problem is in 
> the user interface.
> 
> The interface will be like in Address Book: the user opens a card/record for 
> viewing, but has to click an "Edit" button to make changes. If the record is 
> locked, the user will get an alert when he/she clicks the button. I need:
> 
> 1. A mechanism to avoid users opening records for editing and leaving them 
> open "forever" (timer?);
> 
> 2. Some kind of feedback for the users when a record is unlocked, without 
> having to refresh manually.
> 
> Ideas are very welcome.
> 
> 
> Cheers,
> Flavio

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
https://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to