当一个项目当中有大量的数据的时候,你所有的IO操作都在一个数据库中操作,会造成项目的性能的降低。如果你能对项目中的数据进行读写分离的话,那么将大大提高你项目的性能。而Django自带的机制也对此提供了支持。我们可以简单的操作一下。(当然数据的同步还是需要运维同志的协助)
1修改配置文件
Django默认的是default,我们按照它的格式直接添加一个新的配置:
DATABASES = {
‘default’: {
‘ENGINE’: ‘django.db.backends.sqlite3’,
‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’),
},
‘db2’: {
‘ENGINE’: ‘django.db.backends.sqlite3’,
‘NAME’: os.path.join(BASE_DIR, ‘db2.sqlite3’),
}
}
当然,如果你不想使用默认的sqlite3,想使用mysql还需要自己进行一下配置
DATABASES = {
‘default’: {
‘ENGINE’: ‘django.db.backends.mysql’,
‘HOST’: ‘127.0.0.1’, # 主服务器的运行ip
‘PORT’: 3306, # 主服务器的运行port
‘USER’: ‘django’, # 主服务器的用户名
‘PASSWORD’: ‘django’, # 主服务器的密码
‘NAME’: ‘djangobase’ # 数据表名
},
‘slave’: {
‘ENGINE’: ‘django.db.backends.mysql’,
‘HOST’