• Django学习之完成数据库主从复制、读写分离和一主多从情况下的使用办法


    1.首先配置多个数据库,在settings配置文件中配置以下内容:

    DATABASES = {
        'default': { #默认数据库,配置多个mysql数据也是ok的,混用数据库也是ok的
            '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'),
        }
    }
    

    2.执行数据库同步指令,将我们的表结构生成到db2这个数据库中

    python migrate --database db2(库名)
    

      执行完上面的指令之后,你就会发现,db2这个库里面就有了我们的表

    3.看看读写分离的情况下,django怎么玩

      a.手动写,在views.py文件中写

    def dbtest(request):
        data = []
        # 向db2数据库中写入数据
        # models.Class.objects.using('db2').create(name='xx')
    
        # 从db1中读取数据
        data = models.Class.objects.using('default').all()
        # 更新时    for i in data:        i.name = 'xxxxxx'        i.save(using='default') #更新时指定数据库
        return render(request,'dbtest.html',{'data':data})
    

      b.配置自动

       在应用文件夹中创建一个py文件,名字随意,比如叫做router.py文件,写上下面的内容:

    class Router:
        # 读操作用default库,就return这个库名字符串
        def db_for_read(self,model,**kwargs):
            return 'default'
    
        def db_for_write(self,model,**kwargs):
            return 'db2'
    

        然后在settings配置文件中做下面的配置

    DATABASE_ROUTERS = ['app01.router.Router',] #写上面这个类的路径,我的是在app01应用文件夹下面的router.py文件中了
    

       那么在逻辑的views.py文件中写的时候,就不需要using指定数据库了

    def dbtest(request):
        data = []
        # 向db2数据库中写入数据
        models.Class.objects.create(name='xx2')
    
        # 从db1中读取数据
        data = models.Class.objects.all()
    
        return render(request,'dbtest.html',{'data':data})
    

      那么如果是一主多从的时候,也就是从多个数据库中读取的时候:

    import random
    class Router:
        # 读操作用default库,就return这个库名字符串
        def db_for_read(self,model,**kwargs):
            print(11111)
            print(model._meta.app_label)
            return 'default'
            # return random.choice(['db1','db2','db3']) #多个库读的时候,可以简单的写个随机选择
    
        def db_for_write(self,model,**kwargs):
    
            return 'db2'
    

      

      根据不同的应用来选择不同的库进行读取

    import random
    class Router:
        # 读操作用default库,就return这个库名字符串
        def db_for_read(self,model,**kwargs):
            print(model)
            print(dir(model))# 其中有个_meta属性很有用
            a = model._meta.app_label #获取当前model对象所在的应用名称     m = model._meta.model_name  获取当前操作的model对象的表名,也可以根据表名来进行多数据库读的分配
            # 可以根据应用选择不用的库来进行读取
            if a == 'app01':
                return 'db1'
            elif a == 'app02':
                return 'db2'
            return 'default'
    
        def db_for_write(self,model,**kwargs):
    
  • 相关阅读:
    [Ramda] Getter and Setter in Ramda & lens
    [Angular2 Router] Index router
    [TypeScript] Using Interfaces to Describe Types in TypeScript
    [RxJS] ReplaySubject with buffer
    [Ramda] Declaratively Map Predicates to Object Properties Using Ramda where
    [Ramda] Pluck & Props: Get the prop(s) from object array
    [Ramda] Complement: Logic opposite function
    [TypeScript] Distinguishing between types of Strings in TypeScript
    [NodeJS] Use Now alias for custom sub-domains
    [CSS3] Create a fixed-fluid-fixed layout using CSS calc()
  • 原文地址:https://www.cnblogs.com/caodneg7/p/13277722.html
Copyright © 2020-2023  润新知