鉴于网上有不少文章是关于FastDFS是如何使用的,博主也顺着花了一些时间搭建了关于FastDFS的安装和上传用例,并成功在虚拟机VMware上搭了两台,使之可以成功互相在浏览器上相互访问文件。先谈一下FastDFS和Nginx集成所需要的环境和包
硬件环境:华硕笔记本i5的CPU,8G内存,固态硬盘
软件环境:Win10(64位)、VMware12、Xshell5(ssh连接两个客户端)、WinSCP(传文件到两个系统中)
系统:两台CentOS7.1(64),
软件包:
1.FastDFS_V5.05.gar.gz
2.libfastcommon-master.tar.gz
3.fastdfs-nginx-module_v1.16.tar.gz
4.nginx-1.8.0.tar.gz
注意点:
1.以上版本必须一致,否则会出版本问题,无论两台还是多台机器,必须版本一致,减少潜在的问题
2.在安装前,要保证两个系统没有其它的软件环境,如没有安装过旧的FastDFS版本,如果有,必须将其完全删干净
3.在安装前,要确保前置库已经有,而且能接通公网,网速没问题
4.执行下面一段shell脚本,安装好前置环境:
yum install -y zlib zlib-devel pcre pcre-devel gcc gcc-c++ openssl openssl-devel libevent libevent-devel perl unzip
5.要使用root用户登录,并且博主的四个软件包都放在 /root/tmp/ 下
简单步骤:
1.关闭两台CentOS的防火墙,并固定其IP,博主这里设置为A机是ip为192.168.181.132和B机的ip为192.168.181.129,上传已经下载好的4个文件
2.先在一个系统中A进行操作,解压libfastcommon-master.tar.gz,配置及安装
3.解压FastDFS_V5.05.gar.gz ,并配置及安装
4.解压fastdfs-nginx-module_v1.16.tar.gz和nginx-1.8.0.tar.gz,配置并安装
5.在第二台B重复第一个步骤,然后两个系统中A和B启动FastDFS的tracker,查看进程和日志,如果有误,返回第2步
6.先后启动A和B中的storage,查看日志和进程信息,如有误,重新开始第2步
7.测 试上传文件,如果成功,在两个系统A和B中都会出现storage中都会出现相同的文件
8.启动nignx,并测 试A和B两个系统可以相互访问,然后打入链接,如浏览器中输入可以成功访问的话,目的便成功了。如果失败,返回第2步
详细步骤(图文,代码):
附:以下有几步是参考某一篇博文的,其中有几个步骤是在此的基础上搭建
在进入第2步之前,要先添加用户组:useradd -s /sbin/nologin fastdfs
解压 libfastcommon-master.tar.gz :
1) cd /root/tmp/
2) tar zxvf libfastcommon-master.tar.gz
3) cd libfastcommon-master/
4) ./make.sh
5)./make.sh install
1)tar zxf FastDFS_v5.05.tar.gz && cd FastDFS
2) vim ./FastDFS/conf/client.conf
base_path=/export/fastdfs/storage
tracker_server=192.168.181.129:22122
tracker_server=192.168.181.132:22122
3) vim ./FastDFS/conf/storage.conf
base_path=/export/fastdfs/storage
store_path0=/export/fastdfs/storage
tracker_server=192.168.181.129:22122
tracker_server=192.168.181.132.22122
http.server_port=80
4) vim ./FastDFS/conf/tracker.conf
base_path=/export/fastdfs/tracker
store_group=group1
http.server_port=80
5) ./make.sh
6) ./make.sh install
7)cp ./conf/*.conf /etc/fdfs/
8)cd /etc/fdfs/
9)rm -rf *.sample
10) chown -R fastdfs: /exp
1) cd /root/tmp
2) tar zxvf fastdfs-nginx-module_v1.16.tar.gz
3) vim ./fastdfs-nginx-module/src/mod_fastdfs.conf #下面是编辑的内容
base_path=/export/fastdfs/storage
tracker_server=192.168.181.129:22122
tracker_server=192.168.181.132:22122
group_name=group1
url_have_group_name = true
store_path0=/export/fastdfs/storage
4) vim ./fastdfs-nginx-module/src/config #对应当前版本的安装要改动的几个微调
CORE_INCS="$CORE_INCS /usr/include/fastdfs /usr/include/fastcommon/"
CORE_LIBS="$CORE_LIBS -L/usr/local/lib64 -lfastcommon -lfdfsclient"
5) cp ./fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
解压nginx-1.8.0.tar.gz
1) cd /root/tmp
2) tar zxvf nginx-1.8.0.tar.gz
3) cp ./nginx-1.8.0/conf/mime.types /etc/fdfs/ #必要的配置文件
4) vim ./nginx-1.8.0/conf/nginx.conf
location /group1/M00 {
root /export/fastdfs/storage/data/;
ngx_fastdfs_module;
}
5) cd nginx-1.8.0/
6)./configure --user=www --group=www --add-module=../fastdfs-nginx-module/src/ --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_realip_module
7)make
8)make install
7./usr/bin/fdfs_test /etc/fdfs/client.conf upload /root/data/image/1.jpg #上传文件,同时会在两个系统中同时存储
8. /usr/local/nginx/sbin/nginx #启动,两个系统之中都可以启动,可以打入地址访问 如地址: http://192.168.181.132/group1/M00/00/00/wKi1hFhve2WAfeYMAAJy7MaEBLY083_big.jpg
参考博文:
1.FastDFS_V5.05分布式存储安装与使用
2.FastDFS 5.08 部署与配置(包括老版本卸载)
3.搭建FastDFS分布式存储环境(使用Nginx模块)
4.FastDFS 安装及使用
5.FastDfs 学习进阶之环境安装及上传文件测试
6.分布式文件系统FastDFS设计原理