Django 应用程序已准备好用于生产

django 应用程序已准备好用于生产

要设置满足以下要求的 Django 应用程序用于生产,您可以按照以下步骤操作:

  1. 为媒体文件配置 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'

  1. 在渲染时配置 PostgreSQL 数据库

在 Render 上设置数据库并记下连接详细信息。

安装 psycopg2 以连接 Django PostgreSQL

pip install psycopg2-binary

更新您的设置.py:

设置.py

数据库 = {
“默认”:{
'ENGINE': 'django.db.backends.postgresql',
'NAME': '您的数据库名称',
'USER': '您的数据库用户',
'PASSWORD': '您的数据库密码',
'HOST': '您的数据库主机',
'PORT': '你的数据库端口',
}
}

  1. 使用 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'

  1. 其他制作设置:

安全设置:

设置.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

  1. 在渲染器上部署:

通过连接到 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 应用程序已准备好用于生产的详细内容,更多请关注其它相关文章!