linux单机搭建FastDFS+Nginx实现文件服务器

环境:阿里云服务器centos6.4(文内使用一个假ip代替服务器ip)

工具:xshell、xftp

安装包:FastDFS_v5.05.tar.gz、fastdfs-nginx-module_v1.16.tar.gz、libfastcommonV1.0.7.tar.gz

前言

当你准备按照我的步骤安装时,请你拿出2个小时左右的时间,慢慢的安装,千万不要写错配置文件,那样你可能要rm -rf删除所有相关文件,重头在装一遍。或者像我花一上午的时间才发现是配置文件里面大小写字母写错了。

1.FastDFS介绍

如果你并不了解FastDFS,最好能把中间加粗的介绍和图片看一遍。

1.1什么是FastDFS

FastDFS是用c语言编写的一款开源的分布式文件系统。FastDFS为互联网量身定制,充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务

1.2FastDFS架构

FastDFS架构包括 Tracker server和Storage server。客户端请求Tracker server进行文件上传、下载,通过Tracker server调度最终由Storage server完成文件上传和下载。

Tracker server作用是负载均衡和调度,通过Tracker server在文件上传时可以根据一些策略找到Storage server提供文件上传服务。可以将tracker称为追踪服务器或调度服务器。

Storage server作用是文件存储,客户端上传的文件最终存储在Storage服务器上,Storage server没有实现自己的文件系统而是利用操作系统 的文件系统来管理文件。可以将storage称为存储服务器。

如下图:

1.2.1Tracker 集群

FastDFS集群中的Tracker server可以有多台,Tracker server之间是相互平等关系同时提供服务,Tracker server不存在单点故障。客户端请求Tracker server采用轮询方式,如果请求的tracker无法提供服务则换另一个tracker。

1.2.2Storage集群

Storage集群采用了分组存储方式。storage集群由一个或多个组构成,集群存储总容量为集群中所有组的存储容量之和。一个组由一台或多台存储服务器组成,组内的Storage server之间是平等关系,不同组的Storage server之间不会相互通信,同组内的Storage server之间会相互连接进行文件同步,从而保证同组内每个storage上的文件完全一致的。一个组的存储容量为该组内存储服务器容量最小的那个,由此可见组内存储服务器的软硬件配置最好是一致的。

采用分组存储方式的好处是灵活、可控性较强。比如上传文件时,可以由客户端直接指定上传到的组也可以由tracker进行调度选择。一个分组的存储服务器访问压力较大时,可以在该组增加存储服务器来扩充服务能力(纵向扩容)。当系统容量不足时,可以增加组来扩充存储容量(横向扩容)。

1.2.3Storage状态收集

Storage server会连接集群中所有的Tracker server,定时向他们报告自己的状态,包括磁盘剩余空间、文件同步状况、文件上传下载次数等统计信息。

1.2.4文件上传流程

这个图的流程比较重要

客户端上传文件后存储服务器将文件ID返回给客户端,此文件ID用于以后访问该文件的索引信息。文件索引信息包括:组名,虚拟磁盘路径,数据两级目录,文件名。

  • 组名:文件上传后所在的storage组名称,在文件上传成功后有storage服务器返回,需要客户端自行保存。
  • 虚拟磁盘路径:storage配置的虚拟路径,与磁盘选项store_path*对应。如果配置了store_path0则是M00,如果配置了store_path1则是M01,以此类推。
  • 数据两级目录:storage服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据文件。
  •  文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储服务器IP地址、文件创建时间戳、文件     大小、随机数和文件拓展名等信息。

1.2.5文件下载流程

这个图的流程比较重要

​​​​

tracker根据请求的文件路径即文件ID 来快速定义文件。

比如请求下边的文件:

  •  通过组名tracker能够很快的定位到客户端需要访问的存储服务器组是group1,并选择合适的存储服务器提供客户端访问。  
  •  存储服务器根据“文件存储虚拟磁盘路径”和“数据文件两级目录”可以很快定位到文件所在目录,并根据文件名找到客户端需要访问的文件。

