资讯专栏INFORMATION COLUMN

django中的配置文件

williamwen1986 / 4123人阅读

摘要:默认的,及使用它的号数据库此处使用号数据库,在客户端查看记得切换数据库存储在本机内存中,比数据库的方式读写快很多默认的配置项,采用号库。状态保持的配置项,采用号库。使用名为的配置项存储数据。配置完成后运行程序,测试结果。

1.配置开发环境

当进入虚拟环境,通过django_admin创建一个项目后,会在项目同名目录生成一个setting.py文件。而实际项目过程中会有不同的环境,如开发环境、生产环境;所有不同的环境各自使用不同的配置显得很重要。

开发环境:用于编写和调试项目代码。

生产环境:用于项目线上部署运行。

1.1 新建配置文件

    准备配置文件目录

    项目同名目录里名新建包,命名为settings,作为配置文件目录

    准备开发和生产环境配置文件

    在配置包settings中,新建开发环境配置文件

    准备开发环境配置内容

    将默认的配置文件settings.py中内容拷贝至setting包中,并命名为dev.py

1.2 指定开发环境配置文件

在项目文件manage.py中做如下修改:

</>复制代码

  1. # os.environ.setdefault("DJANGO_SETTINGS_MODULE", "meiduo_mall.settings") #默认找setting.py,此处注释掉
  2. os.environ.setdefault("DJANGO_SETTINGS_MODULE", "meiduo_mall.settings.dev")
2.配置Jinja2模板引擎

2.1 安装Jinja2扩展包

</>复制代码

  1. pip install Jinja2

Jinja2模板渲染速度比django默认模板渲染速度要快很多。

2.2 配置Jinja2模板引擎

在前面配置好的开发环境dev.py中加入如下代码,后续配置不说明也默认指在该文件中做修改。

</>复制代码

  1. TEMPLATES = [
  2. {
  3. "BACKEND": "django.template.backends.jinja2.Jinja2", # jinja2模板引擎
  4. "DIRS": [os.path.join(BASE_DIR, "templates")], # 此为模板渲染目录
  5. "APP_DIRS": True,
  6. "OPTIONS": {
  7. "context_processors": [
  8. "django.template.context_processors.debug",
  9. "django.template.context_processors.request",
  10. "django.contrib.auth.context_processors.auth",
  11. "django.contrib.messages.context_processors.messages",
  12. ],
  13. # Jinja2模板引擎环境
  14. "environment": "项目名.utils.jinja2_env.jinja2_environment", # 项目名修改为你项目的名字
  15. },
  16. },
  17. ]

2.1 编写Jinja2模板引擎环境配置代码

在项目同名应用中新建一个utils包,在包里新建一个jinja2_environment.py文件,文件里内容如下:

</>复制代码

  1. from jinja2 import Environment
  2. from django.contrib.staticfiles.storage import staticfiles_storage
  3. from django.urls import reverse
  4. def jinja2_environment(**options):
  5. env = Environment(**options)
  6. env.globals.update({
  7. "static": staticfiles_storage.url, # 确保模板引擎中可以使用{{ url("") }} {{ static("") }}这类语句
  8. "url": reverse,
  9. })
  10. return env

此时你会发现django中的默认站点admin已经不能访问了,我们要继续使用django强大的后台站点功能做如下修改:

</>复制代码

  1. TEMPLATES = [
  2. {
  3. # django 默认 template 模板配置
  4. "BACKEND": "django.template.backends.django.DjangoTemplates",
  5. "DIRS": [os.path.join(BASE_DIR, "templates")], # 此处配置要渲染的网页目录
  6. "APP_DIRS": True,
  7. "OPTIONS": {
  8. "context_processors": [
  9. "django.template.context_processors.debug",
  10. "django.template.context_processors.request",
  11. "django.contrib.auth.context_processors.auth",
  12. "django.contrib.messages.context_processors.messages",
  13. ],
  14. },
  15. },
  16. {
  17. "BACKEND": "django.template.backends.jinja2.Jinja2", # jinja2模板引擎
  18. "DIRS": [os.path.join(BASE_DIR, "templates")],
  19. "APP_DIRS": True,
  20. "OPTIONS": {
  21. "context_processors": [
  22. "django.template.context_processors.debug",
  23. "django.template.context_processors.request",
  24. "django.contrib.auth.context_processors.auth",
  25. "django.contrib.messages.context_processors.messages",
  26. ],
  27. # Jinja2模板引擎环境
  28. "environment": "项目名.utils.jinja2_env.jinja2_environment",
  29. },
  30. },
  31. ]
3 配置MySQL数据库

3.1 本地MySQL配置

先确保你本地MySQL有所需要的数据库名,然后进行连接,下面语句进入MySQL客户端后可新建一个数据库。

</>复制代码

  1. create database 数据库名 charset=utf8;

