MinIO分布式文件系统

maven依赖

<!--minio依赖-->
<dependency>
    <groupId>io.minio</groupId>
    <artifactId>minio</artifactId>
    <version>8.4.3</version>
</dependency>
<!--HTTP依赖:底层使用okhttp库向minio服务上传文件-->
<dependency>
    <groupId>com.squareup.okhttp3</groupId>
    <artifactId>okhttp</artifactId>
    <version>4.8.1</version>
</dependency>

SDK操作-上传文件

MinioClient minioClient =
    MinioClient.builder()
    .endpoint("http://192.168.101.65:9000")//minio目标地址
    .credentials("minioadmin", "minioadmin")//minio账号密码
    .build();
//上传文件
@Test
public void upload() throws Exception {
    //通过扩展名得到媒体资源类型 mimeType
    ContentInfo extensionMatch = ContentInfoUtil.findExtensionMatch(".mp4");
    String mimeType = MediaType.APPLICATION_OCTET_STREAM_VALUE;
    if(extensionMatch != null){
        mimeType = extensionMatch.getMimeType();
    }
    UploadObjectArgs uploadObjectArgs = UploadObjectArgs.builder()
        .bucket("testbucket")//桶
        //.filename("E:\\ChangShiChao\\图片\\csc.jpg")//指定本地文件路径
        .filename("D:\\MyVido\\EV\\绝地求生两个倒霉蛋.mp4")//指定本地文件路径
        //.object("csc.jpg")//对象名。在根目录(桶)下存储该文件
        .object("test/csc.avi")//对象名。在子目录下存储该文件
        .contentType(mimeType)//设置媒体文件类型
        .build();

    minioClient.uploadObject(uploadObjectArgs);
}

SDK操作-删除文件

MinioClient minioClient =
    MinioClient.builder()
    .endpoint("http://192.168.101.65:9000")//minio目标地址
    .credentials("minioadmin", "minioadmin")//minio账号密码
    .build();
//删除文件
@Test
public void  delete() throws Exception{
    RemoveObjectArgs removeObjectArgs =
        RemoveObjectArgs.builder()
        .bucket("testbucket")//桶
        .object("test/csc.avi")//要删除文件所在位置和名称
        .build();
    minioClient.removeObject(removeObjectArgs);
}

SDK操作-查看文件

MinioClient minioClient =
    MinioClient.builder()
    .endpoint("http://192.168.101.65:9000")//minio目标地址
    .credentials("minioadmin", "minioadmin")//minio账号密码
    .build();
//查询文件  从minio中下载文件
@Test
public void getFile() throws Exception{
    GetObjectArgs getObjectArgs = GetObjectArgs.builder()
        .bucket("testbucket")
        .object("test/csc.jpg")
        .build();
    FilterInputStream inputStream = minioClient.getObject(getObjectArgs);
    FileOutputStream outputStream = new FileOutputStream(new File("E:\\ChangShiChao\\图片\\csc001.jpg"));
    IoUtils.copy(inputStream, outputStream);
    
    //下载的文件跟源码的校验(校验文件的完整性):对文件内容进行md5
    FileInputStream fileInputStream = new FileInputStream(new File("E:\\ChangShiChao\\图片\\csc.jpg"));
    String soure_md5 = DigestUtils.md5Hex(fileInputStream);
    FileInputStream fileInputStream1 = new FileInputStream(new File("E:\\ChangShiChao\\图片\\csc001.jpg"));
    String local_md5 = DigestUtils.md5Hex(fileInputStream1);
    if(soure_md5.equals(local_md5)){
        System.out.println("下载成功");
    }

minio使用准备

1.部署MinIo

//TODO:回头更新

2.配置bucket

bucket名称为:mediafiles,并设置bucket的权限为公开

bucket名称为:video,并设置bucket的权限为公开

3.yml文件中配置minio相关配置

minio:
  endpoint: http://192.168.101.65:9000
  accessKey: minioadmin
  secretKey: minioadmin
  bucket:
    files: mediafiles
    videofiles: video

4.编写minio的配置类

@Configuration
public class MinioConfig {
    @Value("${minio.endpoint}")
    private String endpoint;
    @Value("${minio.accessKey}")
    private String accessKey;
    @Value("${minio.secretKey}")
    private String secretKey;

    @Bean
    public MinioClient minioClient(){
        // Create a minioClient with the MinIO server playground, its access key and secret key.
        MinioClient minioClient =
                MinioClient.builder()
                        .endpoint(endpoint)
                        .credentials(accessKey, secretKey)
                        .build();
        return minioClient;
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值