1. 云服務器下安裝FastDFS
1.2 環境前置要求
- 本地虛擬機/云服務器:CentOS7.x 版本
- 將FastDFS 和 Nginx 相關的軟體壓縮包下載完成并上傳到云服務器中,下載鏈接如下:
- nginx-1.18.0.tar.gz
- libfastcommon-1.0.38.tar.gz
- fastdfs-5.11.tar.gz
- fastdfs-nginx-module-1.20.tar.gz
下載完成后如圖:

將下載的壓縮檔案通過Xftp 6 上傳到云服務器指定路徑下,我指定的路徑是:/usr/local/src/software

1.3 安裝單節點的FastDFS
因為我這里只是用FastDFS 去做檔案服務器,個人開發不需要用到集群的FastDFS,而且個人也沒有多臺服務器的環境!如果有需要,可以找一篇關于FastDFS集群環境搭建的文章閱讀!
1.3.1 安裝gcc 和nginx 依賴庫
因為FastDFS 本身就是淘寶的大牛用C語言寫的,所以其依賴于對C進行編譯的環境 gcc,安裝命令如下:
yum -y install gcc
除了gcc之外,還需要安裝nginx 相關的依賴庫,因為后續要安裝 nginx :
yum install pcre pcre-devel
yum install zlib zlib-devel
yum install openssl openssl--devel
yum install libevent
注意:如果你本機安裝的nginx壓縮包不是tar.gz而是zip格式的,這時候需要自己下載一下解壓zip格式檔案的命令unzip,下載命令如下:
yum install -y unzip zip
1.3.2 安裝libfastcommon
我們進入上傳軟體壓縮包的路徑:cd /usr/local/src/software
解壓:
tar -zxvf libfastcommon-1.0.38
進入解壓完成后的目錄:
cd libfastcommon-1.0.38/
執行編譯并且安裝:
./make.sh
./make.sh install
1.3.3 安裝fastdfs
解壓:
tar -zxvf fastdfs-5.11.tar.gz
進入解壓完成后的目錄:
cd fastdfs-5.11/
執行編譯并且安裝:
./make.sh
./make.sh install
如果安裝成功,會看到/etc/init.d/下看到提供的腳本檔案:

fdfs_trackerd是tracker啟動腳本fdfs_storaged是storage啟動腳本
能夠在 /etc/fdfs/ 目錄下看到默認的組態檔模板:
ll /etc/fdfs/
結果如下:
-rw-r--r-- 1 root root 1461 Dec 9 20:26 client.conf.sample
-rw-r--r-- 1 root root 7927 Dec 9 20:26 storage.conf.sample
-rw-r--r-- 1 root root 7389 Dec 9 20:26 tracker.conf.sample
tarcker.conf.sample是tracker的組態檔模板storage.conf.sample是storage的組態檔模板client.conf.sample是客戶端的組態檔模板
1.3.4 配置并啟動tracker服務
FastDFS 的 tracker 和 storage 在剛剛的安裝程序中,都已經被安裝了,因此我們安裝這兩種角色的方式是一樣的,不同的是,兩種需要不同的組態檔,
我們要啟動tracker,就修改剛剛看到的tarcker.conf,并且啟動fdfs_trackerd腳本即可:
1)首先將模板檔案復制:
cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf
2)修改復制后的組態檔:
vim /etc/fdfs/tracker.conf
# 修改的內容如下:
base_path=/fastdfs_files/tracker # 自己指定的存盤日志和資料的根目錄

因為自己指定的目錄默認是不存在的,所以修改過組態檔后,我們新建一下該目錄:
mkdir -p /fastdfs_files/tracker
注意:如果使用的是本地虛擬機請關閉防火墻,云服務器記得開放安全組對應的埠!下面是我的云服務器開放的埠,FastDFS 默認需要23000 和 22122 兩個埠:

4)啟動和停止:
-
啟動tracker服務器:
/etc/init.d/fdfs_trackerd start -
停止tracker服務器:
/etc/init.d/fdfs_trackerd stop
不過安裝程序中,fdfs 已經被設定為系統服務,我們可以采用熟悉的服務啟動方式:
service fdfs_trackerd start # 啟動fdfs_trackerd服務,停止用stop
檢查FastDFS Tracker Server是否啟動成功:
ps -ef | grep fdfs_trackerd

