Using Django and MongoDB to Build a Blog
How Python and Django Communicate with MongoDB
You will need a Python module called PyMongo to talk to MongoDB from Python. On a Debian 7 system, you can install it as follows:
# apt-get install python-pymongo Reading package lists... Done Building dependency tree Reading state information... Done The following extra packages will be installed: python-bson python-bson-ext python-gridfs python-pymongo-ext The following NEW packages will be installed: python-bson python-bson-ext python-gridfs python-pymongo ↪python-pymongo-ext 0 upgraded, 5 newly installed, 0 to remove and 0 not upgraded. Need to get 212 kB of archives. After this operation, 928 kB of additional disk space will be used. Do you want to continue [Y/n]?
The following instructional Python code (saved as connect.py) connects to a MongoDB database, prints the available databases of the mongodb://localhost:27017 server and closes the MongoDB connection:
import pymongo # Open the MongoDB connection connMongo = pymongo.Connection('mongodb://localhost:27017') # Print the available MongoDB databases print connMongo.database_names() # Close the MongoDB connection connMongo.close()
You can run the small Python script as follows:
$ python connect.py [u'LJ', u'local', u'test']
The output shows that at the time of running the script, three databases exist called LJ, local and test. Although PyMongo will not be used directly in the rest of the article, it is useful to know about it for testing and troubleshooting purposes.
Generally speaking, Django has a wrapper for every relational database it supports, but Mongo is a non-relational database, so you need some external help. You need the MongoEngine Python package in order to utilize MongoDB. Other options are Ming, MongoKit, django-mongodb and django-nonrel. In my opinion, MongoEngine is the best option.
MongoEngine is an object-document mapper made for MongoDB, following Django's ORM style. You can install it by executing this command:
# apt-get install python-mongoengine
MongoEngine is based on PyMongo, and that's why you need to know some basic things about PyMongo.
For those of you who are familiar with Django, you should know that when
you are using MongoEngine, you lose both the Django Admin panel and the
python manage.py syncdb command. Losing the Django Admin panel is a
major drawback, but MongoDB offers features that relational databases cannot
Imagine you registered a new domain to host your personal site. The site also will have a blog. Instead of using a CMS, such as Joomla! or WordPress, for creating the blog, you want more control over the site, so you decide to use Django for creating the blog and MongoDB for storing the blog data.
The nice thing about this solution is that if you already are familiar with Django, it will not take more than two hours to develop, test and deliver a complete version of the blog site.
Note: the solution presented here tries to be as Django-native as possible. The only thing different from the usual Django way is the use of MongoDB.
If you try to access a MongoDB that does not already exist, MongoDB will create it. The same happens if you try to write to a MongoDB collection (table) that does not exist. So, you do not need to execute any commands on MongoDB, but you should be very careful not to have any typos in your code.
Do the following steps on Django.
1) Create a new project called LJ:
$ django-admin.py startproject LJ $ cd LJ
The manage.py script is created for every Django project and is a wrapper around django-admin.py. You do not need to make any changes to it.
2) Run the test development Web server to see if everything is okay:
$ python manage.py runserver
By going to http://localhost:8000/ (or http://127.0.0.1:8000/), you will see Figure 2.
Figure 2. The Test Development Web Server
The test development server restarts automatically every time you make changes to the Django project.
3) Create the app for the blog called LJblog:
$ python manage.py startapp LJblog
With all the industry talk about the benefits of Linux on Power and all the performance advantages offered by its open architecture, you may be considering a move in that direction. If you are thinking about analytics, big data and cloud computing, you would be right to evaluate Power. The idea of using commodity x86 hardware and replacing it every three years is an outdated cost model. It doesn’t consider the total cost of ownership, and it doesn’t consider the advantage of real processing power, high-availability and multithreading like a demon.
This ebook takes a look at some of the practical applications of the Linux on Power platform and ways you might bring all the performance power of this open architecture to bear for your organization. There are no smoke and mirrors here—just hard, cold, empirical evidence provided by independent sources. I also consider some innovative ways Linux on Power will be used in the future.Get the Guide
- SUSE LLC's SUSE Manager
- Tech Tip: Really Simple HTTP Server with Python
- Managing Linux Using Puppet
- My +1 Sword of Productivity
- Murat Yener and Onur Dundar's Expert Android Studio (Wrox)
- Non-Linux FOSS: Caffeine!
- Returning Values from Bash Functions
- Rogue Wave Software's Zend Server
- Doing for User Space What We Did for Kernel Space
- Parsing an RSS News Feed with a Bash Script