◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
如果您希望 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 以包含以下配置:
INSTALLED_APPS += ['存储']
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'
DEFAULT_FILE_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
MEDIA_URL = f'https://{AWS_S3_CUSTOM_DOMAIN}/media/'
STATICFILES_STORAGE = 'storages.backends.s3boto3.S3Boto3Storage'
STATIC_URL = f'https://{AWS_S3_CUSTOM_DOMAIN}/static/'
此配置可确保通过 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 文件:
服务:
第 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 服务器的静态/媒体文件处理负担,使您的应用程序更加高效且可用于生产。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。