zoukankan      html  css  js  c++  java
  • Django中settings设计模式(单例模式)

    配置文件:

    需求:配置文件,默认配置和手动配置分开,参考django的配置文件方案,默认配置文件放在项目容器内部,只让用户做常用配置。

    /bin/settings.py(手动配置)

    PLUGIN_ITEMS = {
        "nic": "src.plugins.nic.Nic",
        "disk": "src.plugins.disk.Disk",
    }
     
    API = "http://127.0.0.1:8000/api/server.html"
    

    /lib/config/global_settings.py(默认配置)

    TEST = True
     
    NAME = "baishuchao"
    

    /lib/config/init.py(/lib/config/目录的初始化文件)

    import sys,os
    import importlib
    from . import global_settings
     
    class Settings():
        """
        global_settings,配置获取
        settings.py,配置获取
        """
        def __init__(self):
     
            for item in dir(global_settings):
                if item.isupper():
                    k = item
                    v = getattr(global_settings,item)
                    setattr(self,k,v)
     
            setting_path = os.environ.get('AUTO_CLIENT_SETTINGS')
            md_settings = importlib.import_module(setting_path)
            for item in dir(md_settings):
                if item.isupper():
                    k=item
                    v=getattr(md_settings,item)
                    setattr(self,k,v)
     
    settings = Settings()
    # 配置文件直接从这个settings对象拿
    

    /bin/run.py(启动文件,打印配置内容)

    import sys
    import os
    import importlib
    import requests
     
    BASEDIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
    sys.path.append(BASEDIR)
     
    os.environ['AUTO_CLIENT_SETTINGS']="conf.settings"
    from lib.config import settings
     
    print(settings.NAME)
    print(settings.TEST)
    

    目录结构:

    注意:引入配置这种方式在软件设计模式里叫单例模式,因为引入两次也相当于一次

    1. 导入配置,from lib.config import settings ,这里的lib.config是一个文件夹,从文件夹导入settings??? 因为:如果导入文件夹的话,默认导入文件夹下面的__init__.py文件,所以import settings就是__init__.py文件里面的settings。

    2. settings是一个导入配置文件的对象,init.py文件有一个获取配置的类,默认配置和手动配置,实例化一个settings对象,这个对象就包含了所有的配置。

  • 相关阅读:
    一个简单的window.onscroll实例
    vue 自定义组件使用v-model
    vue开发后台管理系统有感
    cube打包后css顺序错误
    app嵌套的vue项目更新后,页面没有更新
    vue打包后css背景图片地址找不到
    git取消操作命令
    cube-ui indexList的正确使用
    首次db查询时延迟明显高于后面几次。
    git中的merge与rebase
  • 原文地址:https://www.cnblogs.com/baishuchao/p/9278422.html
Copyright © 2011-2022 走看看