20-Linux搭建FastDFS

1.編譯環(huán)境

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

2.創(chuàng)建磁盤目錄

a. 創(chuàng)建數(shù)據(jù)存儲目錄
mkdir /home/dfs
b.切換到安裝目錄準(zhǔn)備下載安裝包
cd /usr/local/src

3.安裝libfatscommon

a.下載git安裝包
git clone https://github.com/happyfish100/libfastcommon.git --depth 1
b.編譯安裝
cd libfastcommon/
./make.sh && ./make.sh install

4.安裝FastDFS

a.返回上一級目錄
cd ../
b.下載git安裝包
git clone https://github.com/happyfish100/fastdfs.git --depth 1
c.進(jìn)入目錄
cd fastdfs/
d.編譯安裝
./make.sh && ./make.sh install
e.配置文件準(zhǔn)備
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/
cp /usr/local/src/fastdfs/conf/mime.types /etc/fdfs/

5.安裝fastdfs-nginx-module

a.返回上一級目錄
cd ../

b.下載git安裝包
git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1

c.復(fù)制配置文件
cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs

6.安裝nginx

a.下載nginx壓縮包
wget http://nginx.org/download/nginx-1.15.4.tar.gz
b.解壓
tar -zxvf nginx-1.15.4.tar.gz
c.進(jìn)入nginx目錄
cd nginx-1.15.4/
d.添加fastdfs-nginx-module模塊到nginx
./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/
e.編譯安裝
make && make install

7.修改配置

a.tracker配置
vim /etc/fdfs/tracker.conf

#需要修改的內(nèi)容如下
port=22122  # tracker服務(wù)器端口(默認(rèn)22122,一般不修改)
base_path=/home/dfs  # 存儲日志和數(shù)據(jù)的根目錄

b.storage配置
vim /etc/fdfs/storage.conf

#需要修改的內(nèi)容如下
port=23000  # storage服務(wù)端口(默認(rèn)23000,一般不修改)
base_path=/home/dfs  # 數(shù)據(jù)和日志文件存儲根目錄
store_path0=/home/dfs  # 第一個(gè)存儲目錄
tracker_server=192.168.52.1:22122  # tracker服務(wù)器IP和端口
http.server_port=8888  # http訪問文件的端口(默認(rèn)8888,看情況修改,和nginx中保持一致)

c.client測試
vim /etc/fdfs/client.conf

#需要修改的內(nèi)容如下
base_path=/home/dfs
tracker_server=192.168.52.1:22122    #tracker服務(wù)器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

d.配置nginx訪問
vim /etc/fdfs/mod_fastdfs.conf

#需要修改的內(nèi)容如下
tracker_server=192.168.52.1:22122  #tracker服務(wù)器IP和端口
url_have_group_name=true
store_path0=/home/dfs

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;
    }
}

8.啟動(dòng)命令

a.tracker

/etc/init.d/fdfs_trackerd start #啟動(dòng)tracker服務(wù)
/etc/init.d/fdfs_trackerd restart #重啟動(dòng)tracker服務(wù)
/etc/init.d/fdfs_trackerd stop #停止tracker服務(wù)
chkconfig fdfs_trackerd on #自啟動(dòng)tracker服務(wù)

b.storage

/etc/init.d/fdfs_storaged start #啟動(dòng)storage服務(wù)
/etc/init.d/fdfs_storaged restart #重動(dòng)storage服務(wù)
/etc/init.d/fdfs_storaged stop #停止動(dòng)storage服務(wù)
chkconfig fdfs_storaged on #自啟動(dòng)storage服務(wù)

c.nginx

/usr/local/nginx/sbin/nginx #啟動(dòng)nginx
/usr/local/nginx/sbin/nginx -s reload #重啟nginx
/usr/local/nginx/sbin/nginx -s stop #停止nginx

檢查集群狀態(tài)

/usr/bin/fdfs_monitor /etc/fdfs/storage.conf
# 會(huì)顯示會(huì)有幾臺服務(wù)器 有3臺就會(huì) 顯示 Storage 1-Storage 3的詳細(xì)信息

9.建立Springboot項(xiàng)目訪問測試

a.引入swagger和fdfs依賴

        <!-- FastDFS依賴 -->
        <dependency>
            <groupId>com.github.tobato</groupId>
            <artifactId>fastdfs-client</artifactId>
            <version>1.26.5</version>
        </dependency>
        <!-- swagger用于定義API文檔 -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

        <!--美化swagger-->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>swagger-bootstrap-ui</artifactId>
            <version>1.9.3</version>
        </dependency>

b.編寫swagger和fdfs配置類

package com.xiaokai.demo.springboot.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

