Django中多数据库的读写分离、一主多从及分库分表的使用

配置方法

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'),
    },
}

多个数据库的迁移

  默认迁移的是default,当然也可以指定迁移的数据库:

python manage.py migrate --database db2

Django多个数据库的读写分离、一主多从及分库分表

手动方法

  在进行ORM查询的时候指定对应的数据库就好了:

models.Student.objects.using('db2').all()

obj = models.Student.objects.using('db2').get(name='zhazha')
obj.name = 'star'
obj.save(using='default')

自动方法

settings中:

# 自定义的类写在了myrouter.py文件中的Router类中
DATABASE_ROUTERS = ['myrouter.Router']

自定义类:

class Router:
    """
    读写分离
    
    """

    def db_for_write(self, model, **kwargs):
        return 'db2'

    def db_for_read(self, model, **kwargs):
        return 'default'

一主多从:

class Router:
    """
    一主多从
    """

    def db_for_write(self, model, **kwargs):
        return 'db1'

    def db_for_read(self, model, **kwargs):
        return random.choices['db2', 'db3', 'db4']

分库分表:

 

class Router:
    """
    分库分表

    app01  model   db1
    app02  model   db2
    """

    def db_for_write(self, model, **kwargs):
     # 获取应用的名称 app_name
= model._meta.app_label if app_name == 'app01': return 'db1' elif app_name == 'app02': return 'db2' def db_for_read(self, model, **kwargs):
     # 获取应用的名称 app_name
= model._meta.app_label if app_name == 'app01': return 'db1' elif app_name == 'app02': return 'db2'

 

~~

 

posted on 2018-03-27 11:15  江湖乄夜雨  阅读(497)  评论(0编辑  收藏  举报