华为云NFS使用API删除大文件目录

最近在使用华为云SFS时,如果一个目录存储文件数超过100W,执行 "rm -rf path"时,存在删不动的情况,可以使用华为云API接口,执行异步删除。

华为官网:

删除文件系统目录_弹性文件服务 SFS_API参考_SFS Turbo API说明_目录管理_华为云删除文件系统目录在2023年6月1号之后创建的文件系统支持该API操作。 警告:该API为删除文件系统子目录数据的高危操作,删除后无法恢复,使用前请确认下发的文件系统目录是否正确。您可以在API Explorer中调试该接口,支持自动认证鉴权。API Explorer可以自动生成SDK代码示例,并提供SDK代码示例调试功能。DELETE https://support.huaweicloud.com/api-sfs/DeleteFsDir.html

实现代码:

java 复制代码
import com.huaweicloud.sdk.core.auth.ICredential;
import com.huaweicloud.sdk.core.auth.BasicCredentials;
import com.huaweicloud.sdk.core.exception.ConnectionException;
import com.huaweicloud.sdk.core.exception.RequestTimeoutException;
import com.huaweicloud.sdk.core.exception.ServiceResponseException;
import com.huaweicloud.sdk.sfsturbo.v1.region.SFSTurboRegion;
import com.huaweicloud.sdk.sfsturbo.v1.*;
import com.huaweicloud.sdk.sfsturbo.v1.model.*;


/**
 * TODO 删除NFS文件系统目录,高危险操作,务必谨慎执行!!!
 * TODO 删除NFS文件系统目录,高危险操作,务必谨慎执行!!!
 * TODO 删除NFS文件系统目录,高危险操作,务必谨慎执行!!!
 *
 *
 * @author XHH
 */
public class DeleteFsDirSolution {

    public static void main(String[] args) {

        String ak = "<Your AK>";
        String sk = "<Your SK>";

        String pathStr = "<Your Path>";
        String shareId = "<文件系统ID>";

        // 删除
        delFsDir(ak, sk, shareId, pathStr);
    }
    private static void delFsDir(String ak, String sk, String shareId, String pathStr) {

        ICredential auth = new BasicCredentials().withAk(ak).withSk(sk);
        SFSTurboClient client = SFSTurboClient.newBuilder()
                .withCredential(auth)
                .withRegion(SFSTurboRegion.valueOf("cn-southwest-2"))
                .build();
        DeleteFsDirRequest request = new DeleteFsDirRequest();
        request.withShareId(shareId);
        DeleteFsDirRequestBody body = new DeleteFsDirRequestBody();
        body.withPath(pathStr);
        request.withBody(body);

        System.out.println("删除路径: " +pathStr);
        try {
            DeleteFsDirResponse response = client.deleteFsDir(request);
            System.out.println("response ===> " + response.toString());
        } catch (ConnectionException | RequestTimeoutException e) {
            e.printStackTrace();
        } catch (ServiceResponseException e) {
            e.printStackTrace();
            System.out.println("删除路径: " +pathStr+ " --> HttpStatusCode:" + e.getHttpStatusCode() + " --> RequestId:" + e.getRequestId() + " --> ErrorMsg:" + e.getErrorMsg());
        }

    }


}
相关推荐
Byron__几秒前
HashMap面试知识点
java·面试·hash
诺浅24 分钟前
聊聊@DSTransactional的坑
java·多数据源·dstransavtional
菜鸟‍25 分钟前
【后端项目】苍穹外卖day01-开发环境搭建
java·开发语言·spring boot
lzksword29 分钟前
C++ Builder XE OpenDialog1打开多文件并显示xls与xlsx二种格式文件
java·前端·c++
深圳市恒讯科技30 分钟前
云服务器怎么选?从CPU、内存到IOPS的零基础选型手册
运维·服务器
青槿吖35 分钟前
【保姆级教程】Spring事务控制通关指南:XML+注解双版本,避坑指南全奉上
xml·java·开发语言·数据库·sql·spring·mybatis
mygljx1 小时前
spring-ai 下载不了依赖spring-ai-openai-spring-boot-starter
java·人工智能·spring
jaysee-sjc1 小时前
【练习十二】Java实现年会红包雨小游戏
java·开发语言·算法·游戏·intellij-idea
indexsunny1 小时前
互联网大厂Java求职面试实战:核心技术与业务场景解析
java·spring boot·redis·微服务·kafka·互联网大厂·面试技巧
小涛不学习1 小时前
Java 后端核心框架面试题(Spring / SpringMVC / MyBatis / MyBatis-Plus)
java·spring·mybatis