学习 Django 配置,看这篇文章就能学会 50%,剩下的 1/2 看下一篇。

橡皮擦,一个逗趣的互联网高级网虫。新的系列,让我们一起进入 Django 世界。

已经完成的文章

  • 滚雪球学 Python 第三轮,Python Web 之 Django 的世界
  • 小手哆嗦一下,就能用 Python Django 实现一个微型博客系统
  • Django 做个小后台,细节在完善一点点,滚雪球学 Python 第三阶段
  • Django QuerySet 就学那么一点点,一点点就够了
  • 看完这篇博客,Python Django 你就学会一半了
  • 让我们一起开发【菜谱系统】吧,滚雪球学 Python 第三轮项目计划
  • 出现吧,Python Web 菜谱系统的首页,不会前端技术,也能做
  • 简简单单实现 Python Web 的登录注册页面,还包含一半逻辑。
  • Python Web 菜谱项目再次前进一步,从应用层了解内置用户认证系统
  • 菜谱系统小成阶段,Python Web 领域终于攻占一个小山头
  • 销售 小姐姐 给买家打分系统,用 Python Django 又整了一个花活
  • 帮小姐姐打分系统的模型创建,滚雪球学 Python 第三轮第 12 篇
  • 为了完成小姐姐安排的打分系统,又熬了一个小时的夜补充视图与模板
  • 打分吧!客服小姐姐,评分页面与客户总分页面的 Django 实现
  • 就靠这一篇文章,我就弄懂了 Python Django 的 django-admin 命令行工具集

滚雪球学 Python 第三轮

    • 已经完成的文章
  • 十六、Django 配置
    • 16.1 配置文件概述
    • 16.2 CACHES 缓存
      • 16.2.1 CACHES 缓存配置可选参数
    • 16.3 配置文件中的数据库配置
      • 16.3.1 DATABASES
      • 16.3.2 更多的配置
    • 16.4 本篇博客小节

十六、Django 配置

这篇文章主要学习的 Django 的配置文件 settings.py,因为配置文件是一个模块,所以配置项都是模块级别的变量,配置文件在使用时需要提前做好配置,你可以打开 manage.py ,然后在 main 函数开头位置,进行环境变量 DJANGO_SETTINGS_MODULE 的配置。

def main():
    """Run administrative tasks."""
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'cutegirl.settings')

该配置在 wsgi.py 文件中也存在,为了便于使用 WSGI 部署 Django 应用程序。

import os

from django.core.wsgi import get_wsgi_application

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'cutegirl.settings')

application = get_wsgi_application()

16.1 配置文件概述

配置文件可以引入其他文件的中的变量,也可以使用简单语法进行动态设置。
Django 除了项目目录中的 settings.py 文件外,还存在一个默认配置文件。该文件存在与 site-packages\django\conf\global_settings.py 文件中。

代码文件头部注释如下:

"""
Default Django settings. Override these with settings in the module pointed to
by the DJANGO_SETTINGS_MODULE environment variable.
"""

在文件中使用 django 配置

在代码文件中引入配置文件,使用的导入代码为:from django.conf import settings,这里不能采用 from django.conf.settings import 变量 方式进行变量导入,原因在 django 初始化时,将 settings 设置为了对象,代码可以在 \site-packages\django\conf\__init__.py 底部查看到。

settings = LazySettings()

配置文件如果进行了修改,必须重启 django 测试服务器。

16.2 CACHES 缓存

在 django 中定义了项目可以用到的全部缓存,default 是缓存的别名,BACKEND 是缓存的解释引擎。在 global_settings.py 文件中可以直接检索 CACHES 即可找到缓存配置。
缓存的主要价值是在 Django 中,用户请求到达视图 views 后,视图会先从缓存中获取数据,进行动态渲染,渲染后的结果就是用户看到的网页。

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
    }
}

缓存的 BACKEND 包含如下内容,设置如下:
Memcached 缓存
Memcached 是基于内存的缓存,Django 原生支持的最快最有效的缓存系统。推荐使用 Memcached,数据缓存在服务器端。
代码可以参考下述内容:

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'LOCATION': '127.0.0.1:11211',
    }
}

