Fastdfs被用来作为文件存储,在实际的生产中会对其进行灾备处理,下面我们来探究Fastdfs怎么实现双机房的容灾切换。
目录
一、Fastdfs相关知识
FastDFS集群可支持的规则
1、选择tracker server
当集群中不止一个tracker server时,由于tracker之间是完全对等的关系,客户端在upload文件时可以任意选择一个trakcer。 选择存储的group 当tracker接收到upload file的请求时,会为该文件分配一个可以存储该文件的group,支持如下选择group的规则:1、Round robin,所有的group间轮询
2、Specified group,指定某一个确定的group
3、Load balance,剩余存储空间多多group优先
2、选择storage server
当选定group后,tracker会在group内选择一个storage server给客户端,支持如下选择storage的规则:1、Round robin,在group内的所有storage间轮询
2、First server ordered by ip,按ip排序
3、First server ordered by priority,按优先级排序(优先级在storage上配置)
3、选择storage path
当分配好storage server后,客户端将向storage发送写文件请求,storage将会为文件分配一个数据存储目录,支持如下规则:1、Round robin,多个存储目录间轮询
2、剩余存储空间最多的优先
二、Fastdfs双机房集群搭建
Fastdfs的具体搭建过程不做赘述,具体参考他人集群搭建
A机房为主机房 B机房为备机房 |
三、Fastdfs双机房模拟测试
模拟场景一:AB机房容灾测试
测试场景:
测试思路:
1、AB机房搭建完成后,进行数据上传,查看存储状态;2、关闭A机房的所有服务器,继续上传数据,查看存储状态;
3、恢复A机房的所有服务器,上传数据,查看存储状态;
测试过程:
1、搭建AB机房的fastdfs集群,通过/usr/bin/fdfs_monitor /etc/fdfs/storage.conf
查看集群状态;
2、keepalived的虚拟ip在172.18.40.194服务器上
3、用代码进行文件上传与下载,集群状态良好;
@PostMapping("/upload1")
public String uploadFile() throws IOException {
Long count = 0L;
FSEntity fsEntity;
int a = 0;
int b = 0;
ArrayList<String> strings = new ArrayList<>();
File file = new File("D://test");
try {
if (file == null || !file.exists()) {
System.out.println("没有文件夹");
}
//获得文件对象的子文件对象列表
File[] files = file.listFiles();
//遍历文件并上传
for (File f : files) {
InputStream inputStream = null;
FileInputStream fileInputStream = new FileInputStream(f);
String fileName = f.getName(