2024-11-21 ngxin 与 fdsf分布式文件存储

1.创建临时目录,存放需要用到的安装包(装完可删除):

mkdir /usr/local/fastdfs_install

2.将 libfastcommon-master.tar.gz 上传到 fastdfs_install 目录 ,然后解压:

tar -zxf libfastcommon-master.tar.gz

3.进入解压后的目录:cd libfastcommon-master

4.编译、安装:

./make.sh

./make.sh install

5.将 FastDFS_v6.06.tar.gz 上传到 fast_install 目录 ,然后解压:

tar -zxf FastDFS_v6.06.tar.gz

6.进入解压后的目录:cd FastDFS

7.编译、安装:

./make.sh

./make.sh install

6.0以后得版本需要执行./setup.sh /etc/fdfs

8.安装成功后可执行文件在如下目录:ll /usr/bin/fdfs*

9.配置文件在:ll /etc/fdfs

10.创建tracker目录: mkdir /data/tracker

11.给目录权限:chmod -R 777 /data

12.将配置文件拷贝一份,再编辑:

# 进入配置文件目录:cd /etc/fdfs

# 拷贝一份:cp tracker.conf.sample tracker.conf

# 编辑:vi tracker.conf

13.主要配置参数如下:

#启用配置文件

disabled=false

#设置tracker的端口号

port=9010

#设置tracker的数据文件和日志目录(需预先创建)

base_path=/data/tracker

#设置http端口号

http.server_port=9011

14.启动,并查看是否安装成功:

# 启动:/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

# 查看状态:ps -ef | grep fdfs

15.创建storage目录:mkdir /data/storage

16.将配置文件拷贝一份,在编辑:

# 配置文件目录:cd /etc/fdfs

# 拷贝一份:cp storage.conf.sample storage.conf

# 再编辑:vi storage.conf

17.主要配置文件参数如下:地址不能配置127.0.0.1 要配置ip,否则会报错

# 启用配置文件

disabled=false

# 组名,根据实际情况修改

group_name=group1

# 设置storage的端口号

port=23000

# 设置storage的日志目录(需预先创建)

base_path=/data/storage

# 存储路径个数,需要和store_path个数匹配

store_path_count=1

# 存储路径

store_path0=/data/storage

#tracker服务器的IP地址和端口号

tracker_server=IP:9010

# 设置http端口号

http.server_port=8888

18.启动,并查看是否安装成功:

# 启动 /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

# 查看是否成功 ps -ef | grep fdfs

# 通过fdfs_monitor查看storage服务器是否已经登记到tracker服务器

/usr/bin/fdfs_monitor /etc/fdfs/storage.conf

19.设置开机自启,打开开机自启配置文件:vi /etc/rc.d/rc.local

把启动命令放进去:/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

                                /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

21.到这一步FastDFS就基本配置完了,下面内容是集成Nginx以便使用HTTP进行访问文件。

22.先创建一个安装nginx模块的目录:mkdir /data/ngs

23.将 tar -zxf fastdfs-nginx-module_v1.16.tar.gz 上传到fastdfs_install 目录,解压:

tar -zxf fastdfs-nginx-module_v1.16.tar.gz

24.1.把fastdfs-nginx-module复制到 /data/ngs下:cp -R fastdfs-nginx-module /data/ngs/

25.然后找到以前nginx的源码包,如果找不到了,重新下一个,再配置、编译一次:

# 配置 ./configure --add-module=/data/ngs/fastdfs-nginx-module/src

#   make  注意这里千万不要make install,不然就覆盖安装了

(1)报了个错:make[1]: *** [objs/addon/src/ngx_http_fastdfs_module.o] 错误 1

 解决办法,nginx源码的解压目录,里面有一个client目录,进入client 编译、安装:

make && make install

 (2)再回到nginx源码的解压目录,执行make继续报错,则修改config文件如下(去掉local):

# 打开conifg文件  vi /data/ngs/fastdfs-nginx-module/src/config

# 把 /usr/local/include 路径中的 local 去掉 如下:

CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon/"

 (3)make 报错-Werror=format-truncation

这是警告信息,但是会认为是报错,./configure --add-module=/data/ngs/fastdfs-nginx-module/src后,在/mnt/nginx-1.26.2/objs 下Makefile 里去掉 Werror,make即可;

29.编译成功,然后把以前的nginx可执行文件,用objs目录下的同名文件覆盖掉:

先停掉nginx服务:systemctl stop nginx

cp objs/nginx /usr/local/nginx/sbin/nginx

30.把模块src下的 mod_fastdfs.conf 文件拷贝到 /etc/fdfs 下:

cp /data/ngs/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/

31.打开配置文件:vi /etc/fdfs/mod_fastdfs.conf

32.修改配置文件:

# 存放log目录

base_path=/data/storage

# tracker服务器IP和端口(可写多个)

tracker_server=172.17.3.1:8090

# storage所属的服务器组名

group_name=group1

# url中是否包含group名称

url_have_group_name=true

# 放置文件目录(可写多个)

store_path0=/data/storage

33.修改完成后,启动nginx发现有错误如下:

2019/12/24 22:44:31 [notice] 187972#0:

signal process started ngx_http_fastdfs_process_init pid=187973

[2019-12-24 22:44:31] ERROR -

file: ini_file_reader.c, line: 1029, include file "http.conf" not exists,

line: "#include http.conf"

[2019-12-24 22:44:31] ERROR -

file: /data/nmp/fastdfs-nginx-module/src/common.c, line: 155,

load conf file "/etc/fdfs/mod_fastdfs.conf" fail, ret code: 2

2019/12/24 22:44:31 [alert] 174211#0:

worker process 187973 exited with fatal code 2 and cannot be respawned

34.把FastDFS安装包下的conf文件夹下的http.conf和mime.types复制到/etc/fdfs下,重启nginx:

cp /usr/local/fastdfs_install/FastDFS/conf/http.conf /etc/fdfs/

cp /usr/local/fastdfs_install/FastDFS/conf/mime.types /etc/fdfs/

35.最后在nginx中加入FastDFS存储路径:

server {

        listen      80;

        server_name  localhost;

location ~/group[0-9]/ {

          ngx_fastdfs_module;

    }

}

36.测试文件,通过存储路径就可以通过HTTP直接访问:

http://127.0.0.1/group1/M00/00/00/rBEDAV4CMxmAE6paAAC0X34vITI912.jpg

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容