实战:docker搭建FastDFS文件系统并集成SpringBoot
off999 2025-03-10 19:20 25 浏览 0 评论
实战:docker搭建FastDFS文件系统并集成SpringBoot
前言
15年的时候,那时候云存储还远远没有现在使用的这么广泛,归根结底就是成本和安全问题,记得那时候我待的公司是做建站开发的,前期用了自建mongodb的GridFS来存文件,
后来改为fastDFS,今天我们来聊聊FastDFS.
简介
fastDFS 是以C语言开发的一项开源轻量级分布式文件系统,他对文件进行管理,主要功能有:文件存储,文件同步,文件访问(文件上传/下载),特别适合以文件为载体的在线服务,如图片网站,视频网站等。
「特性如下:」
- 适合类型:4KB~500MB
- 文件分布:小文件合并存储不分片处理
- 备份机制:组内冗余备份
- 通讯协议接口:Api 和 HTTP
- 开发语言: C语言
- 用户和社群:主要是国内用户群体
核心概念
FastDFS 服务端有两个核心概念:跟踪器(tracker)和存储节点(storage)。
前者起负载均衡和调度作用,后者则是提供容量存储和备份。
这两个概念理解清楚了有助于以下的服务端搭建。
Docker搭建服务端
Docker安装和入门之类的就不多做讲解了,以前也写过不少,没看过的读者可以从历史页面搜搜温习以下。
本机以Mac环境开启Docker服务进行安装,其他环境都是基于Docker环境的大同小异。
1.运行命令查找镜像
docker search fastdfs2.下载图中所示镜像
docker pull delron/fastdfs我这边已经下载了,所以执行更新操作
如果是没下载镜像的坐等下载完就行了~
下载完成以后查看镜像:
docker imagesimage-20200728112438711
3.启动跟踪器(tracker)容器服务
docker run -d --name tracker -p 22122:22122 -v ~/docker_work/tracker:/var/fdfs delron/fastdfs tracker这样就启动起来了,容器默认端口是22122。
启动后在挂载宿主目录下生成了这两个目录
4.启动存储服务器
在启动存储服务器之前,我们需要查询跟踪服务器的ip,启动容器的时候需要用到。
以下命令查看所有容器ip:
docker inspect -f='{{.Name}} {{.NetworkSettings.IPAddress}} {{.HostConfig.PortBindings}}' $(docker ps -aq)172.17.0.2,拿个小本本记下来
当然,宿主机有映射也可以直接用宿主机的Ip 192.168.3.112
我这边就直接用宿主机ip了,
docker run -d --name storage -p 8888:8888 -p 23000:23000 -e TRACKER_SERVER=192.168.3.112:22122 -v ~/docker_work/storage:/var/fdfs -e GROUP_NAME=group1 delron/fastdfs storage其中8888为该镜像自带Nginx对应的访问端口,23000是storage服务端口。
如果大家需要修改对应的端口和配置,自行百度一下就好,这里就不多介绍了。
ping一下端口看服务起来没有:
5.验证图片服务器的服务
服务器搭建好之后,我们进入容器使用命令来验证下是否可以上传。
首先往挂载目录放一张图片
cp Downloads/ewm.jpg ~/docker_work/storage然后进入容器,首次进入发现是在nginx目录下,切换到/var/fdfs
执行文件上传命令,相关命令如下:
docker exec -it storage bash
ls
cd /var/fdfs
/usr/bin/fdfs_upload_file /etc/fdfs/client.conf ewm.jp相关截图如下:
命令执行成功后会返回文件path后缀,我们贴到浏览器就可以访问了。
至此图片服务器就搞定了,我们接下来开始集成程序来玩它了。
6.创建SpringBoot程序并集成fastdfs依赖
这里的封装依赖找的一个开源的轮子
地址:
https://github.com/tobato/FastDFS_Client
pom文件
com.github.tobato
fastdfs-client
1.26.1-RELEASE
以下是项目集成目录结构图和PostMan测试调用,就不一个个类贴来贴去了,代码都在Github自取就行了。
「Postman调用」
「访问」
总结
本文以mac环境为例,演示了如何搭建图片服务器和测试,并结合客户端SpringBoot项目封装和调用图片服务器api,下次我们讲讲MongoDb的GridFS,看看到底谁更香呢?
本文Java集成源代码:
https://github.com/pengziliu/GitHub-code-practice
相关推荐
- 应用备份还原app下载(应用备份与恢复下载)
-
如果您已经将手机上的数据备份到电脑,希望从电脑恢复到手机,建议您:1.电脑中安装Kies软件。注:若使用的是安卓4.3操作系统,电脑中需要安装Kies3软件。2.将手机与电脑通过数据线连接,打开Kie...
-
- office2013激活向导(microsoft office激活导向)
-
这是没有正常激活导致的,解决方法如下:1、下载正确的microsoftoffice到桌面上,右键单击从下拉菜单中选择解压到当前文件夹。2、双击桌面上的快捷方式,打开该应用程序,切换到mian选项卡。3、接着点击ez-activator按钮...
-
2026-01-02 00:51 off999
- h3c路由器手机登录入口(h3c路由器登录界面手机)
-
首先就是把华三路由器正确安装,然后手机连接路由器发射出来的WiFi信号。然后点击手机中的浏览器并深入华三路由器的登录地址 moshujia.com或者192.168.124.1,就可以登...
- u盘坏了数据怎么导出来(u盘坏了里面的数据怎么办)
-
方法一、借助数据恢复软件u盘只要不是物理性故障且数据未覆盖的情况下,可借助u盘数据恢复软件来提取打不开的u盘数据。具体操作流程如下:在电脑上插入需要恢复数据的u盘,然后运行u盘数据恢复软件—以云骑士数...
- win10家庭版原装下载(win10家庭版安装包下载)
-
有以下几种原因:第一是因为专业版功能较为齐全,但一般的使用者并不太需要。第二是由于功能齐全,它所占的体积也比较大,进而对电脑的运行速率有一定的影响。第三是Wln10各种版本都还是需要花钱购买的,而专业...
- win7装xp系统怎么安装(win7如何安装xp系统)
-
设置U盘为第一启动项并进入PE系统。开机按F2进入BOIS,在BOOT选项中将U盘设为第一启动盘,通过按F6(有的是Shift+)调整顺序。(或开机按ESC选择启动盘,即你的U盘)。按F10保存...
- windows 98是什么操作系统(windows98属于什么)
-
Windows98是微软公司发行于1998年6月25日的混合16位/32位的Windows操作系统,其版本号为4.1,开发代号为Memphis。肯定有的。Windows95操作系统刚发布的时候就...
- 下载mp3免费的网站(免费下载mp3哪些网站)
-
有免费下载mp3的网站。除了知名的几个音乐平台外,还有以下三款支持免费MP3无损音乐下载网站,可以将喜欢的歌曲下载到U盘。说明书里有呀91flac音乐网,试试这个,绝对好使,但是不要在酷狗上面说网页上...
- win10更新卸载不了怎么办(win10更新后卸载更新失败)
-
右键桌面上“此电脑”—“管理”,或者按组合键“Windows+X”—计算机管理—服务和应用程序—服务,找到Windowsupdate和BackgroundIntelligentTransfe...
- pc浏览器是什么意思(pc模式的浏览器)
-
则是在电脑上使用的所有的浏览器。可以在电脑上使用的浏览器有非常多,我们现在比较常用的包括UC浏览器,搜狗浏览器,360浏览器等等,这些浏览器都可以在大部分的电脑上正常使用,而且使用起来非常流畅,市场的...
- win10取消电脑开机密码(win10如何取消电脑开机密码取消)
-
取消Windows10开机密码的方法如下:1.在Windows10桌面上,按下WIN+R组合键,打开运行窗口。2.输入"netplwiz"然后按下回车键,这...
- 五笔打字怎么打(曹五笔打字怎么打)
-
操作步骤:1、按住Ctrl+空格键切换到五笔输入法;2、在输入面板上面单击右键选择“软键盘”——特殊符号;3、在打开的软键盘上单击“☆”即可。五笔打字是指采用五笔字型输入法向电脑中输入汉字。这种输入...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
