【1】第一步:配置文件配置多个数据库
- 在Django的配置文件中的DATABASES参数中,添加多个数据库的配置信息。
- 每个数据库都需要指定ENGINE(数据库引擎)和NAME(数据库名称),可以根据实际情况选择合适的数据库引擎和数据库名称。
- 例如,在配置文件中添加两个数据库配置的示例:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'master_db',
'USER': 'master_user',
'PASSWORD': 'master_password',
'HOST': 'localhost',
'PORT': '3306',
},
'slave': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'slave_db',
'USER': 'slave_user',
'PASSWORD': 'slave_password',
'HOST': 'localhost',
'PORT': '3307',
}
}
【2】第二步:手动读写分离
- 在需要进行读写操作的地方,使用
.using()
方法来指定使用哪个数据库进行操作。 - 例如,向'db1'数据库进行写入操作的示例:
Book.objects.using('db1').create(name='西游记')
【3】第三步:自动读写分离
-
创建一个Python文件,命名为db_router.py,并在其中定义一个类DBRouter,继承自django.db.utils.BaseDatabaseRouter,该类用于自动路由数据库。
-
在DBRouter类中,需要实现
db_for_read()
和db_for_write()
方法,这两个方法分别用于决定读操作和写操作使用的数据库。 -
例如,在DBRouter类中实现自动读写分离的示例:
class DBRouter(object):
def db_for_read(self, model, **hints):
# 多个从库 ['db1','db2','db3'] ---- 负载 --- random
# 决定读操作使用的数据库
return 'slave'
def db_for_write(self, model, **hints):
# 决定写操作使用的数据库
return 'default'
- model 是当前调用的表模型
- 可以通过当前表模型进行分库分表
- 一千万 在一张表
- 一千亿 在另一张表
【4】第四步:配置文件配置路由
- 在Django的配置文件中的DATABASE_ROUTERS参数中,指定使用自定义的DBRouter类来进行数据库路由。
- 例如,在配置文件中配置使用DBRouter来进行数据库路由的示例:
DATABASE_ROUTERS = ['myapp.db_router.DBRouter']
-
这样配置后,Django将会自动根据DBRouter类中定义的逻辑来进行读写操作的数据库路由。
-
需要注意的是,以上示例仅为说明目的,实际使用时,需要根据具体的项目需求和数据库配置进行相应的修改。
【5】总结
- 通过以上配置和操作,就可以在Django中实现读写分离。
- 读操作会自动路由到指定的从库,而写操作则会路由到主库,实现了读写分离的效果。