Django中MySQL读写分离技术

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django中MySQL读写分离技术相关的知识,希望对你有一定的参考价值。

最近需要用到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读写分离技术的主要内容,如果未能解决你的问题,请参考以下文章

docker部署django项目mysql主从搭建django实现读写分离

django+centos+mariadb读写分离完美实现(上)-mysql主从备份实现

Django配置数据库读写分离

配置 Django 实现数据库读写分离

Zend Framework中如何实现MySQL的读写分离 - PHP框架开发

MySQL主从复制技术与读写分离技术amoeba应用