(2)Django生产环境数据库的切换以及环境配置python-dotenv方案

简介

本文分享下个人目前在用的,DRF项目开发环境、生产环境数据库切换的方案。没做过什么大项目,可能实现的不是那么优雅。

主要思路就是通过python-dotenv库,编辑.env环境配置文件区分开发环境和生产环境,再使用数据库路由,部署在生产环境的项目将自动连接生产环境数据库。

环境配置区分实现流程(python-dotenv)

1.安装python-dotenv

shell 复制代码
pip install python-dotenv # 有手就行

2.在项目根目录 下创建.env文件

3.在.env文件内添加自己准备区分的配置,比如DEBUG,或者各种第三方开发平台的key,以及各种生产环境,开发环境需要区分的配置项

python 复制代码
# dotenv会以键值对的形式读取配置,配置项用=分割
DJANGO_DEBUG=True
WEATHER_KEY=***********
......

4.在你项目的git忽略文件.gitignore中添加.env文件,因为我们生产环境和开发环境需要不同的配置,所以这个文件不能同步

5.演示引用配置,比如我们常用的,在settings.py中调取.env中的debug 配置来区别开发/生产环境

settings.py

python 复制代码
from dotenv import load_dotenv
# .ENV配置读取
load_dotenv()
# 读取DEBUG状态
DEBUG = os.getenv('DJANGO_DEBUG') in ['True', 'true', '1', 'yes', 'y']  

# 也可以读取一些KEY
# 和风天气KEY
WEATHER_KEY = os.getenv('WEATHER_KEY')

配置完成

简单几步就配置完成了,环境配置管理还是非常简单好用的,要注意的是首次使用dotenv后别忘了生产环境也要安装上python-dotenv

数据库区分

上面讲到了在settings.py中获取env配置,那么最简单的办法就根据env中的Debug配置,写个if判断就好

python 复制代码
DATABASES = {
    'default': {
        # 开发环境数据库
     		'ENGINE': 'django.db.backends.mysql',
        'NAME': '****-dev',
        'USER': '****',
        'PASSWORD': '****',
        'HOST': '******',
        'PORT': '***'
    } if DEBUG else {
        # 生产环境
     		'ENGINE': 'django.db.backends.mysql',
        'NAME': '****-prod',
        'USER': '****',
        'PASSWORD': '****',
        'HOST': '******',
        'PORT': '***'
    },
}

数据库路由实现

实际上大部分情况都用不上数据库路由,如果只是根据环境区分数据库,只需要settings.py中加个if判断就好了。下面的内容看看就好,搞不好哪天用到了呢

settings.py

python 复制代码
DATABASES = {
    # 开发环境数据库
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '****-dev',
        'USER': '****',
        'PASSWORD': '****',
        'HOST': '******',
        'PORT': '***'
    },
    # 生产环境数据库
    'prodDB': {
     		'ENGINE': 'django.db.backends.mysql',
        'NAME': '****-prod',
        'USER': '****',
        'PASSWORD': '****',
        'HOST': '******',
        'PORT': '***'
    },
}
# 注册数据库路由
DATABASE_ROUTERS = ['database_routers.DatabaseRouter']

在项目根目录创建database_routers.py

python 复制代码
from django.conf import settings
"""
这里能实现很多,目前只是实现了区分生产/开发数据库这个最简单的功能
"""
class DatabaseRouter:
    def db_for_read(self, model, **hints):
        if settings.DEBUG:
            return 'default'
        return 'prodDB'

    def db_for_write(self, model, **hints):
        if settings.DEBUG:
            return 'default'
        return 'prodDB'

    def allow_relation(self, obj1, obj2, **hints):
        return True

    def allow_migrate(self, db, app_label, model_name=None, **hints):
        return True

本人源站原文链接点这里

相关推荐
小生凡一4 分钟前
redis 大key、热key优化技巧|空间存储优化|调优技巧(一)
数据库·redis·缓存
oe10194 分钟前
好文与笔记分享 A Survey of Context Engineering for Large Language Models(上)
数据库·笔记·语言模型·agent·上下文工程
小马哥编程7 分钟前
【软考架构】案例分析-对比MySQL查询缓存与Memcached
java·数据库·mysql·缓存·架构·memcached
一 乐9 分钟前
高校后勤报修系统|物业管理|基于SprinBoot+vue的高校后勤报修系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·毕设
极客数模14 分钟前
2025年(第六届)“大湾区杯”粤港澳金融数学建模竞赛准备!严格遵循要求,拿下大奖!
大数据·python·数学建模·金融·分类·图论·boosting
倔强青铜三28 分钟前
苦练Python第73天:玩转对象持久化,pickle模块极速入门
人工智能·python·面试
折翼的恶魔36 分钟前
SQL190 0级用户高难度试卷的平均用时和平均得分
java·数据库
程序员三藏1 小时前
Postman持久化保存/设置断言详解
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
煎蛋学姐1 小时前
SSM基于框架在线电影评论投票系统3gr0f(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·系统开发·ssm 框架·在线电影评论投票系统
java1234_小锋1 小时前
PyTorch2 Python深度学习 - 卷积神经网络(CNN)介绍实例 - 使用MNIST识别手写数字示例
python·深度学习·cnn·pytorch2