FastDFS是一款开源的轻量级分布式文件系统,纯C实现,支持Linux、FreeBSD等Unix系统。

类google FS,不是通用的文件系统,只能通过专有API访问。

FastDFS服务端有两种角色:跟踪器(tracker)和存储节点(storage)。

tracker主要做调度工作,在访问上起负载均衡的作用,在内存中记录集群中group和storage的状态信息,是连接client和storage的枢纽。

storage存储服务器,文件和文件属性都保存到存储服务器上。

一、安装fastdfs

下载libfastcommon包

https://github.com/happyfish100/libfastcommon/releases

下载fastdfs源码包

https://github.com/happyfish100/fastdfs/releases

安装libfastcommon

> tar xf libfastcommon-1.0.7.tar.gz
> cd libfastcommon-1.0.7
> ./make.sh
> ./make.sh install

安装fastdfs

> tar xf fastdfs-5.09.tar.gz
> cd fastdfs-5.09
> ./make.sh
> ./make.sh install

如果出现ioevent.h:82:2: #error port me这样的错误,请下载最新版的libfastcommon并安装。

二、环境说明

创建两台虚拟主机,IP分别为192.168.1.222和192.168.1.233,分别安装fastdfs。

三、fastdfs的配置文件

配置文件默认在/etc/fdfs下
默认脚本在/etc/init.d下

创建两个目录,用来存放数据

> mkdir -p /data/fdfs_tracker
> mkdir -p /data/fdfs_storage

复制配置文件

> cd /etc/fdfs
> cp storage.conf.sample storage.conf
> cp tracker.conf.sample tracker.conf

跟踪器的配置文件tracker.conf

#绑定IP
bind_addr=
#端口
port=22122
#连接超时时间
connect_timeout=30
#日志数据路径
base_path=/data/fdfs_tracker
#上传文件时选择group的方法
#0:轮询,1:指定组,2:选择剩余空间最大
store_lookup=2
#如果上面的配置是1,那么这里必须指定组名
store_group=group2
#上传文件时选择server的方法
#0:轮询,1:按IP地址排序,2:通过权重排序
store_server=0
#storage上预留空间
reserved_storage_space = 10%

存储节点的配置文件storage.conf

#storage server所属组名
group_name=group1
#绑定IP
bind_addr=
#storage server的端口
port=23000
#连接超时时间
connect_timeout=30
#日志数据路径
base_path=/data/fdfs_storage/base
#storage path的个数
store_path_count=2
#根据store_path_count的值,就要有storage0到storage(N-1)个
store_path0=/data/fdfs_storage/storage0
store_path1=/data/fdfs_storage/storage1
#跟踪服务器
tracker_server=192.168.1.222:22122
tracker_server=192.168.1.233:22122

创建目录,不然会出错

> mkdir -p /data/fdfs_storage/base
> mkdir -p /data/fdfs_storage/storage0
> mkdir -p /data/fdfs_storage/storage1

启动服务

> /etc/init.d/fdfs_trackerd start
> /etc/init.d/fdfs_storaged start

查看服务是否启动

> ps -ef|grep fdfs
> netstat -nltp

  

四、测试fastdfs

配置client文件

> cd /etc/fdfs
> cp client.conf.sample client.conf
> vi client.conf

#存放日志目录
base_path=/data/client
#跟踪服务器
tracker_server=192.168.1.222:22122
tracker_server=192.168.1.233:22122

创建client目录

> mkdir -p /data/client

通过fdfs_upload_file来测试(如果发生错误,请查看防火墙)

> echo "12345678" >> /data/1.txt
> fdfs_upload_file /etc/fdfs/client.conf /data/1.txt

通过fdfs_download_file下载我们刚上传的文件

> fdfs_download_file /etc/fdfs/client.conf group1/M00/00/00/wKgB3li3a2mAejYPAAAADok0NhY177.txt

查看文件信息

> fdfs_file_info /etc/fdfs/client.conf group1/M00/00/00/wKgB3li3a2mAejYPAAAADok0NhY177.txt

追加文件

> echo "hello" >> /data/2.txt
> fdfs_upload_appender /etc/fdfs/client.conf /data/1.txt
> fdfs_append_file /etc/fdfs/client.conf group1/M00/00/00/wKgB3li3bxCEAcqhAAAAAIk0NhY869.txt /data/2.txt

删除文件

> fdfs_delete_file /etc/fdfs/client.conf group1/M00/00/00/wKgB3li3a2mAejYPAAAADok0NhY177.txt

查看集群

> fdfs_monitor /etc/fdfs/client.conf

  

五、fastdfs的nginx模块

下载pcre和nginx源码包

https://ftp.pcre.org/pub/pcre/

如:pcre-8.40.tar.gz

http://nginx.org/en/download.html

如:nginx-1.10.3.tar.gz

https://github.com/happyfish100/fastdfs-nginx-module

如:fastdfs-nginx-module-master.zip

创建用户

> useradd -s /sbin/nologin -M nginx

安装pcre

> tar xf pcre-8.40.tar.gz
> cd pcre-8.40
> ./configure --prefix=/data/pcre
> make && make install

安装nginx

> yum install zlib-devel openssl-devel
> unzip fastdfs-nginx-module-master.zip
> tar xf nginx-1.10.3.tar.gz
> cd nginx-1.10.3
> ./configure --prefix=/data/nginx \
> --with-pcre=/data/pcre-8.40 \
> --user=nginx \
> --group=nginx \
> --with-http_ssl_module \
> --with-http_realip_module \
> --with-http_stub_status_module \
> --add-module=/data/fastdfs-nginx-module-master/src
> make && make install