2.FastDFS+Nginx实现文件服务器

由于是只有一台服务器,所以tracker和storager都放一台服务器上了。

2.1FastDFS--tracker安装

在192.168.101.3上安装tracker。

2.1.1下载

tracker和storage使用相同的安装包,下载地址:https://github.com/happyfish100/FastDFS

本教程下载:FastDFS_v5.05.tar.gz

2.1.2FastDFS安装环境

FastDFS是C语言开发,建议在linux上运行,本教程使用Centos6.4作为安装环境。

安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果没有gcc环境,

需要安装gcc:

yum install gcc-c++

2.1.3​​​​​​​安装libevent

FastDFS依赖libevent库,需要安装:

yum -y install libevent

2.1.4​​​​​​​安装libfastcommon

libfastcommon是FastDFS官方提供的,libfastcommon包含了FastDFS运行所需要的一些基础库。

将libfastcommonV1.0.7.tar.gz拷贝至/usr/local/下

cd /usr/local
tar -zxvf libfastcommonV1.0.7.tar.gz
cd libfastcommon-1.0.7
./make.sh
./make.sh install

注意:libfastcommon安装好后会自动将库文件拷贝至/usr/lib64下,由于FastDFS程序引用usr/lib目录所以需要将/usr/lib64下的库文件拷贝至/usr/lib下。

要拷贝的文件如下:

cp libfastcommon.so /usr/lib/libfastcommon.so

2.1.5​​​​​​​tracker编译安装

将FastDFS_v5.05.tar.gz拷贝至/usr/local/下,并解压

cd FastDFS_v5.05.tar.gz /usr/local/FastDFS_v5.05.tar.gz
tar -zxvf FastDFS_v5.05.tar.gz

进入解压目录安装

cd FastDFS
./make.sh
./make.sh install

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

cp /usr/local/FastDFS/conf/client.conf /etc/fdfs/client.conf
cp /usr/local/FastDFS/conf/http.conf /etc/fdfs/http.conf
cp /usr/local/FastDFS/conf/mime.types /etc/fdfs/mime.types
cp /usr/local/FastDFS/conf/storage.conf /etc/fdfs/storage.conf
cp /usr/local/FastDFS/conf/storage_ids.conf /etc/fdfs/storage_ids.conf
cp /usr/local/FastDFS/conf/tracker.conf /etc/fdfs/tracker.conf

2.1.6配置

安装成功后修改tracker.conf:

vim /etc/fdfs/tracker.conf

将tracker.conf里面的

base_path=/home/yuqing/FastDFS 改为: base_path=/home/FastDFS
http.server_port=8080 改为: http.server_port=80

注意:http.server_port这个是tracker服务器的端口,后面要用

然后创建目录

cd /home
mkdir FastDFS

2.1.7启动

/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

启动的日志显示先停止1303进程(实际环境不是1303)再启动,如下图:

注意:如果没有显示上图要注意是否上面步骤配置正确。

设置开机自启

vim /etc/rc.d/rc.local

将运行命令行添加进rc.local文件末尾:/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

2.2​​​​​​​FastDFS--storage安装

在192.168.101.3上安装storage。

2.2.1​​​​​​​libevent

上面安装tracker时已经安装过

2.2.2​​​​​​​安装libfastcommon

上面安装tracker时已经安装过​​​​​​​

2.2.3storage编译安装

上面编译安装tracker时已经安装过。​​​​​​​

2.2.4配置

安装成功后进入/etc/fdfs目录:

cd /etc/fdfs

修改storage.conf

vim /etc/fdfs/storage.conf
group_name=group1
base_path=/home/yuqing/FastDFS改为:base_path=/home/FastDFS
store_path0=/home/yuqing/FastDFS改为:store_path0=/home/FastDFS/fdfs_storage
#如果有多个挂载磁盘则定义多个store_path,如下
#store_path1=.....
#store_path2=......
tracker_server=192.168.101.3:22122   #配置tracker服务器:IP
#如果有多个则配置多个tracker
#tracker_server=192.168.101.4:22122

