1.关于集群,网上说最少要三台,其实也没必要,两台就够了

2.实验环境

192.168.2.201  tracker、storage、nginx + fastdfs-nginx-module-master + ngx_cache_purge   keepalived

192.168.2.202  tracker、storage、nginx + fastdfs-nginx-module-master + ngx_cache_purge   keepalived

结构如上图所示:

开始搭建

1.准备:

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

2.安装libfastcommon

 解压libfastcommon-master.zip
[root@Node202 fastdfs-master]# cd /data/softwares/fastdfs [root@Node202 opt]# unzip -o libfastcommon-master.zip -d /usr/local [root@Node202 opt]# cd /usr/local/libfastcommon-master/ [root@Node202 libfastcommon-master]# ./make.sh [root@Node202 libfastcommon-master]# ./make.sh install

3.安装 fastdfs

 cd /data/softwares/fastdfs
unzip -o fastdfs-master.zip -d /usr/local
cd /usr/local/fastdfs-master
./make.sh
./make.sh install

4.拷贝配置文件

将fastdfs安装目录下的conf下的文件拷贝到/etc/fdfs/下

root@Node202 fastdfs-master]# cp -r conf/* /etc/fdfs/

fdfs可执行命令
[root@Node202 fdfs]# ll /usr/bin/fdfs*

5.配置并启动trackerd

 修改trackerd.conf
[root@Node202 fdfs]# cd /etc/fdfs/
[root@Node202 fdfs]# vim tracker.conf base_path=/data/fastdfs # 存储日志和数据的根目录 其它参数保留默认配置, 具体配置解释可参考官方文档说明:http://bbs.chinaunix.net/thread-1941456-1-1.html 创建trackerd数据、日志目录
[root@Node202 fdfs]# mkdir -p /data/fastdfs 启动trackerd
[root@Node202 fdfs]# /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
日志:/data/fastdfs/logs/trackerd.log [root@Node202 fdfs]# ps -ef | grep fdfs

6.配置并启动storaged

修改storage.conf

[root@Node202 fdfs]# cd /etc/fdfs/

[root@Node202 fdfs]# vim storage.conf

  base_path=/data/fastdfs
store_path0=/data/fastdfs
tracker_server=192.168.2.202:22122,这个ip改成自己的 启动storaged
[root@Node202 fdfs]# /usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
日志:/data/fastdfs/logs/storaged.log

7.FastDFS 和nginx整合

7.1 fastdfs-nginx-module模块,作用:通过nginx访问时,当访问的节点文件不存在时(没有同步过来),此模块会自动寻找源文件所属机器。

解压
[root@Node202 00]# cd /data/softwares/fastdfs
[root@Node202 opt]# unzip -o fastdfs-nginx-module-master.zip -d /usr/local 拷贝配置文件
[root@Node202 opt]# cd /usr/local/fastdfs-nginx-module-master/src
[root@Node202 src]# cp mod_fastdfs.conf /etc/fdfs/ 编辑配置文件
[root@Node202 src]# cd /etc/fdfs/
[root@Node202 fdfs]# vim mod_fastdfs.conf
base_path=/data/fastdfs
tracker_server=192.168.2.202:22122
url_have_group_name = true;#url中包含group名称
store_path0=/data/fastdfs

7.2 ngx_cache_purge模块 作用:删除缓存

解压缓存模块
[root@Node11 fdfs]# cd /data/softwares/fastdfs/
[root@Node11 fastdfs]# tar -zxvf ngx_cache_purge-2.3.tar.gz -C /usr/local/

8. 安装nginx

8.1 nginx依赖包安装

[root@Node202 fdfs]# cd /opt
[root@Node202 opt]# yum -y install zlib zlib-devel openssl openssl--devel pcre pcre-devel

8.2 安装nginx

