Loading

Django中一种常见的setting与账密保存/读取方式

前言

在查看别人Django代码的时候,发现很多的manager文件都是类似于

#!/usr/bin/env python
import os
import sys

if __name__ == '__main__':
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'conf.development.settings')
    try:
        from django.core.management import execute_from_command_line
    except ImportError as exc:
        raise ImportError(
            "Couldn't import Django. Are you sure it's installed and "
            "available on your PYTHONPATH environment variable? Did you "
            "forget to activate a virtual environment?"
        ) from exc
    execute_from_command_line(sys.argv)

这种的

然后部署时又需要先设置环境变量,看配置文件有.env又有setting.py,这是怎么回事呢?

正文

就以我们之前的某个项目为例,同事写的就是这样的结构.

在 conf 文件夹下的 production文件夹 中有着 settings.py 存放 django 的一些设置,同级目录下还有 .env 文件存放一些账密

那么在请求进入的时候,django是怎样获取这些配置的呢?

我们来从请求进入说起

supervisor托管时会先将整体的settings写入当前shell的环境变量(已下为supervisor配置节选)

environment=DJANGO_SETTINGS_MODULE=conf.production.settings

此时该进程中有环境变量 DJANGO_SETTINGS_MODULE 为 conf.production.settings

然后django按照环境变量去寻找该文件,解析settings.py

我们来看 settings.py 的部分代码

 在开头部分,引用了os和dotenv模块

dovent模块可以将.env文件按每行 k=v 的格式解析出相应的键值对存入环境变量中,代码注释后为

# 拼接路径为当前绝对路径下的.env文件
dotenv_path = join(dirname(__file__), '.env')
# load_dovent作用解析.env文件的配置项写入环境变量
load_dotenv(dotenv_path)

.env文件节选内容为

 

 然后我们发现. settings.py中有些账密的配置是存储在.env中, 启动时通过环境变量写入, 而在settings中引入则为

 

使用 os.environ.get 按照key读取环境变量的值,

而一些不太重要的或者不变的(比如Django时区什么的),就明文写在了settings.py中直接读取

好处

显而易见的,将账密单独存储至 .env 文件可增加部分安全性,将经常改变的配置项写在 .env 也可增加部分可维护性

但是对于之前没有做过类似模式的同学来说可能较难懂,这也是本篇博文的目的所在.希望对你有所帮助.

 

posted @ 2019-10-11 15:42  ChnMig  阅读(1046)  评论(0编辑  收藏  举报