深度解析FastDFS:构建高效分布式文件存储的实战指南(上)

文章目录

  • 一、FastDFS简介
    • 1.1 概述
    • 1.2 特性
  • 二、FastDFS原理架构
    • 2.1 FastDFS角色
    • 2.2 存储策略
    • 2.3 上传过程
    • 2.4 文件同步
    • 2.5 下载过程
  • 三、FastDFS适用场景
  • 四、同类中间件对比
    • 4.1 FastDFS和集中存储方式对比
    • 4.2 FastDFS与其他文件系统的对比
  • 五、FastDFS部署
    • 5.1 单机部署
      • 5.1.1 使用的系统软件
      • 5.1.2 编译环境
      • 5.1.3 安装libfastcommon
      • 5.1.4 安装FastDFS
      • 5.1.5 安装fastdfs-nginx-module
      • 5.1.6 安装nginx
      • 5.1.7 tracker配置
      • 5.1.8 tracker服务启动
      • 5.1.9 storage配置
      • 5.1.10 storage服务启动
      • 5.1.11 client测试
      • 5.1.12 配置nginx访问
      • 5.1.13 nginx服务启动
      • 5.1.14 web浏览器测试
    • 5.2 集群部署
      • 5.2.1 FastDFS集群架构
      • 5.2.2 安装FastDFS相关软件
      • 5.2.3 tracker节点配置
      • 5.2.4 storage节点配置
      • 5.2.5 查看FastDFS集群状态
      • 5.2.6文件的上传
      • 5.2.7文件的下载
      • 5.2.8 文件的删除
    • 5.3 k8s部署
      • 5.3.1 创建tracker.yaml文件
      • 5.3.2 创建tracker.yaml文件
      • 5.3.3 创建service.yaml文件
      • 5.3.4 应该yaml文件
    • 5.4 FastDFS集群维护
      • 5.4.1 tracker节点维护
      • 5.4.2 storage节点维护
      • 5.4.3 fastdfs_storage七种状态

一、FastDFS简介

1.1 概述

FastDFS 是一个开源的高性能分布式文件系统(DFS)。 它的主要功能包括:文件存储,文件同步和文件访问(上传、下载),以及高容量和负载平衡。主要解决了海量数据存储问题,特别适合以中小文件(建议范围:4KB < file_size <500MB)为载体的在线服务。

FastDFS 设计是用来存储小文件的,过大的文件处理方案是拆分为小文件,可跟踪小文件的上传情况。 如果应用场景都是处理大文件,可能选择其他分布式文件系统方案会更合适。

1.2 特性

FastDFS 为互联网量身定制,充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用 FastDFS 很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。

优点:

  • 文件不分块存储,文件和系统中的文件一一对应。
  • 对文件内容做 hash 处理,避免出现重复文件,节约磁盘空间。
  • 下载文件支持 HTTP 协议,可基于内置 Web Server 或外部 Web Server。
  • 支持在线扩容,动态添加卷。
  • 支持文件冗余备份和负载均衡。
  • 存储服务器上可以保存文件属性(meta-data)
  • V2.0 网络通信采用 libevent,支持大并发访问,整体性能更好

缺点:

  • 直接按文件存储,可直接查看文件内容,缺乏文件安全性。
  • 数据同步无校验,存在静默 IO 问题,降低系统可用性。
  • 单线程数据同步,仅适合存储小文件(1)。
  • 备份数根据存储分卷(分组)决定,缺乏文件备份数设置灵活性。
  • 单个挂载点异常会导致整个存储节点下线。
  • 缺乏多机房容灾支持。
  • 静态的负载均衡机制

二、FastDFS原理架构

在这里插入图片描述

2.1 FastDFS角色

FastDFS是一个开源的轻量级分布式文件系统,由管理服务器(tracker server)、存储服务器(storage server)和客户端(client)三个部分组成

**Tracker Server:**跟踪服务器,主要做调度工作,起到均衡的作用;负责管理所有的 storage server 和 group,每个 storage 在启动后会连接 Tracker,告知自己所属 group 等信息,并保持周期性心跳。

**Storage Server:**存储服务器,主要提供容量和备份服务;以 group 为单位,每个 group 内可以有多台 storage server,数据互为备份。

**Client:**客户端,上传下载数据的服务器,也就是我们自己的项目所部署在的服务器。

