Ubuntu下安装并配置FastDFS

当我们实践项目的时候,当加载的图片一多性能就会变差。这时候,采用分布式文件系统就显得特别有必要。


FastDFS模块简介:

FastDFS 系统有三个角色:跟踪服务器(Tracker Server)、存储服务器(Storage Server)和
客户端(Client)。

Tracker Server: 跟踪服务器,主要做调度工作,起到均衡的作用;负责管理所有的 storage server和 group,每个 storage 在启动后会连接 Tracker,告知自己所属 group 等信息,并保持周期性心跳。
Storage Server: 存储服务器,主要提供容量和备份服务;以 group 为单位,每个 group 内可以有多台 storage server,数据互为备份。
Client: 客户端,上传下载数据的服务器,也就是我们自己的项目所部署在的服务器。


那么FastDFS是怎么做到上传下载和同步文件的呢???

Ubuntu下安装并配置FastDFS_第1张图片
【网图,侵删】

环境:

Ubuntu 64位
FastDFS-5.05

  1. 下载安装libfastcommon

fastdfs依赖libfastcommon,需要从github上clone到本地编译安装。因此首先需要安装git。

apt-get install git 
git clone https://github.com/happyfish100/libfastcommon.git  
cd libfastcommon/
./make.sh
./make.sh install

2.设置环境变量和软链接

export LD_LIBRARY_PATH=/usr/lib64/ 
ln -s /usr/lib64/libfastcommon.so /usr/local/lib64/libfastcommon.so  

3.下载,解压,安装FastDFS

FastDFS的Github下载地址为:https://github.com/happyfish100/fastdfs/releases
本次采用FastDFS-5.05.tar.gz

tar xzf fastdfs-5.08.tar.gz 
./make.sh   
./make.sh install 

4.修改配置文件

在默认安装路径 /etc/fdfs 下,有三个示例配置文件:
client.conf.sample , storage.conf.sample , tracker.conf.sample

利用mv 命令 修改文件名,去掉sample后缀

client.conf
storage.conf
tracker.conf

然后修改 tracker.conf 文件中的日志存放路径 和 tracker server HTTP端口号,
注意,这个路径是根据实际情况自定义的,文件路径需要安装者手动创建,否则后续步骤会报“路径不存在”的错误

# the base path to store data and log files  
base_path=/home/fastdfs/log  
# HTTP port on this tracker server  
http.server_port=8090  

修改 storage.conf 文件:

group_name=group1  
store_path0=/home/fastdfs/storage0  
base_path=/home/fastdfs/log  
tracker_server=192.168.1.108:22122  
http.server_port=8888 

修改 client.conf 文件:

base_path=/home/fastdfs/log  
tracker_server=192.168.1.108:22122  
http.tracker_server_port=8888  
#include http.conf  

注意,#include http.conf 这句,原配置文件中有2个#,删掉一个。

5.启动服务

依次执行下列命令:

/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf  
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf  

执行以下命令,验证服务:

neps -ef |grep fdfs  

测试上传文件:

进入/usr/local/bin/目录,上传文件,执行

sudo fdfs_test  /etc/fdfs/client.conf upload a.txt   

Ubuntu下安装并配置FastDFS_第2张图片

即说明成功上传。
使用fdfs_delete_file来删除文件。

可以看到,上传ok了,这里会生成两个文件,这是fastdfs的主/从文件特性,以后再介绍。example file url是不能在浏览器中直接打开的,除非配合nginx使用。删除文件需要完整的group_name和remote_filename。

因为FastDFS默认自带的http服务器性能不好, 所以一般建议用外置的apache或者nginx 来解决http下载。

如果之前机器上安装了nginx,可以单独安装fastdfs-nginx-module模块。关于Nginx之后再尝试吧,今天就到此为止吧。

你可能感兴趣的:(Linux)