拷贝配置文件

> cd /data/fastdfs-nginx-module-master/src
> cp mod_fastdfs.conf /etc/fdfs/
> cd /data/fastdfs-5.09/conf
> cp anti-steal.jpg http.conf mime.types /etc/fdfs/

修改nginx.conf

> vi /data/nginx/conf/nginx.conf

server {listen 80;server_name localhost;location ~ /group[0-9]/M00 {ngx_fastdfs_module;}
}

修改mod_fastdfs.conf

> vi /etc/fdfs/mod_fastdfs.conf

#日志目录
base_path=/tmp
#跟踪服务器
tracker_server=192.168.1.222:22122
tracker_server=192.168.1.233:22122
#url中是否有group名称
url_have_group_name = true
#storage path的个数
store_path_count=2
#根据store_path_count的值,就要有storage0到storage(N-1)个
store_path0=/data/fdfs_storage/storage0
store_path1=/data/fdfs_storage/storage1

启动nginx

> /data/nginx/sbin/nginx

上传一个文件

> echo "12345678" >> /data/1.txt
> fdfs_upload_file /etc/fdfs/client.conf /data/1.txt

然后通过nginx访问该文件

http://192.168.1.222/group1/M00/00/00/wKgB6Vi3fGiAMsO2AAAAB2BGSN8003.txt

centos7下的FastDFS5.09的安装与使用相关推荐

  1. Centos7 下定义MariaDB源Yum安装最新版本的MariaDB

    Centos7 下定义MariaDB源Yum安装最新版本的MariaDB 在Centos下安装软件服务的方式一般就那么几种(yum.rpm ivh xxx.make make&&ins ...

  2. centos7下的elasticsearch-6.2.4安装

    一.elasticsearch安装 1. 下载安装包: elasticsearch-6.2.4.rpm 上传到/home/hadoop 下 2. 直接解压安装:[root@cib129 hadoop] ...

  3. CentOS7下分布式文件系统FastDFS的安装 配置 (单节点)

    背景 FastDFS是一个开源的轻量级分布式文件系统,为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高性能等指标,解决了大容量存储和负载均衡的问题,特别适合以文件为载体 ...

  4. Centos7 下nginx nginx-1.13.4 安装

    环境:CentOS Linux release 7.3.1611 (Core)  Linux localhost.localdomain 3.10.0-514.26.2.el7.x86_64 #1 S ...

  5. CentOS7下搭建Nginx+PHP7的安装配置

    一.安装编译工具及库文件: yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel 环境要求 nginx是C ...

  6. CentOS7下Spark集群的安装

    从物理部署层面上来看,Spark主要分为两种类型的节点,Master节点和Worker节点,Master节点主要运行集群管理器的中心化部分,所承载的作用是分配Application到Worker节点, ...

  7. CentOS7下Mysql Cluster 7.4安装配置

    Mysql Cluster 7.4安装配置(部分图片未显示) 1 环境说明 1.1 所依赖环境 CentOS7.2  (需关闭防火墙) JDK7 1.2 五大服务器IP部署 管理节点 MGM1:10. ...

  8. centos7 php配置,CentOS7 下nginx与PHP的安装与配置

    下载Nginx 1.在服务器上新建文件夹  /home/soft/ ; 2.cd /home/soft/    =>    执行命令下载Nginx    wget http://nginx.or ...

  9. Centos7下搭建LAMP环境,安装wordpress(不会生产博客,只是一名博客搬运工)(菜鸟)

    1.搭建MySQL数据库 安装MariaDB yum install mariadb-server -y 启动MySQL服务 emctl start mariadb #启动服务 emtcl enabl ...

最新文章

  1. 调整亮度_【紫墨手机摄影课堂】图片调整
  2. wxWidgets:wxTreeCtrl类用法
  3. 数据库SQL基础语法
  4. Written English-书面-现在完成时
  5. Android 快速实现微信支付(真的!很快!)
  6. For循环案例---九九乘法表
  7. C# dataTable实用例
  8. 模拟退火算法_Simulated Annealing 模拟退火算法
  9. 安卓资源字串中加全角空格、半角空格、换行、@%等特殊字符
  10. chrom浏览器配置,把跨域保护关闭
  11. 个人网页制作 大学生个人网页设计 个人网站模板 简单静态HTML个人网页作品
  12. 关于如何把用手机查看原型
  13. 笔试c语言编程题技巧,c语言笔试题答题技巧
  14. UE4学习-初识虚幻引擎(下载、安装、重定向问题、安装引擎、启动)
  15. 周易全文&白話翻譯(上)
  16. linux运行natapp,Centos使用natapp教程
  17. SCUT J.O: 百步梯
  18. Python机器学习:适合入门的8个项目
  19. Configuring CODESYS
  20. 房贷新政刺激换房需求 北京楼市成交量反弹

热门文章

  1. spring之AOP的简单实例
  2. 这才是GraphQL最详尽的解释
  3. C#进行MapX二次开发之控件基本操作
  4. [ubuntu] 摆脱一直敲打‘Y'('yes')的困境
  5. 用Jenkins自动化构建Android和iOS应用
  6. json.parse()和json.stringify()
  7. 51nod 1040:最大公约数之和(数论)
  8. Spring+MyBatis
  9. 2.3 CMMI2级——项目跟踪和控制(Project Monitoring and Control)
  10. 添加非oracle用户到dba, oinstall组