Tracker 相当于一个调度中心,上传和下载都通过它来进行分配指定。
Storage cluster 部分,由 Volume1、Volume2……VolumeK 组成,它们称为卷(或者叫做组),卷与卷之间是平行的关系,可以根据资源的使用情况随时增加,卷内服务器文件相互同步备份,以达到容灾的目的。

2.2 存储策略

为了支持大容量,存储节点(服务器)采用了分卷(或分组)的组织方式。存储系统由一个或多个卷组成,卷与卷之间的文件是相互独立的,所有卷的文件容量累加就是整个存储系统中的文件容量。一个卷可以由一台或多台存储服务器组成,一个卷下的存储服务器中的文件都是相同的,卷中的多台存储服务器起到了冗余备份和负载均衡的作用。
在卷中增加服务器时,同步已有的文件由系统自动完成,同步完成后,系统自动将新增服务器切换到线上提供服务。当存储空间不足或即将耗尽时,可以动态添加卷。只需要增加一台或多台服务器,并将它们配置为一个新的卷,这样就扩大了存储系统的容量。

2.3 上传过程

当服务启动之后,Storage Server 会定期的向 Tracker Server 发送存储信息。如果 Tracker Server 是集群形式,则每个 Tracker 之间的关系是对等的,客户端上传时选择任意一个 Tracker 即可。

整体流程:当客户端请求 Tracker 进行上传操作时,会获取存储服务器相关信息,主要包括 IP 和端口。根据返回信息上传文件,通过存储服务器写入磁盘,并返回给客户端 file_id、路径信息、文件名等信息。
对应流程图如下:
在这里插入图片描述
其中,当 Tracker 收到客户端上传文件的请求时,会为该文件分配一个可以存储文件的 group,当选定了 group 后就要决定给客户端分配 group 中的哪一个 storage server。
当分配好 storage server 后,客户端向 storage 发送写文件请求,storage 将会为文件分配一个数据存储目录。然后为文件分配一个 fileid,最后根据以上的信息生成文件名存储文件。

生成的文件名基本格式如下:
在这里插入图片描述

  • 组名:文件上传后所在的 storage 组名称,在文件上传成功后有 storage 服务器返回, 需要客户端自行保存。
  • 虚拟磁盘路径:storage 配置的虚拟路径,与磁盘选项 store_path*对应。如果配置了 store_path0 则是 M00,如果配置了 store_path1 则是 M01,以此类推。
  • 数据两级目录:storage 服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据 文件。
  • 文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储 服务器 IP 地址、文件创建时间戳、文件大小、随机数和文件拓展名等信息。

2.4 文件同步

写文件时,客户端将文件写至 group 内一个 storage server 即认为写文件成功,storage server 写完文件后,会由后台线程将文件同步至同 group 内其他的 storage server。

每个 storage 写文件后,同时会写一份 binlog,binlog 里不包含文件数据,只包含文件名等元信息,这份 binlog 用于后台同步,storage 会记录向 group 内其他 storage 同步的进度,以便重启后能接上次的进度继续同步;进度以时间戳的方式进行记录,所以最好能保证集群内所有 server 的时钟保持同步。

storage 的同步进度会作为元数据的一部分汇报到 tracker 上,tracker 在选择读 storage 的时候会以同步进度作为参考。

2.5 下载过程

跟上传一样,在下载时客户端可以选择任意 Tracker server。

客户端带文件名信息请求 Tracker,Tracker 从文件名中解析出文件的 group、大小、创建时间等信息,然后选择一个 storage 用来服务处理请求,返回对应文件。
对应流程图如下:
在这里插入图片描述
如果是基于 Web 的 http 请求,此处的 Client 可以是 Nginx 代理服务。下面这张图更加形象的描述了相关的流程。
在这里插入图片描述

三、FastDFS适用场景

FastDFS 是为互联网应用量身定做的一套分布式文件存储系统,非常适合用来存储用户图片、视频、文档等文件,不适合分布式计算场景

电商网站:海量商品图片
视频网站:海量视频文件
网盘 : 海量文件
社交网站:海量图片

四、同类中间件对比

4.1 FastDFS和集中存储方式对比

在这里插入图片描述

4.2 FastDFS与其他文件系统的对比

在这里插入图片描述

