Reputation: 52318
I was wondering about implementing my own sessions (more for an exercise than anything else) for a GAE app I'm working ... at first I was thinking of using the datastore to store the session data. However, every time something needs to be added to the session 'bucket', it would require saving to the datastore. Obviously that's bad since we want to minimize our writes. Then I thought about using memcache ... seemed like a good idea but then we're faced with issues of possible session corruption due to memcache being "evicted through memory pressure" by Google. So does that mean we are left with only the following options:
Anyone have any other ideas?
Upvotes: 12
Views: 7780
Reputation: 17732
I suggest checking out (and contributing to) these three implementations of appengine sessions before rolling out your own:
Your options look fine but choosing between them probably depends on the size of the session data in your application.
Upvotes: 3
Reputation: 4427
UPDATE - 21 Mar 2011
At the time of this answer app-engine-patch is discontinued and gaeutilities offer worst features than gae-sessions.
Upvotes: 5
Reputation: 2775
If you use web2py (version 1.46 or latter) sessions are on by default on GAE. This achieved by the following three lines of web2py code at the top of the scaffoling model:
from gluon.contrib.gql import *
db=GQLDB()
session.connect(request,response,db=db)
Here is a sample action that counts:
def index():
session.c=session.c+1 if session.c else 1
return dict(counter=session.c)
Upvotes: 0