Django如何配置多个环境的MySQL数据库

news/2024/11/23 23:46:20/

在 Django 项目中配置多个环境的 MySQL 数据库是一个常见的需求,特别是在开发、测试和生产环境中使用不同的数据库配置。你可以通过在 settings.py 文件中使用条件语句或环境变量来实现这一点。

1. 使用环境变量

使用环境变量是一种灵活且安全的方式来配置多个环境的数据库。你可以使用 django-environ 库来简化环境变量的管理。

djangoenviron_6">安装 django-environ

首先,安装 django-environ 库:

pip install django-environ
配置 settings.py

编辑 settings.py 文件,使用 environ 来读取环境变量:

python"># myproject/settings.pyimport environ# 初始化环境变量
env = environ.Env()
environ.Env.read_env()# 数据库配置
DATABASES = {'default': env.db('DATABASE_URL', default='mysql://root:password@localhost:3306/dbname')
}# 其他配置
DEBUG = env.bool('DEBUG', default=False)
SECRET_KEY = env('SECRET_KEY')
ALLOWED_HOSTS = env.list('ALLOWED_HOSTS', default=['localhost'])
设置环境变量

在不同的环境中设置相应的环境变量。你可以在 .env 文件中设置这些变量,或者在操作系统中直接设置。

.env 文件示例

在项目根目录下创建一个 .env 文件,并添加以下内容:

# 开发环境
DEBUG=True
SECRET_KEY=your_secret_key_for_development
ALLOWED_HOSTS=localhost,127.0.0.1
DATABASE_URL=mysql://root:password@localhost:3306/dev_db# 测试环境
# DEBUG=False
# SECRET_KEY=your_secret_key_for_testing
# ALLOWED_HOSTS=localhost,127.0.0.1
# DATABASE_URL=mysql://root:password@localhost:3306/test_db# 生产环境
# DEBUG=False
# SECRET_KEY=your_secret_key_for_production
# ALLOWED_HOSTS=yourdomain.com
# DATABASE_URL=mysql://root:password@10.177.111.228:3306/ostp
操作系统环境变量

你也可以在操作系统的环境变量中设置这些值。例如,在 Linux 或 macOS 上,你可以在终端中运行:

export DEBUG=True
export SECRET_KEY=your_secret_key_for_development
export ALLOWED_HOSTS=localhost,127.0.0.1
export DATABASE_URL=mysql://root:password@localhost:3306/dev_db

Windows批处理

在bat脚本中设置了
@echo off
chcp 65001
echo "设置数据库运行环境为开发环境"
set DEBUG=True
set SECRET_KEY=123456
set ALLOWED_HOSTS=localhost,127.0.0.1
set DATABASE_URL=mysql://root:123456@localhost:3306/test

2. 使用多个 settings 文件

另一种方法是为每个环境创建一个单独的 settings 文件。这种方式更加直观,但可能会导致更多的文件管理。

创建多个 settings 文件

myproject 目录下创建以下文件:

  • settings_base.py:基础配置
  • settings_dev.py:开发环境配置
  • settings_test.py:测试环境配置
  • settings_prod.py:生产环境配置
settings_base.py
python"># myproject/settings_base.pyimport os# 基础配置
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
SECRET_KEY = 'your_default_secret_key'
ALLOWED_HOSTS = []INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles',# 你的应用'myapp',
]MIDDLEWARE = ['django.middleware.security.SecurityMiddleware','django.contrib.sessions.middleware.SessionMiddleware','django.middleware.common.CommonMiddleware','django.middleware.csrf.CsrfViewMiddleware','django.contrib.auth.middleware.AuthenticationMiddleware','django.contrib.messages.middleware.MessageMiddleware','django.middleware.clickjacking.XFrameOptionsMiddleware',
]ROOT_URLCONF = 'myproject.urls'TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [],'APP_DIRS': True,'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',],},},
]WSGI_APPLICATION = 'myproject.wsgi.application'# 静态文件配置
STATIC_URL = '/static/'
settings_dev.py
python"># myproject/settings_dev.pyfrom .settings_base import *# 开发环境配置
DEBUG = True
SECRET_KEY = 'your_secret_key_for_development'
ALLOWED_HOSTS = ['localhost', '127.0.0.1']
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'dev_db','USER': 'root','PASSWORD': 'password','HOST': 'localhost','PORT': '3306',}
}
settings_test.py
python"># myproject/settings_test.pyfrom .settings_base import *# 测试环境配置
DEBUG = False
SECRET_KEY = 'your_secret_key_for_testing'
ALLOWED_HOSTS = ['localhost', '127.0.0.1']
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'test_db','USER': 'root','PASSWORD': 'password','HOST': 'localhost','PORT': '3306',}
}
settings_prod.py
python"># myproject/settings_prod.pyfrom .settings_base import *# 生产环境配置
DEBUG = False
SECRET_KEY = 'your_secret_key_for_production'
ALLOWED_HOSTS = ['yourdomain.com']
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'ostp','USER': 'root','PASSWORD': 'ostp','HOST': '10.177.111.228','PORT': '3306',}
}
配置 manage.pywsgi.py