五、FastDFS部署

5.1 单机部署

说明:准备1台cento7实例,ip:192.168.52.1

5.1.1 使用的系统软件

名称说明
centos7.x
libfastcommonFastDFS分离出的一些公用函数包
FastDFSFastDFS本体
fastdfs-nginx-moduleFastDFS和nginx的关联模块,作用:访问源文件,由于上传一个大文件到一个组的一个stoage1服务器后,这里的同组的storage2将会进行进行同步复制,如果复制没有完成,用户访问值storage2的时候,那么这个将会没有办法完整访问的,所以fastdfs-nginx-module这个模块,将会查找一个源文件,也就是存在storage1的服务器上,可以访问storage1上的文件
nginxnginx1.15.4

5.1.2 编译环境

CentOS系统
# yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel wget vim -y
Debian系统
# apt-get -y install git gcc g++ make automake autoconf libtool pcre2-utils libpcre2-dev zlib1g zlib1g-dev openssl libssh-dev wget vim

5.1.3 安装libfastcommon

# git clone https://github.com/happyfish100/libfastcommon.git --depth 1
# cd libfastcommon/
# ./make.sh && ./make.sh install #编译安装

5.1.4 安装FastDFS

# git clone https://github.com/happyfish100/fastdfs.git --depth 1
# cd fastdfs/
# ./make.sh && ./make.sh install #编译安装#配置文件准备
# cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
# cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
# cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf #客户端文件,测试用
# cp /usr/local/src/fastdfs/conf/http.conf /etc/fdfs/ #供nginx访问使用
# cp /usr/local/src/fastdfs/conf/mime.types /etc/fdfs/ #供nginx访问使用

5.1.5 安装fastdfs-nginx-module

# git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1
# cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs

5.1.6 安装nginx

# wget http://nginx.org/download/nginx-1.15.4.tar.gz #下载nginx压缩包
# tar -zxvf nginx-1.15.4.tar.gz #解压
# cd nginx-1.15.4/#添加fastdfs-nginx-module模块
# ./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/ 
# make && make install #编译安装

5.1.7 tracker配置

# vim /etc/fdfs/tracker.conf#需要修改的内容如下
port=22122  # tracker服务器端口(默认22122,一般不修改)
base_path=/home/dfs  # 存储日志和数据的根目录

5.1.8 tracker服务启动

/etc/init.d/fdfs_trackerd start #启动tracker服务
/etc/init.d/fdfs_trackerd restart #重启动tracker服务
/etc/init.d/fdfs_trackerd stop #停止tracker服务
chkconfig fdfs_trackerd on #自启动tracker服务

5.1.9 storage配置

# vim /etc/fdfs/storage.conf
#需要修改的内容如下
port=23000  # storage服务端口(默认23000,一般不修改)
base_path=/home/dfs  # 数据和日志文件存储根目录
store_path0=/home/dfs  # 第一个存储目录
tracker_server=192.168.52.1:22122  # tracker服务器IP和端口
http.server_port=8888  # http访问文件的端口(默认8888,看情况修改,和nginx中保持一致)

5.1.10 storage服务启动

/etc/init.d/fdfs_storaged start #启动storage服务
/etc/init.d/fdfs_storaged restart #重动storage服务
/etc/init.d/fdfs_storaged stop #停止动storage服务
chkconfig fdfs_storaged on #自启动storage服务

5.1.11 client测试

# vim /etc/fdfs/client.conf#需要修改的内容如下
base_path=/home/dfs
tracker_server=192.168.52.1:22122    #tracker服务器IP和端口#保存后测试,返回ID表示成功 如:group1/M00/00/00/xx.tar.gz
# fdfs_upload_file /etc/fdfs/client.conf /usr/local/src/nginx-1.15.4.tar.gz

5.1.12 配置nginx访问

# vim /etc/fdfs/mod_fastdfs.conf
#需要修改的内容如下
tracker_server=192.168.52.1:22122  #tracker服务器IP和端口
url_have_group_name=true
store_path0=/home/dfs#配置nginx.config
# vim /usr/local/nginx/conf/nginx.conf
#添加如下配置
server {listen       8888;    ## 该端口为storage.conf中的http.server_port相同server_name  localhost;location ~/group[0-9]/ {ngx_fastdfs_module;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}
}

