【Fastdfs】Fastdfs实现双机房容灾切换

本文详细介绍了如何利用Fastdfs搭建双机房集群,并进行了AB机房容灾切换的模拟测试,确保在切换过程中数据能够成功同步。通过设置storage的priority参数,实现了数据优先在A机房存储,保证了业务连续性和数据一致性。
摘要由CSDN通过智能技术生成
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()
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值