当前位置: 首页 > article >正文

将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-storages,而不使用django-storages-minio、django-minio,因为Github上的star没有django-storages多,而且PyPi上也已经没有版本迭代了,最重要的是照着资料配置,最后都没成功。django-storages好像是官方的组件。
Minio和AmazonS3的API完全兼容,所以直接使用Amazon S3的API即可,官方文档:https://django-storages.readthedocs.io/en/latest/backends/amazon-S3.html#

# 安装依赖
pip instll django-storages[s3] minio

需不需要“[s3]”没有详细的测试,多按一个包也没几兆。

settings.py

注意:桶需要自己创建好。

# 注册应用
INSTALLED_APPS = [
    # ......   
    'storages',
    # ......
]

STATIC_URL = '/static/'  # 静态文件的路由
MEDIA_URL = '/media/'  # 媒体文件的路由
STORAGES = {
    # default是媒体文件的配置
    'default': {
        "BACKEND": "storages.backends.s3.S3Storage",  # 替换Djangpo默认的Stroage
        "OPTIONS": {
            'access_key': 'root',  # Minio账号
            'secret_key': '123456',  # Minio密码
            'bucket_name': 'data-monitor', # Minio中桶名称,需要自己创建
            'file_overwrite': False,  # 同名文件是否允许覆盖
            'use_ssl': False,  # 是否使用Https,False就是使用Http
            'endpoint_url': 'http://127.0.0.1:9000',  # Minio服务地址
            # 'location': 'media'  # 指定媒体文件的MEDIA_ROOT,不指定就是桶的根目录
        },
    },
    # staticfiles是静态文件的配置
    'staticfiles': {
        "BACKEND": "storages.backends.s3.S3Storage",  # 替换Djangpo默认的Stroage
        "OPTIONS": {
            'access_key': 'root',
            'secret_key': '123456',
            'bucket_name': 'data-monitor',  # Minio中桶名称,程序不能自动创建
            'file_overwrite': False,
            'use_ssl': False,
            'endpoint_url': 'http://127.0.0.1:9000',
            'location': 'staticfiles',  # 收集静态文件到哪个目录,不指定默认在桶根目录下
        },
    },
}

测试收集静态文件

python manage.py collectstatic

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
通过静态路由访问静态文件:http://127.0.1:5002/static/admin/img/calendar-icons.svg,可以直接将文件展示出来。
在这里插入图片描述

测试媒体文件

创建一个子应用,在子应用的models.py中创建一个模型类,过程略。

class MyModel(models.Model):
    title = models.CharField(max_length=255)
    # settings中没有配置MEDIA_ROOT的路径默认就是桶的根目录
    # 这里指定的是上传到MEDIA_ROOT的哪个文件夹中,
    # 即“MEDIA_ROOT/upload_to”,路径会自动创建
    file = models.FileField(upload_to='media/')  # 加不加最后的/都可以

将模型注册到Django Admin中,在admin.py中配置

@admin.register(models.MyModel)
class MyModelAdmin(admin.ModelAdmin):
    pass

迁移模型类

python manage.py makemigrations
python manage.py migrate

访问Django Admin,找到刚才的模型类,点击Add创建一条新纪录。

在这里插入图片描述
在这里插入图片描述
去Minio上查看,自动创建了media目录,目录中多了刚才选中的文件。

在这里插入图片描述
在这里插入图片描述


http://www.kler.cn/a/452231.html

相关文章:

  • 【Linux系列】Shell 脚本中的条件判断:`[ ]`与`[[ ]]`的比较
  • vLLM (2) - 架构总览
  • 100V宽压输入反激隔离电源,适用于N道沟MOSFET或GaN或5V栅极驱动器,无需光耦合
  • Vue零基础必学教程(16) 计算属性
  • “檢測到不安全的代理”怎麼修復?
  • Mac系统下 IDEA配置Maven本地仓库
  • 深度学习中常见的权重初始化方法
  • 关于 [MenuItem] Hierarchy 右键扩展多选问题
  • linux查看天气预报
  • Canvas指定三角形内部生成随机点
  • GoFrame框架介绍
  • 宏定义介绍
  • mysql双主双从
  • 《Mycat核心技术》第06章:Mycat问题处理总结
  • 短视频矩阵系统的视频批量剪辑源码技术开发,支持OEM
  • 人工智能ACA(七)——计算机视觉基础
  • Vue3入门(8)
  • THREE.js 入门(六) 纹理、uv坐标
  • 深入探索 npm cache clean --force:清理 npm 缓存的艺术
  • Python + 深度学习从 0 到 1(03 / 99)
  • Pyside6 在 pycharm 中的配置
  • 数据库 SQL 常用语句全解析
  • 瑞吉外卖项目学习笔记(八)修改菜品信息、批量启售/停售菜品
  • Matplotlib中隐藏坐标轴但保留坐标轴标签的3D图
  • 面经zhenyq
  • 图像处理-Ch5-图像复原与重建