5.1.13 nginx服务启动

/usr/local/nginx/sbin/nginx #启动nginx
/usr/local/nginx/sbin/nginx -s reload #重启nginx
/usr/local/nginx/sbin/nginx -s stop #停止nginx

5.1.14 web浏览器测试

#测试下载,用外部浏览器访问刚才已传过的nginx安装包,引用返回的ID
http://192.168.52.1:8888/group1/M00/00/00/wKgAQ1pysxmAaqhAAA76tz-dVgg.tar.gz
#弹出下载单机部署全部跑通

5.2 集群部署

5.2.1 FastDFS集群架构

说明:2台tracker节点、2组storage。
group1对应storage1和storage2,group2对应storage3和storage4
在这里插入图片描述

5.2.2 安装FastDFS相关软件

说明:
所有节点安装参考单机部署“5.1.3安装libfastcommon”和5.1.4安装FastDFS章节

5.2.3 tracker节点配置

FastDFS 配置文件的默认目录/etc/fdfs,操作如下:

  1. 编辑 tracker.conf 配置文件,命令 vim tracker.conf,修改如下内容:
    base_path=/tracker ##数据和日志的存放路径
    store_lookup=2 ##存储组的选择方式,负载均衡方式,这是默认方式
    store_server=0 ##存储节点的选择方式,轮询方式,这是默认方式
    store_path=2 ##存储路径的选择方式,负载均衡方式
    thread_stack_size = 128KB ##线程栈大小,默认 64K
    storage_sync_file_max_delay=600 ##存储节点间文件同步的最大延迟时间,默认 1 天,此处测试 改为 10 分钟
    rotate_error_log = true ##启用错误日志
    其他参数默认即可。
  2. 启动 tracker 服务器:
    fdfs_trackerd /etc/fdfs/tracker.conf start
    如果报错,查看日志:
    $base_path/logs/trackerd.log ,此处配置的base_path=/tracker ,
    所以日志文件路径:/tracker/logs/trackerd.log

5.2.4 storage节点配置

  1. 进入配置文件目录,使用 sample 文件复制一份 storage.conf 文件进行修改:
    cd /etc/fdfs
    cp storage.conf.sample storage.conf
  2. 编辑 storage.conf 配置文件,命令 vim storage.conf,修改如下内容:

storage1 和 storage2 的配置文件:

group_name=group1 ##组名 
base_path=/fastdfs ##基础路径,存放 storage 运行所需文件 
sync_wait_msec=1000 ##同步检查间隔时间 1000ms 
store_path0=/storage ##文件存放路径 
tracker_server=192.168.182.101:22122 ##storage 注册到 tracker1 
tracker_server=192.168.182.102:22122 ##storage 注册到 tracker2 

storage3 和 storage4 的配置文件:

group_name=group2 ##组名 
base_path=/fastdfs ##基础路径,存放 storage 运行所需文件 
sync_wait_msec=1000 ##同步检查间隔时间 1000ms 
##store_path0=/storage ##如果不配置 store_path,那么文件默认存放在${base_path}/data 下 
store_path0,实际生产环境中,尽量将所有节点的存储位置保持一致,方便管理。 
tracker_server=192.168.182.101:22122 ##storage 注册到 tracker1 
tracker_server=192.168.182.102:22122 ##storage 注册到 tracker2 
  1. 启动 storage 服务器:
在四个存储节点执行启动命令: 
fdfs_storaged /etc/fdfs/storage.conf start 
如果报错,查看日志: 
$base_path/logs/storaged.log 此处配置的 base_path=/fastdfs , 所以日志文件路径:/fastdfs/logs/storaged.log 

5.2.5 查看FastDFS集群状态

  1. 在客户端安装 FastDFS(此处选择 tracker1 作为客户端)。
  2. 配置 client.conf 文件
cp client.conf.sample client.conf 
vim client.conf 
client 的配置文件: 
base_path=/client ##配置 client 的基本目录 
tracker_server=192.168.182.101:22122 ##配置 tracker1 服务的地址 
tracker_server=192.168.182.102:22122 ##配置 tracker2 服务的地址 
  1. 使用 fdfs_monitor 命令查看 FastDFS 文件服务器的状态:
fdfs_monitor /etc/fdfs/client.conf -h 192.168.182.101 list 
fdfs_monitor /etc/fdfs/client.conf -h 192.168.182.102 list 参数说明: 
/etc/fdfs/client.conf:客户端配置文件 
-h 192.168.182.101/-h 192.168.182.102:tracker1/tracker2 服务器的 ip 地址 
list:显示指定的 tracker 的服务器信息 

以 tracker1 192.168.182.101 为例,查询结果如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注:如果 tracker1 和 tracker2 的信息都能查看到 group1 和 group2 的信息,说明部署成功,如果部署过程中出现问题,需要参照日志文件中的信息进行修正。

5.2.6文件的上传

上传文件命令:fdfs_upload_file 
语法: 
fdfs_upload_file <config_file> <local_filename> [storage_ip:port] [store_path_index] 
<config_file>:客户端配置文件名称,必须有。 
<local_filename>:要上传的文件名称,必须有。 
[storage_ip:port]:上传的存储节点名称,选择项。 
[store_path_index]:存储路径,选择项。 

示例,上传 testupload 文件:
在这里插入图片描述返回值文件 ID:【group 名+节点上存储目录编号+storage 节点创建的目录+加密的一个文件名】,
根据文件 ID,可以查看文件信息,使用 fdfs_file_info 命令,示例:
在这里插入图片描述

5.2.7文件的下载

下载文件命令:fdfs_download_file 
语法: 
fdfs_download_file <config_file> <file_id> [local_filename] [<download_offset> <download_bytes>] 
<config_file> :客户端配置文件,必须有 
<file_id> :要下载的文件 ID,必须有。 
[local_filename] :存储到本地的文件,选择项。 
[<download_offset> <download_bytes>]:下载偏移量、下载大小,选择项。 
示例: 
fdfs_download_file /etc/fdfs/client.conf 
group1/M00/00/00/wKi2eVZf0KuAEPaaAAAAPm9mCTM1183578 /root/testdownload

5.2.8 文件的删除

文件删除命令:fdfs_delete_file 
语法: 
fdfs_delete_file <config_file> <file_id> 
<config_file> :客户端配置文件,必须有。 
<file_id>:文件 ID,必须有。 

示例:
在这里插入图片描述

5.3 k8s部署

5.3.1 创建tracker.yaml文件

**tracker.yaml部署yaml文件**
apiVersion: extensions/v1beta1
kind: Deployment
metadata:name: tracker-deploy # 部署的容器名称namespace: fastdfs # 部署到的命名空间labels:name: tracker-deploy
spec:# 该 Deployment 的规格说明replicas: 1 # 副本数template:metadata:labels:app: trackerspec:nodeSelector:fastdfs: tracker # 选择器,nodeSelector根据 label 指定pod起在哪台机器上,根据自身所需进行修改,必须先在节点上面定义此标签terminationGracePeriodSeconds: 0containers:- name: trackerimage: fastdfsimagePullPolicy: IfNotPresent#获取镜像的策略 Always表示下载镜像 IfNotPresent表示优先使用本地镜像,否则下载镜像,Nerver表示仅使用本地镜像ports:- containerPort: 22122protocol: TCP #端口协议,支持TCP和UDP,默认TCPvolumeMounts:- name: tracker-volumemountPath: /var/fdfscommand: ["/usr/bin/start.sh","tracker"]volumes:- name: tracker-volumehostPath:path: /home/data/fastdfs/tracker # 在宿主机上存储的地址

5.3.2 创建tracker.yaml文件

**storage.yaml部署yaml文件**
apiVersion: extensions/v1beta1
kind: Deployment
metadata:name: storage0-deploynamespace: fastdfslabels:name: storage0-deploy
spec:replicas: 1template:metadata:labels:app: storage0spec:nodeSelector:fastdfs: storage0terminationGracePeriodSeconds: 0containers:- name: storage0image: fastdfs # 表示引用镜像的地址imagePullPolicy: IfNotPresentports:- containerPort: 22122protocol: TCP #端口协议,支持TCP和UDP,默认TCPvolumeMounts:- name: storage0-volumemountPath: /var/fdfsenv:- name: TRACKER_SERVERvalue: 10.96.0.110:22122command: ["/usr/bin/start.sh","storage"]volumes:- name: storage0-volumehostPath:path: /home/data/fastdfs/storage0 #在宿主机上存储的地址

