【Java】对Minio指定Bucket大量文件的批量下载与本地文件夹的批量上传

这篇具有很好参考价值的文章主要介绍了【Java】对Minio指定Bucket大量文件的批量下载与本地文件夹的批量上传。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

需求

需要批量下载一个bucket下的内容,bucket下文件有19GB+,且文件夹结构复杂,使用官方的Console无法完成这么大量文件的下载,而且也不支持文件夹的分享,所以自己写个工具下载,顺便把上传的也写了。

minio 批量下载,探索与尝试,Java,java,Minio,对象存储,上传下载

使用官方的打包下载,由于文件太多,一直转,而且session一失效,或者刷新页面,就得重来!

minio 批量下载,探索与尝试,Java,java,Minio,对象存储,上传下载

所以官方这个下载,只适合少量文件的打包下载。

批量下载

代码

核心逻辑就是递归,遇到文件夹就继续找文件,遇到文件就下载。

package cn.xdf.xadd.rmq.test;

import io.minio.GetObjectArgs;
import io.minio.ListObjectsArgs;
import io.minio.MinioClient;
import io.minio.Result;
import io.minio.messages.Item;
import org.apache.commons.io.FileUtils;

import java.io.File;
import java.io.InputStream;

/**
 * 批量下载工具
 *
 * @author zhurunhua
 * @date 2023/06/16 3:28 下午
 */
public class BatchDownloadUtil {

    private static final String ENDPOINT = "http://minio:80";
    private static final String ACCESS_KEY = "ak";
    private static final String SECRET_KEY = "sk";
    private static final String BUCKET_NAME = "milvus-t-backup-all";
    private static final String ROOT_PATH = "files/tiku_backup/";
    private static final String LOCAL_DIR = "/Users/xdf/Downloads";

    static MinioClient minioClient = MinioClient.builder().endpoint(ENDPOINT).credentials(ACCESS_KEY, SECRET_KEY).build();

    public static void main(String[] args) throws Exception {
        ListObjectsArgs listObjectsArgs = ListObjectsArgs.builder().bucket(BUCKET_NAME).prefix(ROOT_PATH).build();
        findAndSaveFile(listObjectsArgs);
    }

    private static void findAndSaveFile(ListObjectsArgs listObjectsArgs) throws Exception {
        // List all objects in the bucket
        Iterable<Result<Item>> results = minioClient.listObjects(listObjectsArgs);
        for (Result<Item> result : results) {
            Item item = result.get();
            if (item.isDir()) {
                System.out.println("文件夹:" + item.objectName());
                ListObjectsArgs args = ListObjectsArgs.builder().bucket(BUCKET_NAME).prefix(item.objectName()).build();
                findAndSaveFile(args);
            } else {
                GetObjectArgs getObjectArgs = GetObjectArgs.builder().bucket(BUCKET_NAME).object(item.objectName()).build();
                String objectName = item.objectName();
                // Create a local file with the same name as the object
                File file = new File(LOCAL_DIR + File.separator + objectName);
                // Create parent directories if needed
                file.getParentFile().mkdirs();
                // Get the object as an input stream
                try (InputStream stream = minioClient.getObject(getObjectArgs)) {
                    // Copy the input stream to the file
                    FileUtils.copyInputStreamToFile(stream, file);
                }
                System.out.printf("文件:%s 下载成功!\n", item.objectName());
            }
        }
    }
}

效果

minio 批量下载,探索与尝试,Java,java,Minio,对象存储,上传下载

批量上传

代码

package cn.xdf.xadd.rmq.test;

import io.minio.MinioClient;
import io.minio.UploadObjectArgs;

import java.io.File;

/**
 * @author zhurunhua
 * @since 2023/06/16 3:31 下午
 */
public class BatchUploadUtil {

    private static final String ENDPOINT = "http://minio:80";
    private static final String ACCESS_KEY = "ak";
    private static final String SECRET_KEY = "sk";
    private static final String BUCKET_NAME = "milvus-chatglm";
    private static final String PARENT_PATH = "/Users/xdf/Desktop/Temp/";
    private static final String FILE_PATH = "audio";
    private static final String IGNORE_FILE = ".DS_Store";

    static MinioClient minioClient = MinioClient.builder().endpoint(ENDPOINT).credentials(ACCESS_KEY, SECRET_KEY).build();

    public static void main(String[] args) throws Exception {
        // 创建一个 File 对象,指定要遍历的目录的路径
        File dir = new File(PARENT_PATH + FILE_PATH);
        listFileAndUpload(dir);
    }

    public static void listFileAndUpload(File dir) throws Exception {
        // 调用 listFiles 方法获取该目录中的所有文件
        File[] files = dir.listFiles();
        // 遍历文件数组
        for (File file : files) {
            // 判断是否为文件,如果是就打印出绝对路径
            if (file.isFile()) {
                if (!file.getName().equals(IGNORE_FILE)) {
                    uploadFile(file.getAbsolutePath());
                    System.out.printf("文件:%s 上传完成!\n", file.getAbsolutePath());
                }
            } else {
                System.out.println("文件夹:" + file.getAbsolutePath());
                // 如果是目录,就递归调用 listFiles 方法,继续遍历子目录
                listFileAndUpload(file);
            }
        }
    }

