【发布时间】:2020-05-11 03:50:35
【问题描述】:
从 django 文档中,可以从数据库创建副本并定义它将写入或读取的位置。 (django multiple-database)。
然后,它为它编写代码,配置我的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',
},
}
并创建路由器:
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
但这不能正常工作。当我写的时候,它只是写在default,不反映到replica。然后当我阅读replica 时,值不会退出。
他不应该在default中写入并复制replica中的值吗?我正在使用 django-rest-framework
这段代码与文档非常相似,我不知道有什么问题。还是我看不懂 django 文档?
【问题讨论】:
标签: django database django-rest-framework