在渲染上部署 Django 应用程序

在渲染上部署 django 应用程序

如果您希望 Django 应用程序将图像(或其他媒体文件)存储在 Amazon S3 存储桶中,请按照以下详细步骤在 Render 上集成和部署您的 Django 项目,同时确保媒体文件的无缝 S3 存储。

第 1 步:准备部署 Django 项目

1.1 确保列出所有依赖项

创建一个包含所有项目依赖项的requirements.txt 文件:

pip freeze >requirements.txt

确保包含这些附加包:

boto3:适用于 Python 的 AWS 开发工具包,用于与 S3 交互。

django-storages:将 Django 与 AWS S3 集成。

pip install boto3 django-storages

1.2 创建Procfile

在项目的根目录中创建一个 Procfile 来指定如何运行应用程序:

网络:gunicorn myproject.wsgi:application

将 myproject 替换为您的 Django 项目的名称。

1.3 配置媒体文件以使用 Amazon S3

更新您的 settings.py 以包含以下配置:

设置.py

INSTALLED_APPS += ['存储']

AWS S3 配置

AWS_ACCESS_KEY_ID = os.getenv('AWS_ACCESS_KEY_ID')
AWS_SECRET_ACCESS_KEY = os.getenv('AWS_SECRET_ACCESS_KEY')
AWS_STORAGE_BUCKET_NAME = os.getenv('AWS_STORAGE_BUCKET_NAME')
AWS_S3_REGION_NAME = os.getenv('AWS_S3_REGION_NAME')
AWS_S3_CUSTOM_DOMAIN = f'{AWS_STORAGE_BUCKET_NAME}.s3.amazonaws.com'

媒体文件(图像等)将存储在S3上

DEFAULT_FILE_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
MEDIA_URL = f'https://{AWS_S3_CUSTOM_DOMAIN}/media/'

可选:配置要从 S3 提供的静态文件

STATICFILES_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
STATIC_URL = f'https://{AWS_S3_CUSTOM_DOMAIN}/static/'

确保安装了 boto3 和 django-storages

此配置可确保通过 Django 上传的任何文件(例如,用户个人资料图片、产品图像)将直接存储在 Amazon S3 上。

1.4 配置允许的主机

将您的渲染服务 URL 添加到 settings.py 中的 ALLOWED_HOSTS:

ALLOWED_HOSTS = ['your-django-backend-url.onrender.com']

1.5 数据库配置

如果使用 Render 提供的 PostgreSQL,请更新您的数据库设置:

导入 dj_database_url

数据库 = {
‘默认’: dj_database_url.config(conn_max_age=600)
}

确保 dj-database-url 已在您的 requests.txt 中列出。

1.6 安全设置

设置您的生产就绪设置:

调试=假

确保正确配置 SECURE_SSL_REDIRECT、CSRF_COOKIE_SECURE、SESSION_COOKIE_SECURE 等安全设置。

DJANGO_SECRET_KEY 和其他敏感数据使用环境变量。

第2步:创建渲染配置文件

创建 render.yaml 文件:

服务:

  • 类型:网络 名称: my-django-app 环境:蟒蛇 build命令:pip install -rrequirements.txt 启动命令:gunicorn myproject.wsgi:application 环境变量:
    • 键:DATABASE_URL 来自数据库: 名称:我的数据库
    • 密钥:AWS_ACCESS_KEY_ID 同步:假
    • 密钥:AWS_SECRET_ACCESS_KEY 同步:假
    • 键:AWS_STORAGE_BUCKET_NAME 同步:假
    • 键:AWS_S3_REGION_NAME 同步:假
    • 密钥:DJANGO_SECRET_KEY 同步:假
    • 键:ALLOWED_HOSTS 值:'your-django-backend-url.onrender.com'

第 3 步:设置 Amazon S3 存储桶

3.1 创建 S3 存储桶

登录您的 AWS 管理控制台。

导航到 S3 并单击创建存储桶。

设置唯一的存储桶名称(例如 my-django-media-bucket)。

选择区域并配置权限(确保允许对象的读取权限)。

3.2 创建 IAM 用户以访问 S3

转到 AWS 控制台中的 IAM 并创建一个新用户。

分配 AmazonS3FullAccess 或创建具有所需权限的自定义策略。

生成访问密钥(您需要这些密钥作为 AWS_ACCESS_KEY_ID 和 AWS_SECRET_ACCESS_KEY)。

第 4 步:将代码推送到 GitHub

4.1 初始化Git并推送代码

git 初始化
git add .
git commit -m“渲染部署的初始提交”
git 远程添加源 https://github.com/yourusername/your-repo-name.git
git push -u origin master

第 5 步:部署到渲染

5.1 在渲染上创建新的 Web 服务

转到 Render 的仪表板,单击新建 → Web 服务。

连接您的 GitHub 存储库。

5.2 配置服务设置

选择要部署的分支(通常是 master 或 main)。

Render 将检测您的 render.yaml 文件并设置服务。

5.3 设置环境变量

转到渲染仪表板中的“环境”选项卡:

添加以下环境变量:

DATABASE_URL:如果您创建了 PostgreSQL 数据库,渲染器将生成此内容。

AWS_ACCESS_KEY_ID:来自您的 IAM 用户凭证。

AWS_SECRET_ACCESS_KEY:来自您的 IAM 用户凭证。

AWS_STORAGE_BUCKET_NAME:您的 S3 存储桶名称。

AWS_S3_REGION_NAME:您的 S3 存储桶所在的区域。

DJANGO_SECRET_KEY:安全的随机字符串。

ALLOWED_HOSTS:您的渲染服务 URL。

第 6 步:运行迁移和测试

6.1 部署服务

单击“创建 Web 服务”。 Render 将构建并部署您的 Django 应用程序。监视日志是否有任何错误。

6.2 部署后:运行数据库迁移

服务部署后,登录您的 Render 服务 shell 并运行:

python 管理.py 迁移

6.3 验证媒体文件上传

测试通过 Django 应用程序上传图像或媒体文件。确保它们正确存储在 S3 存储桶中并可通过 URL 访问。

附加说明:

CORS 配置:确保您的 S3 存储桶具有正确的 CORS 配置,以允许从前端进行访问。

文件权限:确保上传到 S3 的文件具有公共读取权限(如有必要,调整 S3 存储桶策略)。

结论:

本详细指南提供了在 Render 上部署 Django 应用程序的必要步骤,确保媒体文件无缝存储在 Amazon S3 上。此设置提高了可扩展性并减轻了 Web 服务器的静态/媒体文件处理负担,使您的应用程序更加高效且可用于生产。

以上就是在渲染上部署 Django 应用程序的详细内容,更多请关注其它相关文章!