使用minio 实现分布式文件上传

前言

由于项目业务发展,文件上传直接保存到服务器的弊端越来越多。后面采用了分布式的文件上传,因为是内网的,所以上网找了很久,发现minio这个开源分布式文件系统。但是收不收费还不确定。后面去网上查了一下,minio 近两年协议换成了GUN AGPL v3。然后我又去搜了一下,这个协议想要免费使用,就得把自己的项目也开源。否则要么乖乖交钱,要么吃官司。

后边在网上找到了 apache 协议的 minio 。这下终于不收费了

找到了之后,直接下载压缩包,或者使用命令下载镜像

bash 复制代码
docker pull minio/minio:RELEASE.2021-02-01T22-56-52Z

下载完成后,使用命令将minio 启动,其中 -v 是将mino 的文件存放映射到服务器本机,而不是直接放在docker 容器里

bash 复制代码
docker run -d -p 9000:9000 -e "MINIO_ROOT_USER=root" -e "MINIO_ROOT_USER=nk@123456" -v F:\miniodata:/data   minio/minio:RELEASE.2021-02-01T22-56-52Z server /data

使用设置好的账号密码登陆

现在minio 成功启动,在代码中添加minio 的包。

添加完成后,注入minio

cs 复制代码
   //链接分布式文件系统

           services.AddSingleton(x => new MinioClient("ip地址:9000", "root", "nk@123456"));

代码

cs 复制代码
private readonly MinioClient _minioClient;
  
         public FileService(MinioClient minioClient)
        {
            _minioClient = minioClient; 
        }
         /// <summary>
        /// 存储桶名称
        /// </summary>
        private const string BucketName = "nk5";
        
        //将文件上传到minio
          public async Task<List<string>> UploadFileAsync(List<IFormFile> files)
        {
            // 验证文件是否存在
            (files.Count == 0).ThrowExceptionByResult("文件不能为空");

            var list = new List<string>();

            //校验桶是否存在,不存在则创建一个桶
            if (!await _minioClient.BucketExistsAsync(BucketName))
            {
                await _minioClient.MakeBucketAsync(BucketName);
            }

            foreach (var file in files)
            {
                // 上传文件到MinIO
                await using var stream = file.OpenReadStream();
                list.Add(file.FileName);
                await _minioClient.PutObjectAsync(BucketName, file.FileName, stream, stream.Length, file.ContentType);
            }
            return list;
        }
        //根据指定桶的文件名获取文件
        public async Task<MemoryStream> DownloadFileAsync(string fileName)
        {
            (!await _minioClient.BucketExistsAsync(BucketName)).ThrowExceptionByResult("未找到存储桶");

            try
            {
                var dataStream = new MemoryStream();
                await _minioClient.GetObjectAsync(BucketName, fileName, (stream) =>
                {
                    stream.CopyTo(dataStream);
                });

                dataStream.Position = 0;
                return dataStream;
            }
            catch (Exception ex)
            {
                throw new Exception("文件下载时,出现错误,请检查文件服务器");
            }
        }

调用文件上传后,去文件服务器查看

相关推荐
暖馒1 小时前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
刘欣的博客5 小时前
C# CS架构程序发版升级的走数据库方案
c#·单文件升级自己的方式
Yorlen_Zhang6 小时前
Python Tkinter Text 控件完全指南:从基础编辑器到富文本应用
开发语言·python·c#
不绝1916 小时前
C#进阶:预处理指令/反射,Gettype,Typeof/关键类
开发语言·c#
大鹏说大话7 小时前
告别 MSBuild 脚本混乱:用 C# 和 Nuke 构建清晰、可维护的现代化构建系统
开发语言·c#
czhc11400756638 小时前
通信 28
c#
bugcome_com12 小时前
C# 程序结构详解:从 Hello World 开始
c#
唐梓航-求职中12 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
bugcome_com15 小时前
阿里云 OSS C# SDK 使用实践与参数详解
阿里云·c#
懒人咖1 天前
缺料分析时携带用料清单的二开字段
c#·金蝶云星空