Google App Engine First Impressions
For those of you that have been hiding under a rock for the last 12 hours, App Engine is Google’s answer to Amazon Web Services. While it is less flexible in some senses (you don’t have a complete OS at your disposal), it does provide tighter integration for web applications and even includes a (somewhat crippled) version of Django out of the box.
I’m pretty excited about this mainly because I’m not a big fan of server administration, so I took a couple hours this morning to test it out. Here are some quick notes:
The Good
- It sort of works with Django
- Deployment is dead simple
- It handles user accounts and registration
- Every app gets a built in Admin Console with stats, version management and datastore CRUD capability
- You can add your own Python libraries
- And, of course, it will scale on the fly
The Bad
- Datastore is not a relational database
This excludes you from using models or anything that depends on them in Django, including the admin, sessions, the authorization framework. - Only pure Python libraries can be used and some libraries are disabled
The Ugly
- YAML configuration files
- Admin CRUD interface is no match for Django’s, see screenshots below.
Other Observations
- Much of the API is clearly influenced by Django making transitioning easier.
- Pricing has not been released, but from this statement, it appears they will have free accounts:
“For now, account registrations are limited to the first 10,000 developers, and applications are restricted to the free account limits.” - Generic views don’t work with the datastore queries ‘Query’ object has no attribute ‘_clone’
- The datastore admin interface only becomes active once you have saved an object for the model.
Screenshots
Adding an item to the Datastore

Conclusion
Despite its limitations, I think App Engine is going to be a great thing for the Django community and I can’t wait to host my apps there.
I started migrating my site over (lincolnloop1.appspot.com) with some quick hacks, but realized that creating a Django database backend for the App Engine Datastore (a.k.a. BigTable) is going to be the best route. I’m not a database guru and I haven’t dug into Django’s database internals, but it looks feasible. The basic stuff is so close to Django that I’m hoping it will be pretty straightforward and we should be able to emulate more advanced queries with some Python magic. I’m happy to open up an app and I started a Google Code project django-appengine-backend for any developers that are interested in working on the project.
Comments
Comments are closed for this post.
Our Products
Categories
- accessiblity
- code
- company news
- django
- gondola
- open source
- portfolio
- presentation
- pro tip
- review
- screencast
- seo
- software
- subversion
- trailmapping
- wordpress
Archives
- February, 2010
- December, 2009
- November, 2009
- October, 2009
- September, 2009
- June, 2009
- April, 2009
- February, 2009
Elsewhere
What we’ve been up to online
-
pushed to master at lincolnloop/django-redmine
Pete, 9 hours, 18 minutes ago -
pushed to master at lincolnloop/django-redmine
Pete, 9 hours, 21 minutes ago -
pushed to master at lincolnloop/django-redmine
Pete, 15 hours, 38 minutes ago -
pushed to master at lincolnloop/django-redmine
Pete, 17 hours, 39 minutes ago -
added cmheisel to django-redmine
Pete, 18 hours, 13 minutes ago -
started following cmheisel
Pete, 18 hours, 14 minutes ago -
created branch master at lincolnloop/django-redmine
Pete, 18 hours, 31 minutes ago -
created repository redpiston
Pete, 18 hours, 31 minutes ago -
Best benefit of a distributed company: "You can hire great people wherever you find them" http://bit.ly/cWint6
Pete, 22 hours, 36 minutes ago -
5 reasons why your company should be distributed « toni.org
Best benefit of a distributed company: "You can hire great people wherever you find them"
Pete, 22 hours, 56 minutes ago -
Great article about the new smart if tag on Django Advent by Lincoln Loop's very own Chris Beaven (aka SmileyChris). http://bit.ly/bDUpH9
Pete, 2 weeks, 1 day ago -
pushed to master at lincolnloop/django-startproject
Pete, 3 weeks ago -
pushed to master at lincolnloop/django-startproject
Pete, 3 weeks ago -
pushed to master at lincolnloop/django-render
Pete, 3 weeks ago -
created branch master at lincolnloop/django-render
Pete, 3 weeks ago





Hi,
Seems you’re using the DEBUG=True into your settings to lincolnloop1.appspot.com. Clue : http://lincolnloop1.appspot.com/blog/
Anyway, thanks for sharing your feelings about GAppEngine, with screenshots ! I’ve got a closer look to how the admin seems to be designed.
One thing that I also hate with google app engine is, it doesnt have a very good site admin. I wish that django will fully support google app engine platform in the future so that we dont need to use google app engine’s specific database api. Everything should be done by the framework under the hood