/**
 * SwaggerConfig
 * Description: <br/>
 * date: 2020/5/3 18:54<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@Configuration
public class SwaggerConfig {

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.xiaokai.demo.springboot.controller")) //此次每次使用須換成自己的web接口的全限定類名
                //.paths(AppUtility.isProd() ? PathSelectors.none() : PathSelectors.any())
                .paths(PathSelectors.any())
                .build();
    }
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("FastDFS - 文件測試接口")
                .description("FastDFS - 文件測試接口")
                .termsOfServiceUrl("http://localhost:8071/swagger-ui.html")
                .contact(new Contact("xiaokai.lv", "http://localhost:8071/swagger-ui.html", "lvxiaokai@aliyun.com"))
                .version("1.0")
                .build();
    }
}

fdfs配置

package com.xiaokai.demo.springboot.config;

import com.github.tobato.fastdfs.FdfsClientConfig;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.EnableMBeanExport;
import org.springframework.context.annotation.Import;
import org.springframework.jmx.support.RegistrationPolicy;

/**
 * DfsConfig
 * Description: <br/>
 * date: 2020/5/3 18:51<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@Configuration
@Import(FdfsClientConfig.class)
// Jmx重復(fù)注冊bean的問題
@EnableMBeanExport(registration = RegistrationPolicy.IGNORE_EXISTING)
public class DfsConfig {
}

建立測試Controller

package com.xiaokai.demo.springboot.controller;

import com.xiaokai.demo.springboot.util.FileDfsUtil;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.http.ResponseEntity;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import javax.annotation.Resource;

/**
 * 一些聲明信息
 * Description: <br/>
 * date: 2020/5/3 18:56<br/>
 *
 * @author lvxk<br />
 * @since JDK 1.8
 */
@RestController
@Api(tags = "FastDFS文件測試")
public class FileController {

    @Resource
    private FileDfsUtil fileDfsUtil ;
    /**
     * 文件上傳
     */
    @ApiOperation(value="上傳文件", notes="測試FastDFS文件上傳")
    @RequestMapping(value = "/uploadFile",headers="content-type=multipart/form-data", method = RequestMethod.POST)
    public ResponseEntity<String> uploadFile (@RequestParam("file") MultipartFile file){
        String result ;
        try{
            String path = fileDfsUtil.upload(file) ;
            if (!StringUtils.isEmpty(path)){
                result = path ;
            } else {
                result = "上傳失敗" ;
            }
        } catch (Exception e){
            e.printStackTrace() ;
            result = "服務(wù)異常" ;
        }
        return ResponseEntity.ok(result);
    }
    /**
     * 文件刪除
     */
    @RequestMapping(value = "/deleteByPath", method = RequestMethod.GET)
    public ResponseEntity<String> deleteByPath (){
        String filePathName = "group1/M00/00/00/wKhIgl0n4AKABxQEABhlMYw_3Lo825.png" ;
        fileDfsUtil.deleteFile(filePathName);
        return ResponseEntity.ok("SUCCESS") ;
    }
}

c.打開swagger頁面測試上傳接口選擇圖片并上傳萤晴,成功會(huì)返回url


image.png

d.瀏覽器輸入服務(wù)器ip:8888/url地址即可


image.png
auto:
    mapping:
        url: '/hello #自定義路由規(guī)則'
nacos:
    name: lvxiaokai6-27
server:
    port: 8887
spring:
    application:
        name: demo-springboot-lvxiaokai
    servlet:
      multipart:
        enabled: true
        max-file-size: 10MB
        max-request-size: 20MB

fdfs:
  # 鏈接超時(shí)
  connect-timeout: 600
  # 讀取時(shí)間
  so-timeout: 600
  # 生成縮略圖參數(shù)
  thumb-image:
    width: 150
    height: 150
  tracker-list: 192.168.79.136:22122
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
禁止轉(zhuǎn)載汤踏,如需轉(zhuǎn)載請通過簡信或評論聯(lián)系作者妄荔。
  • 序言:七十年代末怕品,一起剝皮案震驚了整個(gè)濱河市甚牲,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌呢袱,老刑警劉巖暴氏,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異音诈,居然都是意外死亡幻碱,警方通過查閱死者的電腦和手機(jī)绎狭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來褥傍,“玉大人儡嘶,你說我怎么就攤上這事』蟹纾” “怎么了蹦狂?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長朋贬。 經(jīng)常有香客問我凯楔,道長,這世上最難降的妖魔是什么兄世? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任啼辣,我火速辦了婚禮啊研,結(jié)果婚禮上御滩,老公的妹妹穿的比我還像新娘。我一直安慰自己党远,他們只是感情好削解,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著沟娱,像睡著了一般氛驮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上济似,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天矫废,我揣著相機(jī)與錄音,去河邊找鬼砰蠢。 笑死蓖扑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的台舱。 我是一名探鬼主播律杠,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼竞惋!你這毒婦竟也來了柜去?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤拆宛,失蹤者是張志新(化名)和其女友劉穎嗓奢,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浑厚,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蔓罚,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年椿肩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片豺谈。...
    茶點(diǎn)故事閱讀 40,505評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡郑象,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出茬末,到底是詐尸還是另有隱情厂榛,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布丽惭,位于F島的核電站击奶,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏责掏。R本人自食惡果不足惜柜砾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望换衬。 院中可真熱鬧痰驱,春花似錦、人聲如沸瞳浦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽叫潦。三九已至蝇完,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間矗蕊,已是汗流浹背短蜕。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留傻咖,地道東北人朋魔。 一個(gè)月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像没龙,于是被迫代替她去往敵國和親铺厨。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內(nèi)容