manage.pywsgi.py 中指定使用哪个 settings 文件。

manage.py
python">#!/usr/bin/env python
import os
import sysif __name__ == "__main__":os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings_dev')  # 根据需要切换环境try:from django.core.management import execute_from_command_lineexcept 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 excexecute_from_command_line(sys.argv)
wsgi.py
python">import os
from django.core.wsgi import get_wsgi_applicationos.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings_prod')  # 根据需要切换环境
application = get_wsgi_application()

总结

通过使用环境变量或多个 settings 文件,你可以在 Django 项目中轻松地配置多个环境的 MySQL 数据库。选择哪种方法取决于你的具体需求和团队的工作流程。使用环境变量可以提供更好的灵活性和安全性,而使用多个 settings 文件则更加直观和易于管理。


http://www.ppmy.cn/news/1549398.html

相关文章

【SQL Server】华中农业大学空间数据库实验报告 实验三 数据操作

1.实验目的 熟悉了解掌握SQL Server软件的基本操作与使用方法,以及通过理论课学习与实验参考书的帮助,熟练掌握使用T-SQL语句和交互式方法对数据表进行插入数据、修改数据、删除数据等等的操作;作为后续实验的基础,根据实验要求重…

云平台使用常见场景解决方法清单

面向对象 以下是一份针对云平台租户运维人员在面对云主机故障、磁盘扩容等常见场景时的解决方法清单,所有教程仅供参考 强烈建议先在测试环境操作熟练再去生产环境操作 强烈建议先在测试环境操作熟练再去生产环境操作 强烈建议先在测试环境操作熟练再去生产环境操作…

wsl虚拟机中的dockers容器访问不了物理主机

1 首先保证wsl虚拟机能够访问宿主机IP地址,wsl虚拟机通过vEthernet (WSL)的地址访问,着意味着容器也要通过此IP地址访问物理主机。 2 遇到的问题:wsl虚拟机中安装了docker,用在用到docker容器内的开发环境,但是虚拟机…

uni-app 认识条件编译,了解多端部署

一. 前言 在使用 uni-app 进行跨平台开发的过程中,经常会遇到需要针对不同平台或不同环境进行条件编译的情况。条件编译是一种在编译过程中根据指定条件选择不同代码路径的技术,可以帮助我们在不同平台或环境下编写不同的代码,以适应不同的平…

Spring Boot 教程之六:Spring Boot - 架构

Spring Boot - 架构 Spring Boot建立在核心Spring框架之上。它是 Spring 框架的简化和自动化版本。Spring Boot 遵循分层架构,其中每一层都与其他层(按层次顺序位于上方或下方)进行通信。Spring Boot 文档为 Spring Boot 框架提供了以下定义。…

Spring 与 Spring MVC 与 Spring Boot三者之间的区别与联系

一.什么是Spring?它解决了什么问题? 1.1什么是Spring? Spring,一般指代的是Spring Framework 它是一个开源的应用程序框架,提供了一个简易的开发方式,通过这种开发方式,将避免那些可能致使代码…

经验笔记:git checkout 与 git switch

Git Checkout 与 Git Switch 引言 在使用 Git 进行版本控制时,git checkout 和 git switch 是两个常用的命令,用于分支管理和文件恢复。虽然它们有一些相似之处,但各自的功能和使用场景有所不同。本文将详细介绍这两个命令的用法、区别和实…

中国【食品检测实验室自动化】程度相对欧美等发达国家相对落后,并且技术层面存在明显的代差,未来有比较大的发展空间

摘要 根据 HengCe 研究团队调研统计,2023年全球食品检测实验室自动化市场销售额达到了 亿元,预计2030年将达到 亿元,年复合增长率(CAGR)为 %(2024-2030)。中国市场在过去几年变化较快&#xff…