5.3.3 创建service.yaml文件

**创建tracker和storage的service文件**
apiVersion: v1
kind: Service
metadata:name: trackerlabels:app: trackernamespace: fastdfs
spec:selector:app: tracker # 这里选择器一定要选择容器的标签type: ClusterIPports:- name: "22122"port: 22122targetPort: 22122nodePort: 22122---
apiVersion: v1
kind: Service
metadata:name: storage0labels:app: storage0namespace: fastdfs
spec:selector:app: storage0type: NodePortports:- name: "23000"port: 23000targetPort: 23000nodePort: 23000

5.3.4 应该yaml文件

kubectl apply -f tracker.yaml storage.yaml service.yaml
注:资源清单应用后pod状态是running即可

5.4 FastDFS集群维护

5.4.1 tracker节点维护

tracker的添加和删除比较麻烦,不光要修改tracker的配置文件,原有的存储节点配置文件也要修改。所有tracker之间是对等的。

5.4.1.1 添加tracker节点
添加一个节点 tracker3,tracker3只监控group2,查看tracker3的状态并通过tracker3上传文件。 tracker3主机ip为192.168.182.103。参照FastDFS 的安装步骤安装 FastDFS并修改 client.conf 配置文件(将 tracker1 或 tracker2上的client.conf 直接scp到tracker3),启动 tracker3服务。

在这里插入图片描述
停止group2中storage3,storage4的存储服务
在这里插入图片描述在这里插入图片描述
修改storage3,storage4的配置文件storage.conf,添加tracker3的配置内容并保存
在这里插入图片描述
重启storage3,storage4节点,并在客户端配置文件中添加tracker3的信息
在这里插入图片描述
在客户端查看tracker3服务器的状态信息
在这里插入图片描述
发现即使在storage1和storage2中没有配置tracker3的信息,在tracker3启动后,tracker在启动后也能管理所有的group,测试上传文件
在这里插入图片描述
查看服务器存储目录下内容:
storage3和storage4中的目录全部存有上传后的file11
在这里插入图片描述
在这里插入图片描述
storage1和storage2中的目录全部存有上传后的file11
在这里插入图片描述
在这里插入图片描述
删除客户端配置文件中的tracker1和tracker2 的配置,只保留tracker3的配置
在这里插入图片描述
尝试将文件file11上传到storage1节点,仍然成功
在这里插入图片描述
查看storage1存储目录下文件
在这里插入图片描述
结论:从添加tracker3节点得出结论:即使tracker3只有group2向其注册,tracker3启动后,和其他的tracker节点是等效的,也能向其他节点监听的group中上传数据,即使其他节点停机。

注:生产环境中新增tracker节点,所有storage节点和客户端配置文件都需要添加新增tracker-ip地址。同时需要提前和相应业务沟通并发送通知

5.4.1.2 删除tracker节点

  1. 将各个storage节点配置文件中的tracker_server=IP:PORT 删除,重启storage。这样 storage节点就不再向tracker推送信息。
  2. 停止tracker节点服务
  3. 删除客户端配置文件中的tracker_server=IP:PORT

5.4.2 storage节点维护

5.4.2.1 添加storage节点

  1. 安装Storage并配置storage.conf
  2. 如果在某组中新增的storage节点,注意配置文件组名和存储路径
  3. 如果是新增1组storage节点,注意不要和现有组重名。
  4. storage节点启动服务即可
  5. 通过fdfs_monitor /etc/fdfs/client.conf查看新增storage节点信息

5.4.2.2 删除storage节点

  1. 停止storage节点服务
  2. 通过fdfs_monitor命令删除
    fdfs_monitor /etc/fdfs/client.conf delete group1
  3. 查看集群情况fdfs_monitor命令可以到对应的storage节点状态为DELETED
    fdfs_monitor /etc/fdfs/client.conf

5.4.3 fastdfs_storage七种状态

# FDFS_STORAGE_STATUS:INIT      :初始化,尚未得到同步已有数据的源服务器
# FDFS_STORAGE_STATUS:WAIT_SYNC :等待同步,已得到同步已有数据的源服务器
# FDFS_STORAGE_STATUS:SYNCING   :同步中
# FDFS_STORAGE_STATUS:DELETED   :已删除,该服务器从本组中摘除
# FDFS_STORAGE_STATUS:OFFLINE   :离线
# FDFS_STORAGE_STATUS:ONLINE    :在线,尚不能提供服务
# FDFS_STORAGE_STATUS:ACTIVE    :在线,可以提供服务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/886689.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 3249.统计好节点的数目:深度优先搜索(DFS)