如果是本地虛擬機,不想每次開機都重新啟動該服務,可以將其設定為開啟自啟動:
chkconfig fdfs_trackerd on
1.3.5 配置并啟動storage服務
步驟類似于1.3.4:
1)首先將模板檔案復制:
cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf
2)修改復制后的組態檔:
vim /etc/fdfs/storage.conf
# 修改的內容如下:
base_path=/fastdfs_files/storage # 資料和日志檔案存盤根目錄
store_path0=/fastdfs_files/storage # 第一個存盤目錄
tracker_server=本機ip:22122 # tracker服務器IP和埠
因為自己指定的目錄默認是不存在的,所以修改過組態檔后,我們新建一下該目錄:
mkdir -p /fastdfs_files/storage
3)啟動和停止:
- 啟動storage服務器:
/etc/init.d/fdfs_storaged start - 停止storage服務器:
/etc/init.d/fdfs_storaged stop
推薦使用如下方式啟動:
service fdfs_storaged start # 啟動fdfs_storaged服務,停止用stop
可以使用 ps -ef | grep fdfs 查看行程:

如果是本地虛擬機,不想每次開機都重新啟動該服務,可以將其設定為開啟自啟動:
chkconfig fdfs_trackerd on
再次提醒:本地虛擬機關閉防火墻,云服務器開啟安全組埠!
2. 使用nginx訪問FastDFS
2.1 安裝fastdfs-nginx-module
2.1.1 解壓
tar -zxvf fastdfs-nginx-module-1.20.tar.gz
2.1.2 修改config檔案
1)進入解壓后的檔案夾下的src目錄
cd fastdfs-nginx-module-1.20/src/

2)編輯config
vim config
使用以下底行命令:
:%s+/usr/local/+/usr/+g
將所有的/usr/local替換為 /usr,這個才是正確的目錄:

