将Minio设置为Django的默认Storage(django-storages)

这里写自定义目录标题

  • 前置说明
    • 静态文件
    • 收集静态文件
  • 使用django-storages来使Django集成Minio
    • 安装依赖
    • settings.py
    • 测试收集静态文件
    • 测试媒体文件

前置说明

静态文件

Django默认的Storage是本地,项目中的CSS、图片、JS都是静态文件。一般会将静态文件放到一个单独的目录中,以方便管理。在html页面中调用时,也需要指定静态文件的路径,Django中提供了一种解析的方式配置静态文件的路径。静态文件可以放在项目根目录下,也可以放在子应用的目录下,由于有些静态文件在项目中是通用的,所以推荐放在项目的根目录下,方便管理。
为了提供静态文件,需要配置两个参数:

  • STATICFILES_DIRS=[]:存放查找静态文件的目录,接收的是list;
  • STATIC_URL:访问静态文件URL前缀。
# 1. 静态文件的路由
STATIC_URL = '/static/'

# 2. 访问静态文件时,会遍历列表中的文件夹,找到对应的静态文件
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static_files')]
# 配置静态文件夹路径 未来可能会有很多静态文件夹,都在这里配置

# 3.访问的地址:127.0.0.1:8000/static/xxxx

在生产环境下,即Debug=False时,Django将不再对外提供静态文件,而需要使用collectstatic命令收集静态文件并交由静态文件服务器来提供服务。

收集静态文件

我们需要收集项目中的静态文件,并放到静态文件服务器中,一般使用Nginx服务器作为静态文件服务器。
在settings.py中设置收集静态文件的目录

# 这是Django默认存储的配置,下面使用Minio就用不到这个配置了
STATIC_ROOT = os.path.join(os.path.dirname(BASE_DIR), 'staticfiles')

执行收集静态文件命令,该命令会将项目中所有的静态文件复制到第一步建的目录下。

python manage.py collectstatic

使用django-storages来使Django集成Minio

安装依赖

为什

你可能感兴趣的:(Django,django,python,minio,django-storages)