Look at idea behind this: http://code.djangoproject.com/wiki/CookBookThreadlocalsAndUser
On Feb 14, 6:40 pm, Amit Ramon <[EMAIL PROTECTED]> wrote: > Hello, > > I'm developing a site that need to display ads. The ad to display on a page > is selected by a function based on the value of a global state - an > application state that need to be maintained across requests and different > users. In other words, the state is a "website singleton". > > This state is read and changed on every request. One trivial way to achive > this is to store the state in the database, but I'm afraid that changing the > value in the database with every request might create a performance > bottleneck (I'm using MySql, don't know if it matters). > > I thought about having a global (plain python) variable to store the state. > However, there are some points to think about, especially since I'm not sure > how FastCGI works: > 1. Is there single process that handles all the requests? (so it can keep > state) > 2. If so, are different requests handles by separate threads? If this is > true, then I probably need to make this state variable thread-safe. > 3. How long does the FastCGI process (or the relevant application process) > lives? I don't mind reseting the state from time to time, but not too often. > > The ad selection mechanism is somewhat probabilstic - ads should be displayed > more or less randomly (with some uniform or weighted distribution), so > another option I'm thinking of is using python's random() function to select > an ad. That way I won't have to maintian state explicitly, although a state > would be maintained by python for the random number generator. This also > raises some questions: again, to make this work well there need to be a > single server process, the random number generator (or its state) need to be > global. > > I hope this is not too long, and clear enough. I would appreciate any ideas. > > Thanks, > > Amit Ramon --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---