背景
用户在使用OSS服务中对于不需要的bucket在清除时候
如果存储空间不为空则存储空间无法删除,必须删除存储空间中的所有文件、未完成的分片文件、存在的livechannel以及多版本数据,存储空间才能成功删除,下面会对于这四个因素来进行介绍查看和删除的方法。
本文使用的工具ossutil来进行操作。
注意:删除数据和bucket是不可逆的操作,确认bucket没有关键数据后再进行删除
存储文件和碎片查看和删除
查看bucket数据和碎片简单的方法是可以通过控制台查看下bucket中是否有存在文件,如果有可以使用控制台删除或者是工具ossuti删除
工具ossutil删除文件和碎片并删除bucket,命令如下
./ossutil rm oss://bucket1 -bar
如果指定以上操作再删除bucket的时候还是报错bucekt不为空,无法删除则继续排查多版本。
Bucket多版本查看和删除
多版本的作用是针对数据的覆盖和删除操作将会以历史版本的形式保存下来。通过文件(Object)的版本控制,在错误覆盖或者删除Object后,能够将Bucket中存储的Object恢复至任意时刻的历史版本,但是控制台和工具查看(不指定版本号的查询)只显示最新数据,历史版本不显示的。
- 查看是否开启版本控制
2.命令查看
可以使用ousstil工具来查看
如果bucket是开启了版本控制功能,可以直接删除bucket中数据的版本数据,ossutil删除多版本命令
./ossutil rm oss://bucket1/ --all-versions -r
执行完以上操作后可以尝试删除bucket测试是否可以删除成功,如果还是报错bucket不为空,则排查bucket的Livechannel
Bucket查看和删除LiveChannel
目前对于bucket的LiveChannel查看和删除还未有工具和控制台的查看方法可以使用接口或者是SDK来实现操作,如下代码
至此涉及到所有的数据全部被清理,可以直接对于该bucket进行删除操作。
import java.util.List;
import com.alibaba.fastjson.JSON;
import com.aliyun.oss.ClientException;
import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.OSSException;
import com.aliyun.oss.model.CreateLiveChannelRequest;
import com.aliyun.oss.model.CreateLiveChannelResult;
import com.aliyun.oss.model.ListLiveChannelsRequest;
import com.aliyun.oss.model.LiveChannelGenericRequest;
import com.aliyun.oss.model.LiveChannelListing;
import com.aliyun.oss.model.LiveChannelStatus;
import com.aliyun.oss.model.LiveChannelTarget;
import com.aliyun.oss.model.LiveChannel;
public class DeleteLiveChannel {
private static String endpoint = "http://oss-cn-hangzhou.aliyuncs.com";
// 阿里云主账号 AccessKey 拥有所有 API 的访问权限,风险很高。
// 强烈建议您创建并使用 RAM 账号进行 API 访问或日常运维,请登录 https://ram.console.aliyun.com 创建 RAM 账号。
private static String accessKeyId = "xx";
private static String accessKeySecret = "xx";
private static String bucketName = "bucktname";
public static void createLiveChannel() {
// 创建 OSSClient 实例。
String liveChannelName = "liveChannelName1";
OSS oss = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
CreateLiveChannelRequest request = new CreateLiveChannelRequest(bucketName,
liveChannelName, "desc", LiveChannelStatus.Enabled, new LiveChannelTarget());
CreateLiveChannelResult result = oss.createLiveChannel(request);
//获取推流地址。
List<String> publishUrls = result.getPublishUrls();
for (String item : publishUrls) {
System.out.println(item);
}
//获取播放地址。
List<String> playUrls = result.getPlayUrls();
for (String item : playUrls) {
System.out.println(item);
}
oss.shutdown();
}
public static void listLiveChannels() {
// 创建 OSSClient 实例。
OSS oss = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
ListLiveChannelsRequest request = new ListLiveChannelsRequest(bucketName);
LiveChannelListing liveChannelListing = oss.listLiveChannels(request);
List<LiveChannel> list = liveChannelListing.getLiveChannels();
for(LiveChannel i:list){
deleteLiveChannel(i.getName());
}
oss.shutdown();
}
public static void deleteLiveChannel(String liveChannelName) {
// 创建 OSSClient 实例。
OSS oss = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
LiveChannelGenericRequest request = new LiveChannelGenericRequest(bucketName, liveChannelName);
System.out.println("Delete liveChanne "+liveChannelName+" Done");
try {
oss.deleteLiveChannel(request);
} catch (OSSException ex) {
ex.printStackTrace();
} catch (ClientException ex) {
ex.printStackTrace();
} finally {
oss.shutdown();
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
DeleteLiveChannel.listLiveChannels();
}
}