使用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("文件下载时,出现错误,请检查文件服务器");
            }
        }

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

相关推荐
IT技术分享社区6 小时前
C#实战:使用腾讯云识别服务轻松提取火车票信息
开发语言·c#·云计算·腾讯云·共识算法
△曉風殘月〆13 小时前
WPF MVVM入门系列教程(二、依赖属性)
c#·wpf·mvvm
逐·風14 小时前
unity关于自定义渲染、内存管理、性能调优、复杂物理模拟、并行计算以及插件开发
前端·unity·c#
m0_6569747418 小时前
C#中的集合类及其使用
开发语言·c#
九鼎科技-Leo18 小时前
了解 .NET 运行时与 .NET 框架:基础概念与相互关系
windows·c#·.net
九鼎科技-Leo20 小时前
什么是 ASP.NET Core?与 ASP.NET MVC 有什么区别?
windows·后端·c#·asp.net·mvc·.net
.net开发20 小时前
WPF怎么通过RestSharp向后端发请求
前端·c#·.net·wpf
小乖兽技术20 小时前
C#与C++交互开发系列(二十):跨进程通信之共享内存(Shared Memory)
c++·c#·交互·ipc
幼儿园园霸柒柒21 小时前
第七章: 7.3求一个3*3的整型矩阵对角线元素之和
c语言·c++·算法·矩阵·c#·1024程序员节
平凡シンプル1 天前
C# EF 使用
c#