Django community: Community blog posts RSS
This page, updated regularly, aggregates Community blog posts from the Django community.
-
Tutorial: My Fabric Presentation from RIRUG
Slides are up from my presentation during the June meeting of the RI Ruby Users Group!Fabric: A Capistrano AlternativeView more presentations from Panoptic Development, Inc.. -
Web App Security: Django and the OWASP Top 10
Security threat: Neutralized.At my company, Panoptic Development, we've built several applications for the healthcare industry. Since we often deal with sensitive patient medical data, web application security is a huge concern. Enter the OWASP Top 10, a collection of best practices for web application security.What's OWASP?From Wikipedia:The Open Web Application Security Project (OWASP) is an open-source application security project. The OWASP community includes corporations, educational organizations, and individuals from around the world. This community works to create freely-available articles, methodologies, documentation, tools, and technologies. What's the Top 10?From the OWASP Wiki:The OWASP Top Ten provides a powerful awareness document for web application security. The OWASP Top Ten represents a broad consensus about what the most critical web application security flaws are. Project members include a variety of security experts from around the world who have shared their expertise to produce this list. Versions of the 2007 were translated into English, French, Spanish, Japanese, Korean and Turkish and other languages. Translation efforts for the 2010 version are underway and they will be posted as they become available....As you help us spread the word, please emphasize:OWASP is reaching out to developers, not just the application security communityThe Top 10 is about managing risk, not just … -
Vídeo y diapositivas del taller de Introducción a Django
vasdf -
Beating Google With CouchDB, Celery and Whoosh (Part 7)
The key ingredients of our search engine are now in place, but we face a problem. We can download webpages and store them in CouchDB. We can rank them in order of importance and query them using Whoosh but the internet is big, really big! A single server doesn’t even come close to being able to hold all the information that you would want it to – Google has an estimated 900,000 servers. So how do we scale this the software we’ve written so far effectively? The reason I started writing this series was to investigate how well Celery’s integration with CouchDB works. This gives us an immediate win in terms of scaling as we don’t need to worry about a different backend, such as RabbitMQ. Celery itself is designed to scale so we can run celeryd daemons as many boxes as we like and the jobs will be divided amongst them. This means that our indexing and ranking processes will scale easily. CouchDB is not designed to scale across multiple machines, but there is some mature software, CouchDB-lounge that does just that. I won’t go into how to get set this up but fundamentally you set up a proxy … -
Speeding up a Django web site without touching the code
I’ve recently been tweaking my server setup for a Django 1.3 web site with the goal of making it a bit faster. Of course, there is a lot of speed to gain by improving e.g. the number of database queries needed to render a web page, but the server setup also has an effect on the web site performance. This is a log of my findings. All measurements have been done using the ab tool from Apache using the arguments -n 200 -c 20, which means that each case have been tested with 20 concurrent requests up to 200 requests in total. The tests was run from another machine than the web server, with around 45ms RTT to the server. This is not a scientific measurement, but good enough to let me quickly test my assumptions on what increases or decreases performance. The Django app isn’t particularly optimized in itself, so I don’t care much about the low number of requests per second (req/s) that it manages to process. The main point here is the relative improvement with each change to the server setup. The baseline setup is a Linode 1024 VPS (Referral link: I get USD 20 off my … -
Using dev_appserver with Python 2.7 on App Engine
Starting with SDK 1.6.0 the App Engine fully supports Python 2.7. This article originally described a workaround for getting Python 2.7 running on SDK 1.5.5. Now it only describes how to port your app.yaml and request handlers to Python 2.7. The following instructions work with any WSGI-compliant web framework. I'll explain how to use Python 2.7 with djangoappengine/Django-nonrel at the end of this post. Yes, Django-nonrel works with Python 2.7 on App Engine. This blog (All Buttons Pressed) is already running on Python 2.7 with threadsafe: yes. Let's start with a simple app.yaml for Python 2.5: application: yourappid version: 1 runtime: python api_version: 1 handlers: - url: /.* script: handler.py The handler.py file looks like this: from google.appengine.ext import webapp from google.appengine.ext.webapp.util import run_wsgi_app # This can be any WSGI handler. Here we just use webapp. application = webapp.WSGIApplication(...) def main(): run_wsgi_app(application) if __name__ == '__main__': main() In order to use Python 2.7 you have to change your app.yaml like this: application: yourappid version: 1 runtime: python27 api_version: 1 threadsafe: yes handlers: - url: /.* script: handler.application Here we've changed the runtime to python27, added threadsafe: yes and modified the last line (script) to point to the WSGI handler directly … -
Generar arxius xls amb Python I
Una de les coses que volia que l'aplicació de gestió de comunitat de propietaris que fem és la de tenir algun tipus de via per a poder exportar la informació introduïda. D'aquesta manera el client no està captiu i les seves dades són realment seves, però a més també volia que aquesta informació es presentàs de manera que també pogués ser útil. El format csv està prou bé, però és massa simple a l'hora de presentar les dades. Necessitava quelcom del format del qual fora prou potent per poder aplicar estils i format bàsic, i al mateix temps que no implicàs una despesa addicional per al client. Cercant, cercant vaig arribar a la llibreria xlwt. Aquesta llibreria permet crear fitxers en format xls (Excel) d'una manera prou senzilla i ràpida com per a ser just el que necessitàvem. El format es pot llegir tant mitjançant aplicacions privatives, que de d'aquí no recomanaré, o des d'aplicacions lliures com l'OpenOffice o LibreOffice. Per a qui vulgui saber-ho tot podeu fer una ullada al codi font, però si us conformau amb un poquet menys, podeu llegir-vos el tutorial. Si voleu anar per feina podeu seguir llegint i us ne faré cinc cèntims de … -
Announcing the Yipit Django Blog: Sharing Everything We’re Learning
Yipit has been using Django since its inception nearly two years ago. If it wasn’t for a modern web framework like Django, we probably wouldn’t exist. Two years and hundreds of thousands of users later, we’ve gotten deep into the core of Django and many of the contributed packages. Our goal now is to truly master Django. While one can learn a lot by doing, we tend to believe that you can learn even more by teaching what you’ve learned. Accordingly, we’re going to be spending significant time sharing what we’ve learned and are learning about using and scaling Django. Topics We Will Cover Some of the topics we will be regularly discussing on our new Yipit Django blog include: System configurations: Using Chef and Fabric to deploy our Github-hosted code to Ubuntu servers on Amazon ec2. Running Gunicorn as the application server. Database Migrations: South handling model changes and generating appropriate migrations. Data Storage: A combination of MySQL, Memcache, and MongoDB for storing our data Queueing Tasks: Celery for queueing asynchronous processes. Amazon’s SQS to manage the underlying queue. Templating: Inheritance and custom inclusion tags. Testing: Automated testing tools including Nose, Splinter, and Lettuce We hope that by sharing … -
(Dutch) Python/Django vacature in Utrecht
-
I want to solve the uploads problem
Making file uploads is a frequent, but yet to be solved properly task. I believe we can, and should, do better. For some time now we've been working on a web service which handles file uploads for you, my fellow web developer. -
Postgres and Django
Frank Wiles gave a great talk [Secrets of PostgreSQL Performance][SoPP] ## Don't do dumb things * Dedicate a single server to your database * Only fetch what you need ## Do smart things * cache everything * limit number of queries ## Tuning * shared\_buffers : 25% of available RAM * effective\_cache\_size : OS disk cache size * work_mem : in-memory sort size ### Less important * wal\_buffers : set to 16MB * checkpoint\_segments : at least 10 * maintenance\_work\_mem : 50MB for every GB of RAM Can also transactionally turn on grouping of transactions. ## Hardware * As much RAM as you can afford - fit whole db if you can. * Faster disks. - Disk speed is important - RAID5 is bad - RAID-1+0 is good - WAL on own disk → 4x write performance * CPU speed - unlikely to be the limiting factor. ## Other * use pg_bouncer to pool connections * use tablespaces to move tables/indexes onto other disks + ie, indexes on fastest disk + stuff that might run in background and hit only specific tables that are not used by other bits [SoPP]: http://blip.tv/djangocon/secrets-of-postgresql-performance-5572403?utm\_medium=twitter&utm\_source=twitterfeed -
I got lots of "Solid Django" book feedback
-
Разъяснения Рассела
В недавнем посте с интервью с Джанго-разработчиками меня попросили уточнить, что имел в виду Рассел Кит-Маги, говоря про WSGI и валидацию моделей. У меня и у самого эти два пункты вызывали недопонимание, поэтому я попросил его их разъяснить. Вот перевод его ответа: Так, первый пункт: WSGI на самом деле хорошо заточен под классическую задачу "показать целиком веб-страницу". Он был спроектирован как самый простой рабочий "наименьший общий делитель" — фактически Питоний вариант CGI. То есть он очень хорошо спроектирован для веба 1995 года, но не настолько хорошо для веба 2011, с его long polling'ом и другими вкусными push-технологиями и серверными плюшками, которые теперь используются повсеместно. Многие уже написали гораздо подробней и об этой проблеме, и о WSGI вообще: http://lucumr.pocoo.org/2011/7/27/the-pluggable-pipedream/ http://www.b-list.org/weblog/2009/aug/10/wsgi/ На самом деле, это не обязательно является проблемой самой Джанго — она использует WSGI всего лишь как API для общения с сервером. Можно использовать любой другой интерфейс, если он кем-то специфицирован. Например, Джанго поддерживает fcgi и mod_python — последний хоть и устарел, но показывает, что метод, который используется для запуска Джанго не зависит от Джанго, как библиотеки по обслуживанию веб-запросов. Я также должен заметить, что на WSGI тоже возможно реализовать long poll и другие push-технологии, просто это спецификация не обязательно лучше … -
Utilizar javascript o CSS en el admin de Django
Es realmente sencillo utilizar javascript o CSS propio en el sitio de administración de nuestro proyecto Django. Para ello podemos añadir en nuestros ModelAdmin los archivos JS o CSS que necesitemos utilizando la clase Media en los modelos de administración... -
Kiwi PyCon, DjangoCon US, and PyCodeConf Recap
I just got back from a long conference circuit, attending and speaking at PyCon Australia, Kiwi PyCon, DjangoCon US, and PyCodeConf. It was a ton of work, but it was a blast. I got to blog about PyCon Australia already, but then the time in between the other conferences was just a bit too hectic to blog. Kiwi PyCon 2011 I gave the opening keynote speech at Kiwi PyCon in Wellington, New Zealand. The talk was meant to be mildly provocative but in an inspiring, "go out and code" kind of way. Kiwi PyCon 2011 - Audrey Roy Keynote Speech View more presentations from Audrey Roy The Pythonistas of New Zealand are amazing. I met more Twisted devs than I've ever met in my life, attended tons of hardcore Python talks by women, and ones by men too, and learned all sorts of new things. I was also blown away by the hospitality of the conference organizers, particularly Tim McNamara and Richard Shea. After the conference, I spent a couple of days going around the countryside and southern island coastal towns with Danny. It was spectacular. DjangoCon US 2011 I co-presented the Django Package Thunderdome with Daniel Greenfeld. Here … -
any2any - flexible serialization / deserialization for Python and Django
Why on earth ? When doing web programming, we all the time have to pass data from one format to another, from one object to another, we serialize, we deserialize … For much of those problems, many cook their own stuff … a piece of code that does its thing, and which is usually not so flexible and therefore not re-usable. It ends-up being not very DRY ! Recently I was working on a project implying Django, ldap and a json API ; trying to stick libraries together and endlessly transforming the same data from/to different formats. I grew tired of writing similar-looking code for doing that. So I started gathering, factorizing, generalizing this code, and came up with any2any. NB: if at this point you think “Why on earth would I ever use that ?”, maybe you should first download this example, and play with it. It is a very simple Django project demonstrating, how you can customize the output format of your API with any2any. A primer for Cast any2any’s most important class is Cast. Basically, that’s the base class for building all your transformation operations. Defining a new cast is very simple : class MyCast(Cast): setting1 = … -
Taller de Introducción a Django el 17 octubre en Madrid
El próximo lunes día 17 de Ocubre realizaremos en Madrid un Taller de Introducción a Django de la mano de Betabeers. Está orientado a gente que quiere tener un primer contacto con el framework y que todavía no lo conoce mucho (o nada). Tenéis la información en la sección de formación y en el blog de de Betabeers... -
Ordenar una query por la longitud de un campo
A veces tenemos que hacer queries un poco especiales y necesitamos ayuda de SQL cuando el ORM de Django se nos queda pequeño. Aquí tenemos un ejemplo de cómo ordenar una query a la base de datos por la longitud de un campo... -
Django admin magic screenshots
-
Caktus 2012 Summer Internship Program
I'm excited to announce that Caktus is looking for candidates for our summer internship program. It is a 12 week paid position in our Carrboro, NC office. We're driving distance from UNC Chapel Hill, NC State Univeristy in Raleigh, and Duke in Durham, so students from all parts of the NC Research Triangle are welcome ... -
Caktus 2012 Summer Internship Program
I'm excited to announce that Caktus is looking for candidates for our summer internship program. It is a 12 week paid position in our Carrboro, NC office. We're driving distance from UNC Chapel Hill, NC State Univeristy in Raleigh, and Duke in Durham, so students from all parts of the NC Research Triangle are welcome ... -
Caktus 2012 Summer Internship Program
I'm excited to announce that Caktus is looking for candidates for our summer internship program. It is a 12 week paid position in our Carrboro, NC office. We're driving distance from UNC Chapel Hill, NC State Univeristy in Raleigh, and Duke in Durham, so students from all parts of the NC Research Triangle are welcome ... -
Load Testing with JMeter: Part 2 - Headless Testing and Jenkins Integration
If you read part 1 of my JMeter series, you now know how to create a JMeter performance test with as much complexity as you need to hit every part of your application and push it to its limits. As mentioned at the end of the post, though, when running your test plan from your local machine you are often limited by bandwidth. The test plan may not be able to fully stress your application because it can’t transfer data fast enough for all of your concurrent connections. To really push your application hard, you need to run your load test from the same local network that your application runs within. -
Cómo importar un archivo CSV (ó TSV) en un modelo de django
Mitch Fournier explica en su blog cómo importar datos en formato CSV a un modelo de Django, tal cómo lo ha utilizado en su proyecto Wantbox.com. Primero creamos un modelo que contenga los mismos campos que el archivo CSV que queramos importar, utilizando el tipo de campo más adecuado para cada uno de ellos dependiendo de si sus valores van a ser cadenas de texto, números, fechas... -
I'm writing a Django book