解压nginx
[root@Node202 opt]# tar -zxvf nginx-1.14.2.tar.gz 安装nginx并添加两个模块
[root@Node202 opt]# cd /data/softwares/fastdfs/nginx-1.14.2
[root@Node202 nginx-1.14.2]# ./configure --prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module-master/src --add-module=/usr/local/ngx_cache_purge-2.3 [root@Node202 nginx-1.14.2]# make
[root@Node202 nginx-1.14.2]# make install

8.3 检验nginx

检查nginx模块
[root@Node12 nginx-1.14.2]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.14.2
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-36) (GCC)
configure arguments: --prefix=/usr/local/nginx --add-module=/usr/local/fastdfs-nginx-module-master/src --add-module=/usr/local/ngx_cache_purge-2.3 [root@Node202 opt]# /usr/local/nginx/sbin/nginx -t
ngx_http_fastdfs_set pid=13287
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

9.配置nginx配置文件

注意:创建文件夹:
mkdir -p /data/fastdfs/cache/nginx/proxy_cache/tmp

vim /usr/local/nginx/conf/nginx.conf

    proxy_cache_path /data/fastdfs/cache/nginx/proxy_cache levels=1:2 keys_zone=http-cache:200m max_size=1g inactive=30d;
proxy_temp_path /data/fastdfs/cache/nginx/proxy_cache/tmp; upstream fdfs_group1{
server 192.168.0.115:8888 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.0.244:8888 weight=1 max_fails=2 fail_timeout=30s;
} server {
listen 8888;
server_name 192.168.0.244; location ~/group[0-9]/ {
proxy_next_upstream http_502 http_504 error timeout invalid_header;
proxy_cache http-cache;
proxy_cache_valid 200 304 12h;
proxy_cache_key $uri$is_args$args;
proxy_pass http://fdfs_group1;
expires 30d; ngx_fastdfs_module;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}

10.启动nginx

启动
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf 重启nginx
/usr/local/nginx/sbin/nginx -s reload

11. 验证fastdfs上传功能

修改客户端文件:
vim /etc/fdfs/client.conf
base_path=/data/fastdfs
tracker_server=192.168.0.115:22122
tracker_server=192.168.0.244:22122 上传: /usr/bin/fdfs_upload_file /etc/fdfs/client.conf /opt/fu2.jpg 192.168.2.202:23000 0
/usr/bin/fdfs_test /etc/fdfs/client.conf upload /opt/fu.jpg 访问:
http://192.168.2.202:8888/group1/M00/00/00/wKgCylxQETeAZMTBAADsE2xyRuI261.jpg

12. 开机启动

将Tracker加入开机启动项

# cp /usr/fastdfs/FastDFS/init.d/fdfs_trackerd /etc/init.d/
# chkconfig --add fdfs_trackerd
# chkconfig fdfs_trackerd on 将Storage加入开机启动项 # cp /usr/fastdfs/FastDFS/init.d/fdfs_storaged /etc/init.d/
# chkconfig --add fdfs_storaged
# chkconfig fdfs_storaged on netstat -unltp | grep fdfs

 

Fastdfs集群搭建的更多相关文章

  1. 【开源组件】FastDFS集群搭建与实战

    FastDFS是一个轻量级的分布式文件系统,在实际生产环境往往以集群的形式部署,保证了服务的高可用.本文重点阐述FastDFS集群的搭建和项目实战. 工作流程 上传流程图 下载流程图 基本概念可参考作 ...

  2. fastdfs 集群搭建

    1.部署FastDFS及Nginx (本套FastDFS为简化版安装部署,只需解压至普通用户家目录下或者任意目录,解压后修改脚本,执行脚本后即可使用.) 说明:FastDFS分为tracker(默认端 ...

  3. 19.fastDFS集群理解+搭建笔记

    软件架构理解 1FastDFS介绍 1.1什么是FastDFS FastDFS是用c语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并 ...

  4. FastDFS教程IV-文件服务器集群搭建

    1.简介     本文主要介绍FastDFS文件服务器的集群搭建,在阅读本文之前,您需具备FastDFS文件服务器单节点安装,扩容,迁移等方面的知识.同时,您还需了解Keepalived,nginx方 ...

  5. fastdfs集群版搭建(一)- storage集群搭建与统一入口访问

    前言 接着上篇博客:详细的最新版fastdfs单机版搭建,今天来讲讲fastdfs的集群搭建,限于篇幅,今天先搭建stoarge集群,并实现统一的http访问方式: 没看我上篇博客的小伙伴,最好先去瞅 ...

  6. FastDFS+nginx+keepalived集群搭建

    安装环境 nginx-1.6.2 libfastcommon-master.zip FastDFS_v5.05.tar.gz(http://sourceforge.net/projects/fastd ...

  7. 手把手教你搭建FastDFS集群(下)

    手把手教你搭建FastDFS集群(下) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u0 ...

  8. 手把手教你搭建FastDFS集群(中)

    手把手教你搭建FastDFS集群(中) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u0 ...

  9. 手把手教你搭建FastDFS集群(上)

    手把手教你搭建FastDFS集群(上) 本文链接:https://blog.csdn.net/u012453843/article/details/68957209        FastDFS是一个 ...

随机推荐

  1. Nginx+PHP(FastCGI)高性能服务器加载redis+memcache模块

    1)Nginx+FastCGI安装配置: yum install  openssl openssl-devel pcre-devel pcre zlib zlib-devel –y #下载Nginx源 ...

  2. python 字典dict - python基础入门(15)

    前面的课程讲解了字符串str/列表list/元组tuple,还有最后一种比较重要的数据类型也需要介绍介绍,那就是python字典,俗称:dict. python中的字典可与字符串/列表/元组不同,因为 ...

  3. 批量添加删除Windows server DNS服务 恶意域名 * A记录 指向 127.0.0.1(2019年6月5日更新)

    下载链接:https://pan.baidu.com/s/1OUHyvnIfXYF0PdiT-VRyHw  密码:7gjj 注意!本解决方案在本地的Windows server服务器上把恶意域名指向1 ...

  4. Zookeeper开源客户端Curator之事件监听详解

    Curator对Zookeeper典型场景之事件监听进行封装,提供了使用参考.这篇博文笔者带领大家了解一下Curator的实现方式. 引入依赖 对于Curator封装Zookeeper的典型场景使用都 ...

  5. Linux 线程取消(pthread_cancel)

    基本概念 pthread_cancel调用并不等待线程终止,它只提出请求.线程在取消请求(pthread_cancel)发出后会继续运行,直到到达某个取消点(CancellationPoint).取消 ...

  6. [转帖]华为鲲鹏云服务器实战:华为云鲲鹏KC1实例 vs. 阿里云G5实例

    鲲鹏云服务器实战:华为云鲲鹏KC1实例 vs. 阿里云G5实例 https://m.ithome.com/html/444828.htm 2019-09-12 15:25IT之家 (阿迷) 今年一月份 ...

  7. NoSQL数据库一MongoDB基本使用

    如今的网站对数据存储要求越来越灵活,在这种需求下 NoSQL 也就是非关系数据库越来越流行.所谓非关系数据库,是指不使用 SQL 语言进行数据操作的数据库的统称.这类数据库存储数据时没有固定的模式,不 ...

  8. 一个好隐蔽的C/C++代码bug

    来自:微博@ruanyf, 一本书上说,下面的 C 语言代码可能会产生无限循环.看了半天,才意识到 Bug 在哪里. 完美解答: 数组下标越界.数组a总共有10个值,a[0]~a[9].for循环里面 ...

  9. springboot整合thymeleaf——引用静态资源

    原html src="/css/index.css" thymeleaf中,th:src="@{/css/index.css}"

  10. 体验Managed Extensibility Framework精妙的设计

    MEF(Managed Extensibility Framework)是.NET Framework 4.0一个重要的库,Visual Studio 2010 Code Editor的扩展支持也是基 ...