    /**
     * eg.
     * 本地文件路径:/Users/xdf/Downloads/files/tiku_backup/meta/partition_meta.json
     * 上传后:/bucket_name/files/tiku_backup/meta/partition_meta.json
     * 即把本地文件前缀去掉,保留指定目录
     */
    private static void uploadFile(String filePath) throws Exception {
        UploadObjectArgs uploadObjectArgs = UploadObjectArgs.builder().bucket(BUCKET_NAME)
                .object(filePath.substring(PARENT_PATH.length()))
                .filename(filePath)
                .build();
        minioClient.uploadObject(uploadObjectArgs);
    }
}

效果

上传后,保留了文件的目录结构

minio 批量下载,探索与尝试,Java,java,Minio,对象存储,上传下载

minio 批量下载,探索与尝试,Java,java,Minio,对象存储,上传下载
完工!文章来源地址https://www.toymoban.com/news/detail-703437.html

到了这里,关于【Java】对Minio指定Bucket大量文件的批量下载与本地文件夹的批量上传的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • java minio通过getPresignedObjectUrl设置(自定义)预签名URL下载文件的响应文件名之minio源码改造方案

    用户上传文件到Minio时,一般存储在Minio中的对象名称都是后端以UUID或者其他随机或非随机方案生成的唯一标识做为文件名,这个对象名称一般都不会是用户上传时的原文件名称。 在用户下载时,想让文件流不通过后端服务器,而是用户直接申请并使用某个要下载对象的Min

    2024年01月25日
    浏览(64)
  • PowerShell批量修改、替换大量文件的文件名

      本文介绍基于 PowerShell 语言,对文件夹中全部文件的名称加以 批量 替换、修改的方法。   在之前的文章基于Python一次性批量修改多个文件的文件名(https://blog.csdn.net/zhebushibiaoshifu/article/details/115869725)中,我们介绍了基于 Python 语言,批量修改大量文件的名称的方法。

    2024年02月01日
    浏览(63)
  • java 批量下载文件 打包成zip包

    创建DownLoadUrlStream承载数据 创建工具类,进行zip包压缩 封装数据,调用方法即可

    2024年02月12日
    浏览(40)
  • java下载指定文件并返回给前端返回流文件

    java下载返回文件流的实现 作为一名经验丰富的开发者,我将教会你如何实现Java下载返回文件流的功能。在这篇文章中,我将分为以下几个部分来详细介绍这个过程: 1.简介 2.实现步骤 3.代码示例 4.总结 在Java开发中,有时候我们需要实现文件下载功能,并且将文件以流的形

    2024年03月15日
    浏览(72)
  • 根据若依系统+minio实现批量下载附件并自动压缩成zip

    效果实现:   分割!!!! 以下代码参考于 http://t.csdn.cn/4dUmDwg 话不多说 直接从后端开始 0.首先是pom依赖 1.后端Controller ids和tableName为我业务需要(主要是查询数据库的附件表) 2.Service实现层 需要各位自己搜索minio关于下载的代码 也就是获取图片的inputStream流(因为各自代码逻辑不同

    2024年02月09日
    浏览(57)
  • springboot 本地/minio 附件下载优化

    本地上传大文件内存溢出 Direct buffer memory 附件下载服务端传流给前端需要将流缓存完毕才可以下载,导致大文件下载系统崩溃 后端服务采用nio本地上传到服务器指定目录,通过nginx代理提供下载 Java8出现了NIO,缓存,通道,选择器。在 写NIO程序的时候,经常使用ByteBuffer来读

    2024年02月07日
    浏览(42)
  • 实用VBA:17.大量word文件中的文本内容进行批量替换

    在工作中可能会遇到需要对大量word文件中的文字内容进行批量替换的情况。相比excel的批量处理,个人感觉word文档中由于包含大量样式信息,批处理时总感觉有顾虑。一者担心影响了文档的格式,误修改了文档的样式,那后果……整过文档的小伙伴都懂的;二者担心批处理不

    2024年01月25日
    浏览(42)
  • Java实现打包压缩文件或文件夹生成zip以实现多文件批量下载

    有时候在系统中需要一次性下载多个文件,但逐个下载文件比较麻烦。这时候,最好的解决办法是将所有文件打包成一个压缩文件,然后下载这个压缩文件,这样就可以一次性获取所有所需的文件了。 下面是一个名为CompressUtil的工具类的代码,它提供了一些方法来处理文件压

    2024年02月06日
    浏览(58)
  • SCP命令在不同远程服务器之间发送文件(指定端口、大量小文件操作)

    最近想把数据集放在另一个服务器上,但是如果先下载到本地然后再上传过去,则需要浪费好久时间。 特总结下如何快捷的通过命令完成不同远程服务器之间的文件传输,以及遇到的问题。 SCP命令 Linux scp 命令用于 Linux 之间复制文件和目录。 1 scp 是 secure copy 的缩写, scp 是

    2023年04月18日
    浏览(52)
  • SpringBoot上传文件到Minio服务器,支持批量上传

    本文主要介绍如何使用SpringBoot上传到minio服务器。 没什么可多说的,公司用什么咱们开发研究什么就完事了。直接分享核心代码。 minio依赖 配置文件 首先是核心的参数,包括服务器minio地址,以及用户名密码,使用的桶名称 controller代码 如果只需要上传文件,只需要Multipa

    2024年02月08日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包