创建fds_storage

cd /home/FastDFS/
mkdir fdfs_storage

2.2.5启动

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

启动的日志显示先停止1314进程(实际环境不是1314)再启动,如下图:

注意:

如果没有显示上图要注意是否配置正确或者正常停止原有进程。

如果是阿里云服务器要开启安全组规则(22122端口)

设置开机自动启动。

vim /etc/rc.d/rc.local

将运行命令行添加进文件:/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

2.3上传文件测试

2.3.1​​​​​​​通过fdfs_test程序

FastDFS安装成功可通过/usr/bin/fdfs_test测试上传、下载等操作。

修改/etc/fdfs/client.conf

base_path=/home/FastDFS
tracker_server=192.168.101.3:22122
http.tracker_server_port=80  #http.tracker_server_port要与tracker端口对应

使用格式:

/usr/bin/fdfs_test  客户端配置文件地址  upload  上传文件

比如将FastDFS自带的图片上传到FastDFS中:

/usr/bin/fdfs_test /etc/fdfs/client.conf upload /usr/local/FastDFS/conf/anti-steal.jpg

上传后的提示:

This is FastDFS client test program v5.05

Copyright (C) 2008, Happy Fish / YuQing

FastDFS may be copied only under the terms of the GNU General
Public License V3, which may be found in the FastDFS source kit.
Please visit the FastDFS Home Page http://www.csource.org/ 
for more detail.

[2018-08-17 04:36:21] DEBUG - base_path=/home/FastDFS, connect_timeout=30, network_timeout=60, tracker_server_count=1, anti_steal_token=0, anti_steal_secret_key length=0, use_connection_pool=0, g_connection_pool_max_idle_time=3600s, use_storage_id=0, storage server id count: 0

tracker_query_storage_store_list_without_group: 
	server 1. group_name=, ip_addr=192.168.101.3, port=23000

group_name=group1, ip_addr=192.168.101.3, port=23000
storage_upload_by_filename
group_name=group1, remote_filename=M00/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637.jpg
source ip address: 192.168.101.3
file timestamp=2018-08-17 04:36:21
file size=23981
file crc32=2553063749
example file url: http://192.168.101.3/group1/M00/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637.jpg
storage_upload_slave_by_filename
group_name=group1, remote_filename=M00/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637_big.jpg
source ip address: 192.168.101.3
file timestamp=2018-08-17 04:36:21
file size=23981
file crc32=2553063749
example file url: http://192.168.101.3/group1/M00/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637_big.jpg

http://192.168.101.3/group1/M00/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637.jpg就是文件的下载路径。

对应storage服务器上的

/home/FastDFS/fdfs_storage/data/00/00/rBPrOVt14EWAJTXDAABdrZgsqUU637.jpg文件。

由于现在还没有和nginx整合无法使用http下载。

2.3.2​​​​​​​通过java Client API

测试源代码。

这里需要:fastdfs_client_v1.20.jar

import java.io.FileNotFoundException;
import java.io.IOException;

import org.csource.fastdfs.ClientGlobal;
import org.csource.fastdfs.StorageClient;
import org.csource.fastdfs.StorageServer;
import org.csource.fastdfs.TrackerClient;
import org.csource.fastdfs.TrackerServer;
import org.junit.Test;

public class FastDFSTest {
    //配置文件
	public String conf_filename = "F:\\client.conf"; 
	//本地文件,要上传的文件
		public String local_filename = "C:\\Users\\Administrator\\Desktop\\1.jpg";
	@Test
	public void testFastdfs() {

		try {
			ClientGlobal.init(conf_filename);
			TrackerClient tracker = new TrackerClient();
			TrackerServer trackerServer = tracker.getConnection();
			StorageServer storageServer = null;
			StorageClient storageClient = new StorageClient(trackerServer, storageServer);
			String fileIds[] = storageClient.upload_file(local_filename, null,null);
			System.out.println(fileIds.length);
			System.out.println("组名:" + fileIds[0]);
			System.out.println("路径: " + fileIds[1]);

		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		} catch (Exception e) {
			e.printStackTrace();
		}

	}
}