默认连接MySQL都是root用户权限级别太高,拥有操作所有数据库的权限,下面介绍MySQL新建用户并赋予操作多带带一个数据库的权限。

</>复制代码

  1. create user tom identified by "123456"; --新建tom用户,密码123456
  2. grant all on mall.* to "tom"@"%"; --授权tom用户操作mall数据库使用权限
  3. flush privileges; --刷新权限

3.2 配置MySQL数据库

django默认使用sqlite3数据库,这是一个轻量级关系型数据库,我们下面替换掉它,在dev.py中做如下配置:

</>复制代码

  1. DATABASES = {
  2. "default": {
  3. "ENGINE": "django.db.backends.mysql", # 数据库引擎
  4. "HOST": "127.0.0.1", # 数据库主机,填项目中数据库真实ip
  5. "PORT": 3306, # 数据库端口
  6. "USER": "tom", # 数据库用户名
  7. "PASSWORD": "123456", # 数据库用户密码
  8. "NAME": "mall" # 数据库名字
  9. },
  10. }

3.3 安装PyMySQL扩展包

</>复制代码

  1. pip install pymysql

在工程同名子目录的__init__.py文件中,添加如下代码:

</>复制代码

  1. from pymysql import install_as_MySQL
  2. db​​install_as_MySQLdb()

配置完成后:运行程序,测试结果。

4.配置redis

首先确保安装了redis数据库,然后在虚拟环境中安装redis,同样是通过pip安装。安装完以后还有安装redis的django扩展包django-redis

</>复制代码

  1. pip install redis
  2. pip install django-redis

dev.py中配置redis,此处用它来做session缓存。

</>复制代码

  1. CACHES = {
  2. "default": { # 默认
  3. "BACKEND": "django_redis.cache.RedisCache",
  4. "LOCATION": "redis://127.0.0.1:6379/0", # redis的ip,及使用它的0号数据库
  5. "OPTIONS": {
  6. "CLIENT_CLASS": "django_redis.client.DefaultClient",
  7. }
  8. },
  9. "session": { # session
  10. "BACKEND": "django_redis.cache.RedisCache",
  11. "LOCATION": "redis://127.0.0.1:6379/1", # 此处使用1号数据库,在客户端查看记得select 1,切换数据库
  12. "OPTIONS": {
  13. "CLIENT_CLASS": "django_redis.client.DefaultClient",
  14. }
  15. },
  16. }
  17. SESSION_ENGINE = "django.contrib.sessions.backends.cache" # 存储在本机内存中,比数据库的方式读写快很多
  18. SESSION_CACHE_ALIAS = "session"

default:

默认的Redis配置项,采用0号Redis库。

session:

状态保持的Redis配置项,采用1号Redis库。

SESSION_ENGINE

修改session存储机制使用Redis保存。

SESSION_CACHE_ALIAS:

使用名为"session"的Redis配置项存储session数据

配置完成后:运行程序,测试结果。

关于对session缓存策略的说明:

本地缓存

存储在本机内存中,如果丢失则不能找回,比数据库的方式读写更快。

</>复制代码

  1. SESSION_ENGINE="django.contrib.sessions.backends.cache"

混合存储

优先从本机内存中存取,如果没有则从数据库中存取。

</>复制代码

  1. SESSION_ENGINE="django.contrib.sessions.backends.cached_db"

默认存储

存储在数据库中,如下设置可以写,也可以不写。

</>复制代码

  1. SESSION_ENGINE="django.contrib.sessions.backends.db"
5.配置项目日志

下面介绍使用logging记录项目的日志。在dev.py中做如下设置:

</>复制代码

  1. LOGGING = {
  2. "version": 1,
  3. "disable_existing_loggers": False, # 是否禁用已经存在的日志器
  4. "formatters": { # 日志信息显示的格式
  5. "verbose": {
  6. "format": "%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s"
  7. },
  8. "simple": {
  9. "format": "%(levelname)s %(module)s %(lineno)d %(message)s"
  10. },
  11. },
  12. "filters": { # 对日志进行过滤
  13. "require_debug_true": { # django在debug模式下才输出日志
  14. "()": "django.utils.log.RequireDebugTrue",
  15. },
  16. },
  17. "handlers": { # 日志处理方法
  18. "console": { # 向终端中输出日志
  19. "level": "INFO",
  20. "filters": ["require_debug_true"],
  21. "class": "logging.StreamHandler",
  22. "formatter": "simple"
  23. },
  24. "file": { # 向文件中输出日志
  25. "level": "INFO",
  26. "class": "logging.handlers.RotatingFileHandler",
  27. "filename": os.path.join(os.path.dirname(BASE_DIR), "logs/mall.log"), # 日志文件的位置
  28. "maxBytes": 300 * 1024 * 1024,
  29. "backupCount": 10,
  30. "formatter": "verbose"
  31. },
  32. },
  33. "loggers": { # 日志器
  34. "django": { # 定义了一个名为django的日志器
  35. "handlers": ["console", "file"], # 可以同时向终端与文件中输出日志
  36. "propagate": True, # 是否继续传递日志信息
  37. "level": "INFO", # 日志器接收的最低日志级别
  38. },
  39. }
  40. }