【LetMeFly】3249.统计好节点的数目&#xff1a;深度优先搜索(DFS) 力扣题目链接&#xff1a;https://leetcode.cn/problems/count-the-number-of-good-nodes/ 现有一棵 无向 树&#xff0c;树中包含 n 个节点&#xff0c;按从 0 到 n - 1 标记。树的根节点是节点 0 。给你一…

中国省级金融发展水平指数(金融机构存款余额、贷款余额、GDP)2020-2023年

数据范围&#xff1a; 包含的数据内容如下&#xff1a; 分省份金融机构存款余额、分省份金融机构贷款余额、分省份金融机构存贷款余额、分省份GDP、分省份金融发展指数 西藏自治区、贵州省、黑龙江省2023年数据暂未公布&#xff0c;计算至2022年&#xff0c;其他省份数据无缺失…

大模型(LLMs)RAG 版面分析——表格识别方法篇

大模型&#xff08;LLMs&#xff09;RAG 版面分析——表格识别方法篇 一、为什么需要识别表格&#xff1f; 表格的尺寸、类型和样式展现出多样化的特征&#xff0c;如背景填充的差异性、行列合并方法的多样性以及内容文本类型的不一致性等。同时&#xff0c;现有的文档资料不…

力扣(leetcode)题目总结——辅助栈篇

leetcode 经典题分类 链表数组字符串哈希表二分法双指针滑动窗口递归/回溯动态规划二叉树辅助栈 本系列专栏&#xff1a;点击进入 leetcode题目分类 关注走一波 前言&#xff1a;本系列文章初衷是为了按类别整理出力扣&#xff08;leetcode&#xff09;最经典题目&#xff0c…

【python系列】python数据类型的分类和比较

一、数据类型的定义 在程序设计的类型系统中,数据类型(英语:Data type),又称资料型态、资料型别,是用来约束数据的解释。——Wikipedia 从定义我们可以看出来,数字类型的理解最主要的是约束数据的解释,每个类型都有他们自己所使用得场景,这个就是数字类型的分类,分类…

【JavaSE】【多线程】阻塞队列

目录 一、阻塞队列1.1 生产者消费者模型1.2 Java提供的阻塞队列1.3 实现一个简单生产者消费者模型 二、自己实现阻塞队列2.1 成员变量2.2 构造方法2.3 put方法2.4 take方法2.5 最终代码 一、阻塞队列 阻塞队列&#xff1a;是一种特殊的队列&#xff0c;也有先进先出的特性。它…

【pytest】pytest注解使用指南

前言&#xff1a;在 pytest 测试框架中&#xff0c;注解&#xff08;通常称为装饰器&#xff09;用于为测试函数、类或方法提供额外的信息或元数据。这些装饰器可以影响测试的执行方式、报告方式以及测试的组织结构。pytest 提供了多种内置的装饰器&#xff0c;以及通过插件扩展…

el-table合并单元格之后,再进行隔行换色的且覆盖表格行鼠标移入的背景色的实现

el-table 中有现成的隔行换色功能&#xff0c;只要增加 stripe 属性即可。但是如果有单元格合并的话&#xff0c;这个属性就不可用了。这时候我们就需要动点小心思了。 基于相同字段进行合并 单元格合并&#xff1a;基于表头中的某一列&#xff0c;具有相同值的个数相加进行合…

OpenAI模型whisper 音频转文本

最近有一个音频转文本的需求&#xff0c;了解到了OpenAI的whisper模型可以实现。 Whisper 是 OpenAI 提供的一个通用语音识别模型&#xff0c;支持多语言的音频转文本功能&#xff0c;并具有较高的准确性。它的主要用途包括自动语音识别 (ASR)、语言翻译&#xff08;将音频直接…

ubuntu下连接了192.168.1.x和192.168.2.x两个网络段,如何让这个两个网段互相通信?

