zoukankan      html  css  js  c++  java
  • Django中MySQL读写分离技术

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

    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

  • 相关阅读:
    UVALive
    训练指南 UVA
    训练指南 UVALive
    Codeforces Round #535 (Div. 3)
    训练指南 UVALive
    训练指南 UVALive
    Codeforces Round #534 (Div. 2)
    Codeforces Round #532 (Div. 2)
    《算法问题实战策略》——chaper9——动态规划法技巧
    《训练指南》——8.3
  • 原文地址:https://www.cnblogs.com/linkenpark/p/7607675.html
Copyright © 2011-2022 走看看