Charles

This user hasn't shared any biographical information


Posts by Charles

Why you should be using VirtualEnv

One of the more annoying things when writing any code is when libraries change. Either deprecating functions, or changing how you expect functions to be handled. In some languages and platforms this isn’t a very large issue, libraries made by large companies seldom change. But now, so many libraries are community driven, updates are happening almost daily. New releases are happening monthly in some cases.

 

There is a solution, VirtualEnv allows you to create an environment for python and all its libraries. This environment is separate from the rest of your system libraries, anything installed is only accessible from within the environment. I am planning on writing a few articles related to VirtualEnv, everything from setting it up, using it, and deploying a website using django with it.

 

Installing VirtualEnv is fairly simple, I am assuming that you already have easy_install installed.


sudo easy_install virtualenv

 

Once easy_install has done its thing, and virtualenv is installed there’s really only 2 main commands you will want to familiarize yourself with. The first command is used for creating a environment, making sure to use distribute (–distribute) for installing new packages and telling virtualenv to not use the systems already installed packages (–no-site-packages). Finally at then end will be the path (full or relative) to the project location.


virtualenv --no-site-packages --distribute ./project/

cd ./project/

 

Now that your environment is setup, all there is to do is enter the environment, this is easily accomplished


source bin/activate

 

From here you will notice that your prompt has changed, adding the project name at the start, anything you install from here is now installed on your environment and will only be accessible from with in. Installing new packages is easily accomplished using the PIP installer.


pip install django

 

To access your environment all you must do is execute a deactivate command anywhere from within the shell


deactivate

 

Although this might seem like a bit more work then your standard work flow, the benefits severely outweigh the extra work involved. The entire environment is portable, meaning you can dump a list of all libraries (including versions) to a file which allows anyone to completely build your environment on there computer without requiring you to upload the entire set of libraries to them. I will cover this later in the series, stay tuned.

 

Times are changing

It has been almost a full year since my last post, in that short time much has changed. My previous place of work has decided to pull their offices out of town leaving myself and many others behind. Many sought refuge in a few larger businesses in town and seem to be enjoying it. A few have ventured out into smaller local companies, bringing with them there knowledge and expertise. In January I decided I would do something I have always wanted to do, I incorporated Nullobject and started working on contracts and whatever work I could find in an effort to build up some money into the company as well as keep my bills payed.

 

I have decided that I want to keep a record of some of the stuff I am working on, as well as continue to help people learn in all areas. I plan on posting articles on things as I did before, problems I tackle and solve, solution to problems people have, as well as the usual rants and opinions. I am hoping that I will learn more by teaching others and others will learn as well. So anyone that can bare my horrible writing and want to learn new stuff together, are welcome to join me. I plan on keeping updates frequent and with substance.

Django: Sending mail with Templates

It’s interesting how only a few lines of code can save so much work. A few days ago, I was working on adding a new feature to a system I wrote a while ago using django. I noticed there were a few places that I wanted to send out an email along with logging. I started looking into Django’s ability to send out emails, after much searching I found the mail_admins function. I wasn’t a huge fan of having the email content buried in the code. I did a few quick searches on the documentation and came up with no real solutions. Using Django’s render_to_response as an example I created a function that would allow me to send an email using a Django template.


from django.template import loader
from django.core.mail import mail_admins

def render_to_email(template, subject, context):
    template = loader.render_to_string(template,  context)
    mail_admins(subject, template)

The function works exactly like Django’s render_to_response function, with one added value to the function for setting the email’s subject


render_to_email('email_general_error.html', 'General Error', { 'request': request, 'message': message})

Website Image Caching

In a previous post titled Django Json Woes I mentioned setting response headers for caching for Json responses. This was done to make sure that data that was sent was always refreshed and the browser didn’t use cached content. Most times this is accomplished with a technique called “cachebuster”, which means adding a pseudo random string to your request. This is done because your web browser, performs caching on your content based on urls including any parameters that are passed. By adding a random string onto the URL, your tricking your browser into thinking its a totally different URL and the browser will bypass the cache and download it.

I personally am not a huge fan of using the “cachebuster” because deciding if something should be cached or not should be decided on by the site and less by the connection to the site for 90% of requests.

This kind of cache bypassing can be useful when trying to get a bit more performance from a image heavy website. By hosting your images with a cache set to essentially never expire, and having your website pass “cachebuster” type information at the end.


 <img src="/images/background.jpg?1273456709" >

The data at the end of the image url could be anything that indicates that the image has changed. When a request comes in the first time the browser would download the image based on the given url, each time afterwards it would continue to use the cache image. When you modify or change the image the data on the url would change and any hit from cached browsers would see the change and download the new copy of the image.

I am currently working on a template command for django that can do this easily, once its completed ill update this post.