I'm interested in running Django on an async framework like Concurrence or gevent. Both frameworks come with its own async MySQL driver.
Problem is Django only officially supports MySQLdb. What do I need to do to make Django work with the MySQL drivers that come with gevent or Concurrence?
Is there a step-by-step guide somewhere that I can follow? Is this a major undertaking?
Thanks.
with a low latency database, MySQLdb is good enough even used with gevent. Though it is not patchable, it's possible to achieve good performance by reusing database connection and increasing the number of gevent workers. Database is heavy and generally you don't need to create thousands of concurrent connections to leverage its performance, and 1:1 ratio of worker to connection is not a very bad choice. But for memory cache it is totally another story.
three cheers for @traviscline's suggestion to go with pymysql. his suggestion was based on this post from mozilla. all it takes is a simple patch to your manage.py file
changing the import in your settings file, and monkeypatch() since pymysql is a pure python driver.
travis mentioned that he tests for compatability by changing the imports and running the unittests for pymysql, mysqldb, and myconnpy.
note that there are already examples of finer details to watch out for - but overall this is an elegant, maintainable solution. i will update when i get this running in production!
I was successful in getting pymysql to work with Django doing the following :
Add the following four lines to base.py
As mentioned in the link that egbutter posted, go to the base.py file and find-replace
MySQLdb
withpymysql
at relevant portions of the file, i.e. don't bother changing the error messages (you could, but that's up to you).Save base.py, and run the following command from the apt location to see the server start up.