Django配置(settings)解析

1、项目路径(自动生成)

BASE_DIR = Path(__file__).resolve().parent.parent

2、密钥(自动生成)

SECRET_KEY = 'p*d7^ue2asdfsdxmk+1d(sdf5!jk_1^lk2rasdf1jf%!+@)k3!)asdhjo3(c%asmygsusdfs'

随机字符串,可手工修改长一点,防止跨站攻击。

3、调试模式

DEBUG = True

开发运行模式(python manage.py runserver)下,只能使用调试模式,不能使用生产模式。

DEBUG = False模式下,运行时不会访问static目录,也就是不能加载静态资源。

4、域名访问权限

ALLOWED_HOSTS = []

允许所有域名或ip访问,可设置:ALLOWED_HOSTS = [*]

5、App列表

INSTALLED_APPS = [

    #  内置的后台管理系统

    'django.contrib.admin',

    #  内置的用户认证系统

    'django.contrib.auth',

    # 所有model元数据

    'django.contrib.contenttypes',

    # 会话,表示当前访问网站的用户身份

    'django.contrib.sessions',

    # 消息提示

    'django.contrib.messages',

    # 静态资源路径

    'django.contrib.staticfiles',

    # 周期性任务

    'django_celery_beat',

    # 注册自己的APP

    'userapp',

]

默认只有前6个APP,Django在启动时,是按list的顺序进行顺序加载的,所以,APP放的顺序不能乱,不能随便放。

6、中间件

MIDDLEWARE = [

    'django.middleware.security.SecurityMiddleware',

    'django.contrib.sessions.middleware.SessionMiddleware',

    'django.middleware.common.CommonMiddleware',

    # csrfToken校验,开启此中间件后,post请求头域里需要携带正确的X-CSRFToken,后台才能Token校验通过,或者在post views函数前加装饰器@csrf_exempt

    'django.middleware.csrf.CsrfViewMiddleware',

    'django.contrib.auth.middleware.AuthenticationMiddleware',

    'django.contrib.messages.middleware.MessageMiddleware',

    'django.middleware.clickjacking.XFrameOptionsMiddleware',

    # 自定义添加的中间件,用于实现request和response的拦截器。

    'userapp.middleware.SimpleMiddleware',

]

中间件是request和response对象之间的钩子。

Django系统默认只有前7个中间件。

8、模板引擎

TEMPLATES = [

    {

        #### 定义模板引擎

        'BACKEND': 'django.template.backends.django.DjangoTemplates',

        #### 设置模板路径

        'DIRS': [],

        #### 是否在App里查找模板文件

        'APP_DIRS': True,

        #### 用于RequestContext上下文的调用函数

        'OPTIONS': {

            'context_processors': [

                'django.template.context_processors.debug',

                'django.template.context_processors.request',

                'django.contrib.auth.context_processors.auth',

                'django.contrib.messages.context_processors.messages',

            ],

        },

    },

]

系统默认即可,除非有需求才修改。

9、数据库配置

Django默认的是sqlite,我们一般改为mysql。

# 注释sqlite

# DATABASES = {

#     'default': {

#         'ENGINE': 'django.db.backends.sqlite3',

#         'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),

#     }

# }

# 添加mysql

DATABASES = {

    'default': {

        'ENGINE': 'django.db.backends.mysql',

        'NAME': 'test',

        'USER': 'root',

        'PASSWORD': 'rootpwd',

        'HOST': '127.0.0.1',

        'PORT': '3306',

    }

    # 生产环境有可能连接第二个数据库

    # 'db2': {

    #     'ENGINE': 'django.db.backends.mysql',

    #     'NAME': 'mydatabase',

    #     'USER': 'mydatabaseuser',

    #     'PASSWORD': 'mypassword',

    #     'HOST': '127.0.0.1',

    #     'PORT': '3307',

    # }

}

10、缓存

CACHES = {

    "default": {

        "BACKEND": "django_redis.cache.RedisCache",

        "LOCATION": f"redis://{redis_ip}:{redis_port}/0",

        "OPTIONS": {

            "CLIENT_CLASS": "django_redis.client.DefaultClient",

            "CONNECTION_POOL_KWARGS": {"max_connections": 100},

            "PASSWORD": redis_pwd,

            "DECODE_RESPONSES": True

        },

        "TIMEOUT": 30,

    }

}

CACHES实现models对redis的读写。

11、时区和语言设置

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = True

12、静态资源目录

STATIC_URL = '/static/'

STATICFILES_DIRS = [(os.path.join(BASE_DIR,'static'))] # 这里必须是list或者tuple格式

13、celery的中间人设置

以redis为例:

BROKER_URL = f'redis://:{redis_pwd}@{redis_ip}:{redis_port}/0'  # 代理人

# 哨兵模式下的BROKER_URL配置

#BROKER_URL = f'sentinel://:{redis_pwd}@{redis_ip1}:{redis_port}/0;sentinel://:{redis_pwd}@{redis_ip2}:{redis_port}/0;sentinel://:{redis_pwd}@{redis_ip3}:{redis_port}/0;'

# redis哨兵master配置

#BROKER_TRANSPORT_OPTIONS = {'master_name':masterName}

CELERY_IMPORTS = ('commapp.tasks')  # app

CELERY_TIMEZONE = 'Asia/Shanghai' # 时区

CELERYBEAT_SCHEDULER='django_celery_beat.schedulers.DatabaseScheduler'

# 并发的worker数量,也是命令行-c指定的数目,事实上并不是worker数量越多越好,保证任务不堆积,加上一些新增任务的预留就可以了

CELERYD_CONCURRENCY = 4

# 防止celery进程假死

CELERYD_FORCE_EXECV = True

# 每个worker执行了多少次任务后就会死掉

CELERYD_MAX_TASKS_PER_CHILD = 100


BROKER_URL的配置参考:https://www.celerycn.io/ru-men/zhong-jian-ren-brokers

Broker支持:RabbitMQ、Redis、Amazon SQS

你可能感兴趣的:(Django配置(settings)解析)