2.1.3 配置nginx與FastDFS關聯組態檔
復制 fastdfs-nginx-module-1.20 原始碼中的組態檔到/etc/fdfs 目錄, 并修改:
cp /usr/local/src/software/fastdfs-nginx-module-1.20/src/mod_fastdfs.conf /etc/fdfs/
vim /etc/fdfs/mod_fastdfs.conf
修改以下配置:
connect_timeout=10 # 客戶端訪問檔案連接超時時長(單位:秒)
tracker_server=本機ip:22122 # tracker服務IP和埠
url_have_group_name=true # 訪問鏈接前綴加上組名
store_path0=/fastdfs_files/storage # 檔案存盤路徑
復制 FastDFS 的部分組態檔到/etc/fdfs 目錄:
cd /usr/local/src/software/fastdfs-5.11/conf/
cp http.conf mime.types /etc/fdfs/
2.2 安裝Nginx的插件
因為文章 1.3.1 小節已經安裝了 nginx 依賴庫,所以這里不需要再安裝:
# 如果前面沒安裝,這里就需要安裝虛啊 nginx依賴庫:
yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
2.2.1 解壓安裝包
tar -zxvf nginx-1.18.0.tar.gz
2.2.2 配置nginx安裝包并指定fastdfs-nginx-model
# 進入解壓后的nginx-1.18.0 目錄:
cd nginx-1.18.0/
# 執行以下命令:
./configure --prefix=/opt/nginx --sbin-path=/usr/bin/nginx --add-module=/usr/local/src/software/fastdfs-nginx-module-1.20/src/
注意:在執行./configure 配置nginx 引數的時候,需要將 fastdfs-nginx-moudle 原始碼作為模塊編譯進去,
2.2.3 編譯并安裝
make && make install
2.2.4 啟動nginx
配置nginx整合fastdfs-module模塊,我們需要修改nginx組態檔,在/opt/nginx/config/nginx.conf 檔案中:
vim /opt/nginx/conf/nginx.conf
將檔案中,原來的server 80{ ...} 部分代碼替換為如下代碼:
server {
listen 80;
server_name 你的域名;
# 監聽域名中帶有group的,交給FastDFS模塊處理
location ~/group([0-9])/ {
ngx_fastdfs_module;
}
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
啟動命令:
nginx # 啟動nginx
nginx -s stop # 停止nginx
nginx -s reload # 重新載入組態檔
可通過ps -ef | grep nginx查看nginx是否已啟動成功:

3. 使用SpringBoot 整合FastDFS
3.1 相關依賴
<dependency>
<groupId>com.github.tobato</groupId>
<artifactId>fastdfs-client</artifactId>
</dependency>
3.2 相關配置引數
# fastDFS 相關配置
fdfs:
so-timeout: 1501 # 讀取超時時間
connect-timeout: 601 # 連接超時時間
thumb-image: # 縮略圖配置
width: 60
height: 60
tracker-list: # tracker地址:你的虛擬機服務器地址+埠(默認是22122)
- 你的服務器ip:22122
3.3 相關配置類
/**
* @Auther: csp1999
* @Date: 2020/12/10/11:29
* @Description: fastDFS 客戶端配置類
*/
@Configuration
@Import(FdfsClientConfig.class)
// 解決jmx重復注冊bean的問題
@EnableMBeanExport(registration = RegistrationPolicy.IGNORE_EXISTING)
public class FastDfsClientConfig {
}
3.4 測驗類中進行測驗
/**
* @Auther: csp1999
* @Date: 2020/12/10/11:33
* @Description: 測驗FastDFS 檔案上傳
*/
@SpringBootTest
@RunWith(SpringRunner.class)
public class FastDFSTest {
// fastDFS 存盤客戶端
@Autowired
private FastFileStorageClient storageClient;
// 用于獲取 fastDFS 圖片縮略圖
@Autowired
private ThumbImageConfig thumbImageConfig;
@Test
public void testUpload() throws FileNotFoundException {
// 獲取本機要上傳的檔案
File file = new File("M:\\code\\IDEA\\leyou\\image\\lf.jpg");
/**
* 上傳并保存圖片
*
* 引數:
* 1-上傳的檔案流
* 2-檔案的大小
* 3-檔案的后綴
* 4-可以不管他
*/
StorePath storePath = this.storageClient.uploadFile(
new FileInputStream(file), file.length(), "jpg", null);
// 帶分組的路徑
System.out.println(storePath.getFullPath());
// 不帶分組的路徑
System.out.println(storePath.getPath());
}
@Test
public void testUploadAndCreateThumb() throws FileNotFoundException {
// 獲取本機要上傳的檔案
File file = new File("M:\\code\\IDEA\\leyou\\image\\bz4.jpg");
/**
* 上傳并保存圖片并且生成縮略圖
*
* 引數:
* 1-上傳的檔案流
* 2-檔案的大小
* 3-檔案的后綴
* 4-可以不管他
*/
StorePath storePath = this.storageClient.uploadImageAndCrtThumbImage(
new FileInputStream(file), file.length(), "png", null);
// 帶分組的路徑
System.out.println(storePath.getFullPath());
// 不帶分組的路徑
System.out.println(storePath.getPath());
// 獲取縮略圖路徑
String path = thumbImageConfig.getThumbImagePath(storePath.getPath());
System.out.println(path);
}
}
先測驗testUpload() 方法,輸出結果:

然后我們就可以通過服務器ip地址/group1/M00/00/00/wKg4ZVsWl5eAdLNZAABAhya2V0c424.jpg,去訪問圖片:

同理我們測驗testUploadAndCreateThumb() 帶縮略圖的方法,輸出結果如下:
group1/M00/00/00/rBHaFV_Rmq6AC7m3AAQvu4hOzN4945.png # 帶分組的路徑
M00/00/00/rBHaFV_Rmq6AC7m3AAQvu4hOzN4945.png # 不帶分組的路徑
M00/00/00/rBHaFV_Rmq6AC7m3AAQvu4hOzN4945_60x60.png # 縮略圖路徑
我們先看下不是縮略圖的效果:ip地址/group1/M00/00/00/rBHaFV_Rmq6AC7m3AAQvu4hOzN4945.png

再看下縮略圖的效果:ip地址/group1/M00/00/00/rBHaFV_Rmq6AC7m3AAQvu4hOzN4945_60x60.png

圖片大小是我們在組態檔中配置的寬高60px! 我們可以到服務器/fastdfs_files/storage/data/路徑下查看上傳的圖片:

SpringBoot整合FastDFS完成!
擴展:除了FastDFS分布式檔案上傳,現在開發中基于OSS的檔案上傳也很常用,可以參考下面這篇文章學習:
springboot操作阿里云OSS實作檔案上傳,下載,洗掉(附原始碼)
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/233119.html
標籤:其他
上一篇:了解OpenStak基礎架構