数据库缓存

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
        'LOCATION': 'my_cache_table',
}

文件系统缓存
案例以 windows 为参考,其它系统大同小异。

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': 'c:\demo\django_cache'
    }
}

本地内存缓存

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        'LOCATION': 'unique-snowflake'
    }
}

redis 缓存
默认采用 1 数据库

CACHES = {
     
    "default": {
     
        "BACKEND": "redis_cache.cache.RedisCache",
        "LOCATION": "localhost:6379",
        'TIMEOUT': 60
    }
}

16.2.1 CACHES 缓存配置可选参数

缓存配置参数使用在 default 字典中,代码格式如下:

CACHES = {
     
    'default': {
     
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        '配置参数1': '配置参数值',
        '配置参数2': '配置参数值',
        '配置参数3': '配置参数值',
        '配置参数4': '配置参数值'
    }
}

KEY_PREFIX
使用该配置之后,在生成的缓存名称前会自动加上前缀。

TIMEOUT
缓存的默认过期时间,以秒为单位,默认值为 300;TIMEOUTNone 表示永远不会过期,值设置成 0 ,缓存立即失效。

LOCATION
缓存地址,依据 BACKEND 不同,配置也不同。

OPTIONS
配合 BACKEND 传递更多的参数。

VERSION
缓存的版本号。

其它内容在应用到的时候,可以进行补充。例如 CACHE_MIDDLEWARE_ALIASCACHE_MIDDLEWARE_KEY_PREFIXCACHE_MIDDLEWARE_SECONDS

16.3 配置文件中的数据库配置

16.3.1 DATABASES

global_settings.py 文件中,DATABASES 只有一个空字典,但是在项目的 settings.py 中,django 为其初始化了一个值。

DATABASES = {
     
    'default': {
     
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}

DATABASES 很容易理解,就是用于指定网站所使用的数据库类型以及连接方式,最外层的是数据库别名,值就是数据库配置信息。

在我们使用初始化命令创建数据库的时候,系统自动初始化了一个 sqlite 类型的数据连接,自然可以基于此使用 Django 自带的后台管理系统。

不过一般在项目中,我们还是会使用 MySQL,Oracle 这些主流的数据库,所以该配置必须要牢牢掌握。

下面是基于 MySQL 的配置信息。

DATABASES = {
     
    'default': {
     
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'scoring',
        'USER': 'root',
        'PASSWORD': '',
        'HOST': 'localhost',
        'PORT': '3306',
    }
}

配置含义非常简单,直接翻译即可。

  • DATABASE_ENGINE:数据库引擎;
  • DATABASE_NAME:数据库名称;
  • DATABASE_USER:连接用户;
  • DATABASE_PASSWORD:用户密码;
  • DATABASE_HOST:主机名;
  • DATABASE_PORT:数据库端口。

16.3.2 更多的配置

ATOMIC_REQUESTS
如果设置为 True,Django 会把每个视图的数据库操作封装到一个数据库事务中。

AUTOCOMMIT
Django 是否开启事务。

CONN_MAX_AGE
数据库会话的声明周期,默认为 0,表示每次请求结束立刻关闭数据库连接。

OPTIONS
附加参数。

TIME_ZONE
数据库所使用的时区。

TEST
配置测试数据库,关于测试数据库配置支持的参数,可以后续继续扩展学习。

16.4 本篇博客小节

本篇博客带大家进入 Django 文件配置的学习,本文只是其中的一部分,希望能给你提供学习的方向。

相关阅读

  1. Python 爬虫 100 例教程,超棒的爬虫教程,立即订阅吧
  2. Python 游戏世界(更新中,目标文章数 50+,现在订阅,都是老粉)
  3. Python 爬虫小课,精彩 9 讲,只要 9 块 9

今天是持续写作的第 137 / 200 天。
如果你想跟博主建立亲密关系,可以关注同名公众号 梦想橡皮擦,近距离接触一个逗趣的互联网高级网虫。
博主 ID:梦想橡皮擦,希望大家点赞评论收藏

你可能感兴趣的:(滚雪球学,Python,第三轮,数据库,python,java,mysql,django)