在 Ubuntu 上连接两个网络段&#xff08;如 个人终端A 192.168.1.10 和 个人终端B 192.168.2.10&#xff09;&#xff0c;需要配置路由和网络转发功能&#xff0c;使这两个网段能够相互通信。以下是实现方法&#xff1a; 步骤 1&#xff1a;确认网络配置 1. 确保 Ubuntu 机器…

汽车资讯新高度:Spring Boot技术飞跃

6系统测试 6.1概念和意义 测试的定义&#xff1a;程序测试是为了发现错误而执行程序的过程。测试(Testing)的任务与目的可以描述为&#xff1a; 目的&#xff1a;发现程序的错误&#xff1b; 任务&#xff1a;通过在计算机上执行程序&#xff0c;暴露程序中潜在的错误。 另一个…

03-axios常用的请求方法、axios错误处理

欢迎来到“雪碧聊技术”CSDN博客&#xff01; 在这里&#xff0c;您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者&#xff0c;还是具有一定经验的开发者&#xff0c;相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导&#xff0c;我将…

机器学习基础04_朴素贝叶斯分类决策树分类

目录 一、朴素贝叶斯分类理论 1、贝叶斯分类理论 2、条件概率 3、全概率公式 4、贝叶斯推断 5、朴素贝叶斯推断 6、拉普拉斯平滑系数 二、决策树分类 1、相关概念 2、基于信息增益决策树的建立 3、基于基尼指数决策树的建立 一、朴素贝叶斯分类理论 1、贝叶斯分类理…

git日志查询和导出

背景 查看git的提交记录并下载 操作 1、找到你idea代码的路径&#xff0c;然后 git bash here打开窗口 2、下载所有的日志记录 git log > commit.log3、下载特定日期范围内记录 git log --since"2024-09-01" --until"2024-11-18" 你的分支 > c…

后台管理系统(开箱即用)

很久没有更新博客了&#xff0c;给大家带上一波福利吧,大佬勿扰 现在市面上流行的后台管理模板很多,若依,芋道等,可是这些框架对我们来说可能会有点重,所以我自己从0到1写了一个后台管理模板,你们使用时候可扩展性也会更高 项目主要功能: 成员管理&#xff0c;部门管理&#…

Spring Boot 牛刀小试 org.springframework.boot:spring-boot-maven-plugin:找不到类错误

今天看了下书翻了下Spring Boot的用法&#xff0c;下载idea后&#xff0c; 反复出现org.springframework.boot:spring-boot-maven-plugin:找不到类错误&#xff0c;后来看了下调试窗口&#xff0c;发现是连不上maven的网站443错误&#xff0c;解决思路很简单&#xff0c;把ide连…

数据中心的拥塞控制

前面提到&#xff0c;如今的高速网络方案集中在卸载主机网络能力&#xff0c;降低主机处理时延&#xff0c;甚至 PFC 用网络排队时延换主机时延&#xff0c;本末倒置。而在拥塞控制领域仍是传统的 AIMD 闭环反馈&#xff0c;ECN&#xff0c;QCN 那一套&#xff0c;但拥塞是端到…

【网络云计算】2024第48周-技能大赛-初赛篇

文章目录 1、比赛前提2、比赛题目2.1、 修改CentOS Stream系统的主机名称&#xff0c;写出至少3种方式&#xff0c;并截图带时间戳和姓名&#xff0c;精确到秒&#xff0c;否则零分2.2、 创建一个名为你的名字的拼音的缩写的新用户并设置密码&#xff0c;将用户名添加到 develo…

SAP+Internet主题HTML样式选择

SAP目前只支持三种HTML样式选择&#xff1a; 样式一 背景色&#xff1a;深色&#xff0c;蓝 特点&#xff1a;适中型排列&#xff0c;与SAP界面排列相同&#xff0c;富含UI特征&#xff0c;整齐美观 URL地址&#xff1a;http://cn1000-sap-01.sc.com:8000/sap/bc/gui/sap/it…

鸿蒙动画开发07——粒子动画

1、概 述 粒子动画是在一定范围内随机生成的大量粒子产生运动而组成的动画。 动画元素是一个个粒子&#xff0c;这些粒子可以是圆点、图片。我们可以通过对粒子在颜色、透明度、大小、速度、加速度、自旋角度等维度变化做动画&#xff0c;来营造一种氛围感&#xff0c;比如下…