码迷,mamicode.com
首页 > 数据库 > 详细

Django中MySQL读写分离技术

时间:2016-02-13 15:50:11      阅读:472      评论:0      收藏:0      [点我收藏+]

标签:python django

最近需要用到Django的MySQL读写分离技术,查了一些资料,把方法整理了下来。

在Django里实现对MySQL的读写分离,实际上就是将不同的读写请求按一定的规则路由到不同的数据库上(可以是不同类型的数据库),我们需要做的就是,定义不同的数据库,定义不同的路由规则。

 

首先定义我们的主从数据库:

DATABASES = {

    ‘default‘: {

        ‘ENGINE‘: ‘django.db.backends.mysql‘,

        ‘NAME‘: sae.const.MYSQL_DB,

        ‘USER‘: sae.const.MYSQL_USER,

        ‘PASSWORD‘: sae.const.MYSQL_PASS,

        ‘HOST‘: sae.const.MYSQL_HOST,

        ‘PORT‘: sae.const.MYSQL_PORT,

    },

      

    ‘slave‘: {

        ‘ENGINE‘: ‘django.db.backends.mysql‘,

        ‘NAME‘: sae.const.MYSQL_DB,

        ‘USER‘: sae.const.MYSQL_USER,

        ‘PASSWORD‘: sae.const.MYSQL_PASS,

        ‘HOST‘: sae.const.MYSQL_HOST_S,

        ‘PORT‘: sae.const.MYSQL_PORT,

    },       

}

 

定义我们的路由规则,路由规则可以有好多个,每个规则是一个类。如下所示:

# -*- coding:utf-8 -*-

 

class DBRouter(object):

    

    def db_for_read(self, model, **hints):

        return ‘slave‘

 

    def db_for_write(self, model, **hints):

        return ‘default‘

 

    def allow_relation(self, obj1, obj2, **hints):

        return None

 

    def allow_syncdb(self, db, model):

        return None

 

最后在setting.py中加上这个路由规则:

DATABASE_ROUTERS = [‘opensound.models.DBRouter‘]

 

因为Django不负责主从数据库之间的同步,所以如果在读取完数据后马上要对数据进行操作,可以显式地使用主数据库来读取并修改数据。

 

>>> Author.objects.using(‘other‘).all()

>>> my_object.save(using=‘legacy_users‘)

参考资料:https://docs.djangoproject.com/en/dev/topics/db/multi-db/

http://www.truease.com/thread-262-1-1.html


本文出自 “我的运维时光” 博客,请务必保留此出处http://aaronsa.blog.51cto.com/5157083/1741768

Django中MySQL读写分离技术

标签:python django

原文地址:http://aaronsa.blog.51cto.com/5157083/1741768

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!