然后在项目目录中建立一个logs的目录,然后在目录中建立一个mall.log文件。名字可以任意起,记得很上面file中filename对应起来即可。

当然实际开发中大都是使用git来管理项目的,每个人调试产出的log不太一样,开发中可以先将其加入忽略文件中。在项目文件.gitignioe中新增如下信息:

</>复制代码

  1. *.log

然后在logs目录中建立一个.gitkeep文件,保证logs目录能被git管理。

6.配置前端静态文件

前面提了一下项目中的html模板文件是配置在templates中,需要在项目同名子应用中建立一个templates目录,项目中需要使用静态文件,比如 css、images、js 等等,需要专门使用配置一个目录。在里面建立不同的目录来存放不同的文件。

</>复制代码

  1. STATIC_URL = "/static/" # 静态文件的路由​# 配置静态文件加载路径
  2. STATICFILES_DIRS = [os.path.join(BASE_DIR, "static")] # 在项目同名子引用中建立一个static目录

STATICFILES_DIRS是一个列表,这样我们就可以配置多个目录来存放静态文件。如:

</>复制代码

  1. # 配置静态文件加载路径
  2. STATICFILES_DIRS = [os.path.join(BASE_DIR, "static"),os.path.join(BASE_DIR, "static2")]
7.应用注册

在项目同名目录中,也就是setting包同级目录中新建一个apps的包,然后进入到apps的目录中,在终端执行如下命令,创建一个users应用。

</>复制代码

  1. python ../../manage.py startapp users

然后在dev.py中注册应用:

</>复制代码

  1. INSTALLED_APPS = [
  2. "django.contrib.admin",
  3. "django.contrib.auth",
  4. "django.contrib.contenttypes",
  5. "django.contrib.sessions",
  6. "django.contrib.messages",
  7. "django.contrib.staticfiles",
  8. # 注册
  9. "mall.apps.users.apps.UsersConfig", # 用户模块应用
  10. ]

下面介绍一下python中sys模块,在dev.pyBASE_DIR下新增:

</>复制代码

  1. import sys
  2. # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
  3. BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
  4. sys.path.insert(0, os.path.join(BASE_DIR, "apps")) # 追加项目路径

这样注册应用就能简化成如下方式了:

</>复制代码

  1. INSTALLED_APPS = [
  2. "django.contrib.admin",
  3. "django.contrib.auth",
  4. "django.contrib.contenttypes",
  5. "django.contrib.sessions",
  6. "django.contrib.messages",
  7. "django.contrib.staticfiles",
  8. # 注册
  9. # "mall.apps.users.apps.UsersConfig", # 用户模块应用
  10. "users", # 用户模块应用
  11. ]


文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/7031.html

相关文章

  • django中的配置文件

    摘要:默认的,及使用它的号数据库此处使用号数据库,在客户端查看记得切换数据库存储在本机内存中,比数据库的方式读写快很多默认的配置项,采用号库。状态保持的配置项,采用号库。使用名为的配置项存储数据。配置完成后运行程序,测试结果。 1.配置开发环境当进入虚拟环境,通过django_admin创建一个项目后,会在项目同名目录生成一个setting.py文件。而实际项目过程中会有不同的环境,如开发环境、生...

    番茄西红柿 评论0 收藏0
  • Django 项目配置初体验(一)

    摘要:静态资源路径可以有多个,所以这里使用一个列表进行配置再次进入,完美后记现在只涉及到了项目的配置和一些基础的配置,没有涉及到请求从开始到完成的任何内容。下篇教程将集中进行记录。 前言 推荐使用 virtualenv 创建 python 虚拟环境,防止因为使用 pip 安装依赖到全局引起版本冲突的问题,PyCharm 默认会生成一个 venv 目录并创建虚拟环境,使用 IDE 自带的终端...

    Wildcard 评论0 收藏0
  • 【连载】Django入门到实战(一)

    摘要:一项目目录结构介绍与项目进行交互的命令行工具集的入口项目管理器目录项目容器,包含项目的基本配置,目录名称不建议修改中声明模块的文件,内容默认为空项目的总配置文件,包含数据库应用时间等各种配置配置文件,项目中所有地址页面都需要我们自己去配置其 一、项目目录结构介绍 showImg(https://segmentfault.com/img/remote/1460000016373937?w...

    since1986 评论0 收藏0

发表评论

0条评论

williamwen1986

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<