我有两个服务器,运行postgres,设置为使用热备用的主/复制器。当我在主服务器上使用django进行查询时,查询所花费的时间大约是复制服务器上相同查询所花费的时间的一半。除了运行提供WAL文件的读/写数据库,另一个运行从WAL文件复制的只读数据库外,服务器是相同的。
如果我在复制服务器上进行查询以掌握查询,则如果我直接向本地数据库进行查询,则查询速度会降低两倍。这是为什么?
我正在使用django文档中描述的数据库路由器:
class DatabaseRouter:
def db_for_read(self, model, **hints):
"""
Reads go to local host.
"""
return 'default'
def db_for_write(self, model, **hints):
"""
Writes always go to master.
"""
return 'write'
def allow_relation(self, obj1, obj2, **hints):
"""
Relations between objects are allowed if both objects are
in the primary/replica pool.
"""
db_list = ('default', 'write')
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):
"""
Migration handled by PostgreSQL
"""
return None
我的设置文件中有数据库设置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': NAME,
'USER': USERNAME,
'PASSWORD': PASSWORD,
'HOST': '127.0.0.1',
'PORT': '5432',
},
'write': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': NAME,
'USER': USERNAME,
'PASSWORD': PASSWORD,
'HOST': MASTER_IP,
'PORT': '5432',
}
}