client.conf

tracker_server=192.168.101.3:22122

2.4​​​​​​​FastDFS 和nginx整合

2.4.1​​​​​​​在tracker上安装nginx

在每个tracker上安装nginx,的主要目的是做负载均衡及实现高可用。如果只有一台tracker服务器可以不配置nginx。

2.4.2在Storage上安装nginx

第一步:安装​​​​​​​FastDFS-nginx-module

将fastdfs-nginx-module_v1.16.tar.gz 传至/usr/local/下,并解压

cp fastdfs-nginx-module_v1.16.tar.gz /usr/local/fastdfs-nginx-module_v1.16.tar.gz
cd /usr/local
tar -zxvf fastdfs-nginx-module_v1.16.tar.gz 

编辑配置文件

cd fastdfs-nginx-module/src
vim config

修改config文件将/usr/local/路径改为/usr/

将fastdfs-nginx-module/src下的mod_fastdfs.conf拷贝至/etc/fdfs/下

cp mod_fastdfs.conf /etc/fdfs/

并修改mod_fastdfs.conf的内容:

vim /etc/fdfs/mod_fastdfs.conf

 修改如下内容

base_path=/home/FastDFS
tracker_server=192.168.101.3:22122
#tracker_server=192.168.101.4:22122(多个tracker配置多行)
url_have_group_name=true		#url中包含group名称
store_path0=/home/FastDFS/fdfs_storage   #指定文件存储路径

将libfdfsclient.so拷贝至/usr/lib下

cp /usr/lib64/libfdfsclient.so /usr/lib/

创建nginx/client目录

mkdir -p /var/temp/nginx/client

第二步:安装nginx

安装nginx环境

yum install gcc-c++(如果已经安装则不需要再安装)
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel
yum install -y openssl openssl-devel

上传ningx的安装包:nginx-1.8.0.tar.gz 到/usr/local/下

cp nginx-1.8.0.tar.gz /usr/local/nginx-1.8.0.tar.gz

解压nginx压缩包

tar -xvf nginx-1.8.0.tar.gz

cd 到nginx-1.8.0

cd nginx-1.8.0

输入下列命令(这是一个命令):

./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi \
--add-module=/usr/local/fastdfs-nginx-module/src

然后编译安装

make(#编译)
make install(#安装)

第三步:配置nginx

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

添加server:

server {
        listen       80;
        server_name  192.168.25.141;

        location /group1/M00/{
			ngx_fastdfs_module;
		}
}

第四步:启动nginx

cd /usr/local/nginx/sbin/
./nginx

有可能出现的错误:

出现错误:

1.nginx: [error] open() "/var/run/nginx/nginx.pid" failed (2: No such file or directory)

指定nginx配置文件即可

[root@localhost sbin]# nginx -c /usr/local/nginx/conf/nginx.conf

2.nginx: [emerg] mkdir() "/var/temp/nginx/client" failed (2: No such file or directory)

创建文件夹

mkdir -p /var/temp/nginx/client

说明:

server_name指定本机ip

location /group1/M00/:group1为nginx 服务FastDFS的分组名称,M00是FastDFS自动生成编号,对应store_path0=/home/FastDFS/fdfs_storage,如果FastDFS定义store_path1,这里就是M01

2.5.3测试

使用格式:

/usr/bin/fdfs_test  客户端配置文件地址  upload  上传文件

/usr/bin/fdfs_test /etc/fdfs/client.conf upload /usr/local/FastDFS/conf/anti-steal.jpg

这个是fastdfs安装自带的图片

访问storage:http://192.168.101.3/group1/M00/00/00/rBPrOVt16AGAL3GgAABdrZgsqUU093.jpg

此致单机版fastdfs+nginx搭建成功。

猜你喜欢

转载自blog.csdn.net/pdsu161530247/article/details/81743889