Django 应用程序已准备好用于生产
要设置满足以下要求的 Django 应用程序用于生产,您可以按照以下步骤操作:
- 为媒体文件配置 AWS S3 存储桶:
安装 boto3 和 django-storages 以将 AWS S3 与您的 Django 应用程序集成:
pip install boto3 django-storages
更新 Django 设置 (settings.py) 以配置 AWS S3:
设置.py
AWS S3 配置
AWS_ACCESS_KEY_ID = '您的访问密钥'
AWS_SECRET_ACCESS_KEY = '您的秘密密钥'
AWS_STORAGE_BUCKET_NAME = '您的存储桶名称'
AWS_S3_REGION_NAME = 'your-region' # 例如,'us-east-1'
AWS_S3_CUSTOM_DOMAIN = f'{AWS_STORAGE_BUCKET_NAME}.s3.amazonaws.com'
媒体文件配置
MEDIA_URL = f'https://{AWS_S3_CUSTOM_DOMAIN}/media/'
DEFAULT_FILE_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
- 在渲染时配置 PostgreSQL 数据库:
在 Render 上设置数据库并记下连接详细信息。
安装 psycopg2 以连接 Django 和 PostgreSQL:
pip install psycopg2-binary
更新您的设置.py:
设置.py
数据库 = {
“默认”:{
'ENGINE': 'django.db.backends.postgresql',
'NAME': '您的数据库名称',
'USER': '您的数据库用户',
'PASSWORD': '您的数据库密码',
'HOST': '您的数据库主机',
'PORT': '你的数据库端口',
}
}
- 使用 WhiteNoise 提供静态文件:
安装 WhiteNoise 来提供静态文件:
pip 安装白噪声
更新 settings.py 中的 MIDDLEWARE 和 STATICFILES_STORAGE:
设置.py
中间件 = [
'django.middleware.security.SecurityMiddleware',
'whitenoise.middleware.WhiteNoiseMiddleware', # 在 SecurityMiddleware
之后添加此内容
# 其他中间件
]
静态文件(CSS、JavaScript、图像)
STATIC_URL = '/static/'
STATIC_ROOT = BASE_DIR / '静态文件'
白噪声配置
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
- 其他制作设置:
安全设置:
设置.py
调试=假
ALLOWED_HOSTS = ['your-domain.com', 'your-render-subdomain.onrender.com']
安全设置
SECURE_SSL_REDIRECT = True
SESSION_COOKIE_SECURE = True
CSRF_COOKIE_SECURE = True
收集静态文件:运行以下命令收集所有静态文件:
python管理.pycollectstatic
- 在渲染器上部署:
通过连接到 GitHub 存储库在 Render 上设置您的项目。
在渲染平台上为 Django 设置定义环境变量(例如 AWS_ACCESS_KEY_ID、AWS_SECRET_ACCESS_KEY、DJANGO_SECRET_KEY 等)。
配置构建和启动命令:
构建命令
pip install -r requests.txt
启动命令
gunicorn your_project_name.wsgi:application
遵循这些步骤将确保您的 Django 应用程序已做好生产准备,媒体文件托管在 AWS S3 上、Render 上的 PostgreSQL 数据库以及使用 WhiteNoise 高效提供的静态文件。
以上就是Django 应用程序已准备好用于生产的详细内容,更多请关注其它相关文章!