Django 副本数据保存到多个数据库

wil*_*eam 3 database django django-rest-framework

根据 django 文档,可以从数据库创建副本并定义它将写入或读取的位置。(django 多数据库)。

然后,它为其编写了代码,配置我的DATABASE喜欢:

DATABASES = {
    'default': {
        'NAME': 'my_write_database',
        'ENGINE': 'django.db.backends.mysql',
        'USER': 'mysql_user',
        'PASSWORD': 'writedatabase',
    },
    'replica': {
        'NAME': 'replica',
        'ENGINE': 'django.db.backends.mysql',
        'USER': 'mysql_user',
        'PASSWORD': 'readdatabase',
    },
}
Run Code Online (Sandbox Code Playgroud)

并创建路由器:

class ReplicaDatabaseWriteRead(object):

    route_app_labels = {..all_possible_applications}

    def db_for_read(self, model, **hints):
        return 'replica' # O just wanna read from 'replica'

    def db_for_write(self, model, **hints):
        if model._meta.app_label in self.route_app_labels:
            return 'default' # I wanna write in default and 'reflect' to 'replica'
        return None

    def allow_relation(self, obj1, obj2, **hints):
        db_list = (..all_possible_apps)
        if obj1._state.db in db_list and obj2._state.db in db_list:
            return True
        return None

    def allow_migrate(self, db, app_label, model_name=None, **hints):
        return True
Run Code Online (Sandbox Code Playgroud)

但这不能正常工作。当我写入时,它只是写入default,并没有反映到replica。然后,当我读取 时replica,值不存在。

他不应该写在 中default并复制 中的值吗replica?我正在使用 django-rest-framework 这段代码与文档非常相似,我不知道出了什么问题。或者我不明白django文档?

Ole*_*kin 7

Django 并没有为你解决复制问题。

复制的常用方法-一个数据库用于写入多个副本用于读取。复制是在数据库级别(不是 django)完成的,即数据库配置为写入其事务日志,读取副本同步该日志并重播它。

Django多数据库配置允许指定不同的数据库 URL 进行读取和写入,和/或为不同的应用程序甚至表指定不同的数据库 - 这更多的是数据库集群的关注,而不是复制。