当前位置: 首页 > news >正文

FastDFS分布式文件存储

FastDFS文件上传

简介:

主要解决:大容量的文件存储和高并发访问的问题

论坛:https://bbs.chinaunix.net

下载网站:https://sourceforge.net/projects/fastdfs/files/

安装参考:https://www.cnblogs.com/cxygg/p/16000425.html

启动方式:参考上的方式启动不了,使用如下方式启动:

service fdfs_trackerd start

service fdfs_trackerd status

service fdfs_trackerd stop

service fdfs_storaged start

service fdfs_storaged status

service fdfs_storaged stop

上传文件命令:

fdfs_upload_file /etc/fdfs/client.conf /home/b.txt

java操作使用:

<dependency><groupId>cn.bestwu</groupId><artifactId>fastdfs-client-java</artifactId><version>1.27</version>
</dependency>
<dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.4</version>
fastdfs.connect_timeout_in_seconds=10
fastdfs.network_timeout_in_seconds=30
fastdfs.charset=UTF-8
fastdfs.tracker_servers=192.168.0.138:22122
#/etc/fdfs/tracker.conf中http.server_port配置的完全一致
fastdfs.http_tracker_http_port=8080
package org.example;import org.csource.common.MyException;
import org.csource.common.NameValuePair;
import org.csource.fastdfs.*;import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;/*** Hello world!*/
public class App {private static String dirPath = "C:\\Users\\Administrator\\Desktop\\notes\\";public static void main(String[] args) throws IOException, MyException {//加载配置信息Properties properties = new Properties();properties.load(App.class.getClassLoader().getResourceAsStream("fdfs.properties"));ClientGlobal.initByProperties(properties);//初始化客户端对象,StorageClient,存储客户端TrackerClient trackerClient = new TrackerClient();TrackerServer trackerServer = trackerClient.getConnection();StorageServer storageServer = trackerClient.getStoreStorage(trackerServer);StorageClient storageClient = new StorageClient(trackerServer, storageServer);//文件上传//读取文件字节内容到一个字节数组中,文件必须完整的存在一个数组中。FileInputStream in = new FileInputStream(dirPath + "Redis.md");//根据文件的字节长度,创建一个等长的数组byte[] data = new byte[in.available()];//把文件内容完整的读取到数组中in.read(data, 0, data.length);//元数据,由使用者自定义,是名值对形式NameValuePair[] nvps = new NameValuePair[]{new NameValuePair("name", "Redis.md")};//上传文件,返回一个字符串数组,长度为2。0下标代表组名。1下标代表文件路径及文件名// 如: [0]=group1;  [1]=M00/00/00/dadfsfsdfs.mdString[] result = storageClient.upload_file(data, "md", nvps);System.out.println("返回结果数组长度:" + result.length);System.out.println("rest[0]=" + result[0]);System.out.println("rest[1]=" + result[1]);}
}

//工具

package org.example.utils;import org.csource.common.MyException;
import org.csource.common.NameValuePair;
import org.csource.fastdfs.*;
import org.example.App;import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties;public class FastDFSUtils {private FastDFSUtils() {}private static final Properties properties = new Properties();private static StorageClient storageClient;static {try {//加载配置信息properties.load(App.class.getClassLoader().getResourceAsStream("fdfs.properties"));ClientGlobal.initByProperties(properties);//初始化客户端对象,StorageClient,存储客户端TrackerClient trackerClient = new TrackerClient();TrackerServer trackerServer = trackerClient.getConnection();StorageServer storageServer = trackerClient.getStoreStorage(trackerServer);storageClient = new StorageClient(trackerServer, storageServer);} catch (Exception e) {e.printStackTrace();throw new ExceptionInInitializerError(e);}}//上传public static String uploadFile(byte[] datas, String extName, NameValuePair[] nvps) {try {String[] resutl;resutl = storageClient.upload_file(datas, extName, nvps);String path = resutl[0] + "/" + resutl[1];return path;} catch (Exception e) {e.printStackTrace();//上传失败return null;}}//下载public static byte[] download(String group,String path){try {byte[] bytes = storageClient.download_file(group, path);return bytes;} catch (Exception e) {e.printStackTrace();return null;}}public static  NameValuePair[] getMetaDatas(String group,String path){try {NameValuePair[] metadata = storageClient.get_metadata(group, path);return metadata;} catch (Exception e) {e.printStackTrace();return null;}}public static boolean delete(String group,String path) throws Exception{try {int status = storageClient.delete_file(group,path);return status == 0;} catch (Exception e) {e.printStackTrace();return false;}}}
package org.example;import org.csource.common.MyException;
import org.csource.common.NameValuePair;
import org.csource.fastdfs.*;
import org.example.utils.FastDFSUtils;import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import java.util.UUID;/*** Hello world!*/
public class App {private static String dirPath = "C:\\Users\\Administrator\\Desktop\\notes\\";public  static  void uploadFile() throws Exception{FileInputStream in = new FileInputStream(dirPath + "Redis.md");int length = in.available();byte[] datas = new byte[length];in.read(datas,0,length);NameValuePair[] nvps = new NameValuePair[]{new NameValuePair("name","Redis.md")
//                new NameValuePair("length",length + "")};String result = FastDFSUtils.uploadFile(datas,"md",nvps);System.out.println(result);}public static void download() throws Exception{String group = "group1";String path = "M00/00/00/wKgAimRDupOAC57HAAAtdrasJ7c7839.md";NameValuePair[]  nvps = FastDFSUtils.getMetaDatas(group,path);byte[] data = FastDFSUtils.download(group, path);String loclaFileName = "";for (NameValuePair nvp : nvps) {if (nvp.getName().equals("name")){loclaFileName = nvp.getValue();}}if ("".equals(loclaFileName)){//元数据中没有文件名,设置文件名为随机命名loclaFileName = UUID.randomUUID().toString() + path.substring(path.lastIndexOf("."+1));}FileOutputStream out = new FileOutputStream("F:\\"+loclaFileName);out.write(data,0,data.length);out.flush();out.close();}public static void delete() throws Exception {String group = "group1";String path = "M00/00/00/wKgAimRDupOAC57HAAAtdrasJ7c7839.md";boolean delete = FastDFSUtils.delete(group, path);System.out.println(delete? "删除成功":"删除失败");}public static void main(String[] args) throws Exception {//        uploadFile();
//        download();delete();//        //加载配置信息
//        Properties properties = new Properties();
//        properties.load(App.class.getClassLoader().getResourceAsStream("fdfs.properties"));
//        ClientGlobal.initByProperties(properties);
//
//        //初始化客户端对象,StorageClient,存储客户端
//        TrackerClient trackerClient = new TrackerClient();
//        TrackerServer trackerServer = trackerClient.getConnection();
//        StorageServer storageServer = trackerClient.getStoreStorage(trackerServer);
//        StorageClient storageClient = new StorageClient(trackerServer, storageServer);
//
//        //文件上传
//        //读取文件字节内容到一个字节数组中,文件必须完整的存在一个数组中。
//        FileInputStream in = new FileInputStream(dirPath + "Redis.md");
//        //根据文件的字节长度,创建一个等长的数组
//        byte[] data = new byte[in.available()];
//        //把文件内容完整的读取到数组中
//        in.read(data, 0, data.length);
//        //元数据,由使用者自定义,是名值对形式
//        NameValuePair[] nvps = new NameValuePair[]{
//                new NameValuePair("name", "Redis.md")
//        };
//        //上传文件,返回一个字符串数组,长度为2。0下标代表组名。1下标代表文件路径及文件名
//        // 如: [0]=group1;  [1]=M00/00/00/dadfsfsdfs.md
//        String[] result = storageClient.upload_file(data, "md", nvps);
//        System.out.println("返回结果数组长度:" + result.length);
//        System.out.println("rest[0]=" + result[0]);
//        System.out.println("rest[1]=" + result[1]);}
}

安装nginx的依赖

yum install -y gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl openssl-devel

上传nginx nginx-moduel

解压 nginx-moduel

vim config

看文件中的一个目录 一般删除local

ls /usr/local/include/fastdfs

ls /usr/local/include/fastcommon

ls /usr/local/lib

/etc/fdfs/mod_fastdfs.conf 文件就在当前的src 目录下 进行 cp mod_fastdfs.conf /etc/fdfs/

解压 nginx

创建文件夹

mkdir -p  /usr/local/nginx
mkdir -p  /var/run/nginx
mkdir -p  /var/lock
mkdir -p  /var/log/nginx
mkdir -p  /var/temp/nginx

启动nginx

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi \
--add-module=/opt/tools/fastdfs-nginx-module/src

修改

vim /etc/fdfs/mod_fastdfs.conf

tracker_server=192.168.0.138:22122

url_have_group_name = true

编译

有Makefile文件 的直接执行

make

make install

cd /usr/local/nginx

vim nginx.conf

user root;

/opt/tools/FastDFS/conf

cp http.conf /etc/fdfs/

cp mime.types /etc/fdfs/

sbin/nginx

vim nginx.conf

server{
listen 8888;
server_name localhost;
location ~/group([1-9])/M00 {
ngx_fastdfs_module;

}

}

sbin/nginx -s quit

sbin/nginx

http://192.168.0.138:8888/group1/M00/00/00/wKgAimRFUpeAbRwAAAFNn0YHOlA48.jpeg

相关文章:

FastDFS分布式文件存储

FastDFS文件上传 简介&#xff1a; 主要解决&#xff1a;大容量的文件存储和高并发访问的问题 论坛&#xff1a;https://bbs.chinaunix.net 下载网站&#xff1a;https://sourceforge.net/projects/fastdfs/files/ 安装参考&#xff1a;https://www.cnblogs.com/cxygg/p/1…...

Android的AAC架构

AAC Android Architecture Components的简称&#xff0c;是一套用来搭建具有生命周期感知架构的系列组件&#xff0c;在2017年 GoogleI/O大会上发布。 dependencies {def lifecycle_version "2.2.0"implementation "androidx.lifecycle:lifecycle-livedata-ktx…...

高功率激光切割中不良现象的排除技巧

高功率切割市场现状 随着激光行业的发展和下游产业需求的变化&#xff0c;高功率的激光切割设备已逐渐成为市场关注的热点。高功率激光切割凭着速度和厚度上无可比拟的优势&#xff0c;目前已获得了市场的广泛认可。 但由于高功率激光切割技术尚处于普及的初级阶段&#xff0c;…...

MySQL-----复合查询

文章目录 前言一、基本查询回顾二、 多表查询解决多表查询的思路 三、自连接四、子查询1. 单行子查询2. 多行子查询3. 多列子查询4. 在from子句中使用子查询5. 合并查询5.1 union5.2 unoin all 总结 前言 前面的学习中,对于mysql表的查询都是对一张表进行查询,在实际开发中这远…...

10.Yarn概述

如果说HDFS是存储&#xff0c;则Yarn就是cpu和内存&#xff0c;mapreduce就是程序。 1.基础架构 复习&#xff1a; 1.Container就是一个容器&#xff0c;其中封装了需要使用的内存与cpu 2.每当提交一个job,就会产生一个appMaster(总指挥),app Master负责其他container里面的…...

MFC实现背景透明,控件不透明的对话框,且点击图片有事件响应

最终成果&#xff1a;背景半透明、但是控件不透明的对话框。 对话框上用图片代表功能&#xff0c;当点击图片时&#xff0c;响应点击事件&#xff0c;弹出相对应的对话框。 对话框固定大小&#xff0c;不可放大缩小&#xff0c;以免影响图片的显示数量。 步骤一&#xff1a;背景…...

案例01-tlias智能学习辅助系统01-增删改查+参数传递

目录 1、需求说明&#xff1a;实现对部门表和员工表的增删改查 2、环境搭建 3、部门管理 3.1 查询部门 3.2 前后端联调 3.3 删除部门 3.4 新增部门 3.5 根据ID查询数据 3.5 修改部门 总结&#xff08;Controller层参数接收&#xff09;&#xff1a; 4、员工管理 4.…...

Spring之Bean的配置与实例

Spring之Bean的配置与实例 一、Bean的基础配置1. Bean基础配置【重点】配置说明代码演示运行结果 2. Bean别名配置配置说明代码演示打印结果 3. Bean作用范围配置【重点】配置说明代码演示打印结果 二、Bean的实例化1. Bean是如何创建的2. 实例化Bean的三种方式2.1 构造方法方式…...

“不保留活动”打开,导致app返回前台崩溃问题解决

问题描述 不保留活动开关打开&#xff0c;把app切入后台&#xff0c;会导致当前展示的Activity被回收&#xff0c;切到前台后重建。 我们有个业务场景是&#xff0c;Activity里面有个ViewPager2&#xff0c;VP里面放Fragment&#xff0c;Fragment的展示需要在Activity中做一些…...

解读vue3源码(3)——watch

Vue3的watch底层源码主要是通过使用Proxy对象来实现的。在Vue3中&#xff0c;每个组件实例都会有一个watcher实例&#xff0c;用于监听组件数据的变化。当组件数据发生变化时&#xff0c;watcher实例会触发回调函数&#xff0c;从而更新组件的视图。 Vue3的watch底层源码主要涉…...

优秀简历的HR视角:怎样打造一份称心如意的简历?

简历的排版应该简洁工整&#xff0c;注重细节。需要注意对齐和标点符号的使用&#xff0c;因为在排版上的细节需要下很大功夫。除此之外&#xff0c;下面重点讲述几点简历内容需要注意的地方。 要点1&#xff1a;不相关的不要写。 尤其是与应聘岗位毫不相关的实习经历&#x…...

系统集成项目管理工程师——考试重点(三)项目管理一般知识

1.项目定义&#xff1a; 为达到特定的目的&#xff0c;使用一定资源&#xff0c;在确定的期间内&#xff0c;为特定发起人提供独特的产品、服务或成果而进行的一系列相互关联的活动的集合。 2.项目目标&#xff1a; 成果性目标&#xff1a;项目产品本身 约束性目标&…...

为什么医疗保健需要MFT来帮助保护EHR文件传输

毫无疑问&#xff0c;医疗保健行业需要EHR技术来处理患者&#xff0c;设施&#xff0c;提供者等之间的敏感患者信息。但是&#xff0c;如果没有安全的MFT解决方案&#xff0c;您将无法安全地传输患者文件&#xff0c;从而使您的运营面临遭受数据泄露&#xff0c;尴尬&#xff0…...

对项目总体把控不足,项目经理应该怎么办?

公司现状&#xff1a;项目人员紧缺&#xff0c;只有两人了解此项目技术细节&#xff0c;其中一个不常驻现场&#xff0c;另一个是执行项目经理李伟。 项目经理王博是公司元老&#xff0c;同时负责多个项目&#xff0c;工作比较忙&#xff0c;不常驻现场&#xff0c;没有参加过…...

【学习笔记】CF603E Pastoral Oddities

先不考虑数据结构部分&#xff0c;尝试猜一下结论。 结论&#xff1a;一个连通块有解当且仅当连通块的度数为偶数。 然后这题要你最大边权最小。最无脑的方法就是直接上 lct \text{lct} lct。真省事啊 我第一眼想到的还是整体二分。这玩意非常好写。 但是为什么也可以用线段…...

如何使用ESP32-CAM构建一个人脸识别系统

有许多人识别系统使用签名、指纹、语音、手部几何、人脸识别等来识别人&#xff0c;但除了人脸识别系统。 人脸识别系统不仅可以用于安全目的来识别公共场所的人员&#xff0c;还可以用于办公室和学校的考勤目的。 在这个项目中&#xff0c;我们将使用 ESP32-CAM 构建一个人脸识…...

JavaWeb分页条件查询参数特殊字符处理

问题背景 在项目开发过程中&#xff0c;基本都会有列表条件查询&#xff0c;例如用户管理会有通过用户姓名模糊查询用户&#xff0c;课程管理会有课程名称模糊查询课程等等。 而查询过程中如果用户在界面上输入一些特殊字符&#xff0c;例如&#xff1a;%_等等&#xff0c;这…...

ubuntu18服务安装

一、JDK安装 将jdk解压缩到该目录 /opt/ sudo tar -zxvf jdk-8u261-linux-x64.tar.gz -C /opt/ #重命名 cd /opt sudo mv jdk-8u261-linux-x64 jdk_8 修改环境变量 sudo vi ~/.bashrc #在文件最后追加以下文本 #进入编辑器后输入以下指令&#xff1a; #1. G //将光标移到最后一…...

这些使用工具大推荐,现在知道不晚

1.Snip Snip是一款截图软件&#xff0c;它突出的优点就是可以制作滚动截图。 例如&#xff1a;对整个网页进行截图&#xff0c;使用Snip即可轻松获取&#xff0c;无需处理水印。 2.Sleep Cycle 快节奏、高压力的生活导致我们越来越晚睡觉&#xff0c;睡眠质量越来越差。 想提…...

【Java|golang】1048. 最长字符串链

给出一个单词数组 words &#xff0c;其中每个单词都由小写英文字母组成。 如果我们可以 不改变其他字符的顺序 &#xff0c;在 wordA 的任何地方添加 恰好一个 字母使其变成 wordB &#xff0c;那么我们认为 wordA 是 wordB 的 前身 。 例如&#xff0c;“abc” 是 “abac”…...

钢链数智,赋能实业——千匠网络钢铁产业电商系统,破解行业困局,激活钢铁增长新动能

钢铁行业作为国民经济的支柱产业&#xff0c;贯穿基建、制造、房地产、机械装备等核心领域&#xff0c;正处于从“规模扩张”向“质量提升”转型的关键阶段&#xff1a;从铁矿开采、冶炼轧制、钢材加工&#xff0c;到多级分销、终端采购、工程交付&#xff0c;全链路环节繁杂、…...

EmbeddingGemma-300m部署指南:Ollama镜像+Prometheus监控+日志追踪一体化

EmbeddingGemma-300m部署指南&#xff1a;Ollama镜像Prometheus监控日志追踪一体化 想快速搭建一个功能强大、易于管理的文本向量化服务吗&#xff1f;EmbeddingGemma-300m作为谷歌推出的轻量级嵌入模型&#xff0c;凭借其3亿参数和出色的性能&#xff0c;是构建本地语义搜索、…...

告别水印烦恼!3步轻松去水印,新手秒上手。

找到心仪的图片有水印、做设计好不容易找到的素材有水印、下载好看的壁纸有水印&#xff0c;遇到的好图全被水印扫兴&#xff1f;PS去水印&#xff0c;操作复杂&#xff0c;学习成本高&#xff0c;浪费时间&#xff1b;用专业去水印工具&#xff0c;收费昂贵&#xff0c;还有广…...

3步解锁网易云音乐:ncmdumpGUI让你的NCM文件重获自由

3步解锁网易云音乐&#xff1a;ncmdumpGUI让你的NCM文件重获自由 【免费下载链接】ncmdumpGUI C#版本网易云音乐ncm文件格式转换&#xff0c;Windows图形界面版本 项目地址: https://gitcode.com/gh_mirrors/nc/ncmdumpGUI 你是否曾经遇到过这样的烦恼&#xff1f;在网…...

从原理到代码:用Python实现简易变焦跟踪算法(OpenCV实战)

从原理到代码&#xff1a;用Python实现简易变焦跟踪算法&#xff08;OpenCV实战&#xff09; 在计算机视觉领域&#xff0c;变焦跟踪是一个既基础又关键的技术难题。想象一下&#xff0c;当你用手机拍摄远处景物时&#xff0c;镜头从广角切换到长焦的过程中&#xff0c;画面往往…...

Qwen3.5-2B多场景教程:农业技术人员上传病虫害图→识别种类→推荐药剂

Qwen3.5-2B多场景教程&#xff1a;农业技术人员上传病虫害图→识别种类→推荐药剂 1. 引言&#xff1a;农业病虫害识别的技术痛点 在农业生产中&#xff0c;病虫害防治一直是困扰农户的核心问题。传统识别方式存在三大痛点&#xff1a; 识别门槛高&#xff1a;需要专业农技人…...

掌握ModTheSpire:从入门到精通的开源模组加载工具实战指南

掌握ModTheSpire&#xff1a;从入门到精通的开源模组加载工具实战指南 【免费下载链接】ModTheSpire External mod loader for Slay The Spire 项目地址: https://gitcode.com/gh_mirrors/mo/ModTheSpire 认知铺垫&#xff1a;走进模组加载的技术世界 当你第一次尝试为…...

Python 数据库 ORM 实战:SQLAlchemy 详解

Python 数据库 ORM 实战&#xff1a;SQLAlchemy 详解 1. 背景与动机 ORM&#xff08;对象关系映射&#xff09;简化了数据库操作&#xff0c;使开发者可以使用面向对象的方式操作数据库。SQLAlchemy 是 Python 最强大的 ORM 工具&#xff0c;提供了灵活且功能丰富的数据库操作接…...

ThinkPHP6(TP6)控制器404问题排查与Nginx伪静态配置指南

1. 为什么你的TP6控制器总是404&#xff1f; 最近帮朋友排查一个ThinkPHP6项目&#xff0c;明明控制器写得没问题&#xff0c;路由也配置了&#xff0c;但一访问就蹦出个404页面。这种问题在新手部署TP6时特别常见&#xff0c;尤其是用Nginx服务器的环境。我自己第一次用TP6时也…...

MXene基单原子催化剂在电催化CO2还原中的电子结构调控与性能优化

1. MXene基单原子催化剂为何能成为CO2还原的"黑马"&#xff1f; 在碳中和背景下&#xff0c;电催化CO2还原技术就像一位"化学魔术师"&#xff0c;能把温室气体变废为宝。而MXene材料凭借其独特的层状结构和导电性&#xff0c;正成为这场魔术表演的明星道具…...