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