前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >快速学习-FastDFS 安装

快速学习-FastDFS 安装

作者头像
cwl_java
发布2020-01-14 14:50:42
6580
发布2020-01-14 14:50:42
举报
文章被收录于专栏:cwl_Java

1 FastDFS 安装

1.1 安装 VMware 虚拟机

安装 CentOS7 虚拟机。

1.2 FastDFS–tracker 安装

分别在 192.168.101.3 和 192.168.101.4 上安装 tracker。

注:初次安装可只安装一台 tracker,快速体验。

1.2.1 下载

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

1.2.2 FastDFS 安装环境

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

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

代码语言:javascript
复制
gcc:yum install gcc-c++

1.2.3 安装 libevent

FastDFS 依赖 libevent 库,需要安装:

代码语言:javascript
复制
yum -y install libevent

1.2.4 安装 libfastcommon

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

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

代码语言:javascript
复制
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 下。要拷贝的文件如下:

在这里插入图片描述
在这里插入图片描述

1.2.5 tracker 编译安装

代码语言:javascript
复制
将 FastDFS_v5.05.tar.gz 拷贝至/usr/local/下
tar -zxvf FastDFS_v5.05.tar.gz
cd FastDFS
./make.sh 编译
./make.sh install 安装

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

在这里插入图片描述
在这里插入图片描述

1.2.6 配置

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

在这里插入图片描述
在这里插入图片描述

拷贝一份新的 tracker 配置文件:

代码语言:javascript
复制
cp tracker.conf.sample tracker.conf
修改 tracker.conf
vi tracker.conf
base_path=/home/yuqing/FastDFS 
改为:
base_path=/home/FastDFS
配置 http 端口:
http.server_port=80

1.2.7 启动

代码语言:javascript
复制
/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

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

在这里插入图片描述
在这里插入图片描述

注意:如果没有显示上图要注意是否正常停止原有进程。

1.3 FastDFS–storage 安装

分别在 192.168.101.5、192.168.101.6、192.168.101.7、192.168.101.8 上安装 storage。

注:初次安装可只安装一台 storage,快速体验。

1.3.1 安装 libevent

同 tracker 安装

1.3.2 安装 libfastcommon

同 tracker 安装。

1.3.3 storage 编译安装

同 tracker 编译安装。

1.3.4 配置

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

在这里插入图片描述
在这里插入图片描述

拷贝一份新的 storage 配置文件:

代码语言:javascript
复制
cp storage.conf.sample storage.conf
修改 storage.conf
vi 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
#配置 http 端口
http.server_port=80

1.3.5 启动

代码语言:javascript
复制
/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

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

在这里插入图片描述
在这里插入图片描述

注意:如果没有显示上图要注意是否正常停止原有进程。

1.4 上传图片测试

1.4.1 通过 fdfs_test 程序

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

修改/etc/fdfs/client.conf tracker_server 根据自己部署虚拟机的情况配置 。

代码语言:javascript
复制
base_path=/home/fastdfs
tracker_server=192.168.101.3:22122
tracker_server=192.168.101.4:22122

使用格式: /usr/bin/fdfs_test 客户端配置文件地址 upload 上传文件

比如将/home 下的图片上传到 FastDFS 中: /usr/bin/fdfs_test /etc/fdfs/client.conf upload /home/tomcat.png

打印如下日志:

代码语言:javascript
复制
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.
[2015-05-18 02:07:10] 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.5, port=23000
server 2. group_name=, ip_addr=192.168.101.6, port=23000
group_name=group1, ip_addr=192.168.101.5, port=23000
storage_upload_by_filename
group_name=group1, 
remote_filename=M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485.png
source ip address: 192.168.101.5
file timestamp=2015-05-18 02:07:11
file size=5103
file crc32=3979441827
example file url: 
http://192.168.101.5/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485.
png
storage_upload_slave_by_filename
group_name=group1, 
remote_filename=M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png
source ip address: 192.168.101.5
file timestamp=2015-05-18 02:07:11
file size=5103
file crc32=3979441827
example file url: 
http://192.168.101.5/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_
big.png

http://192.168.101.5/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png 就是文件的下载路径。

对应 storage 服务器上的 /home/fastdfs/fdfs_storage/data/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png 文件。

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

1.5 FastDFS 和 nginx 整合

1.5.1 nginx 代理

单独安装 nginx 代理服务,它的作用是代理访问 storage 上的文件,实现负载均衡。nginx 的安装细节参考 nginx 文档,这里使用单机 nginx,也可以使用两台 nginx 组成高可用或者采用 lvs+nginx 访问 Storage 上的 nginx。

创建 nginx-fdfs.conf 配置文件:

代码语言:javascript
复制
#storage 群 group1 组
upstream storage_server_group1{
 server 192.168.101.5:80 weight=10;
server 192.168.101.6:80 weight=10;
 }
 #storage 群 group2 组
upstream storage_server_group2{
 server 192.168.101.7:80 weight=10;
server 192.168.101.8:80 weight=10;
 }
 server {
	listen 80;
	server_name ccc.test.com;
	location /group1{
	proxy_redirect off;
	proxy_set_header Host $host;
	proxy_set_header X-Real-IP $remote_addr;
	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
	proxy_pass http://storage_server_group1;
}
location /group2{
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://storage_server_group2; } }

1.5.2 在 Storage 上安装 nginx

在 storage server 上安装 nginx 的目的是对外通过 http 访问 storage server 上的文件。使用 nginx 的模块 FastDFS-nginx-module 的作用是通过 http 方式访问 storage 中的文件,当 storage 本机没有要找的文件时向源 storage 主机代理请求文件。

1.5.2.1 FastDFS-nginx-module

FastDFS-nginx-module_v1.16.tar.gz 传 至 fastDFS 的 storage 服 务 器 的/usr/local/下,执行如下命令:

代码语言:javascript
复制
cd /usr/local
tar -zxvf FastDFS-nginx-module_v1.16.tar.gz
cd FastDFS-nginx-module/src

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

在这里插入图片描述
在这里插入图片描述

FastDFS-nginx-module/src 下的 mod_FastDFS.conf 拷贝至/etc/fdfs/

代码语言:javascript
复制
cp mod_FastDFS.conf /etc/fdfs/

并修改 mod_FastDFS.conf 的内容:

代码语言:javascript
复制
vi /etc/fdfs/mod_FastDFS.conf
base_path=/home/FastDFS
tracker_server=192.168.101.3:22122
tracker_server=192.168.101.4:22122
url_have_group_name=true #url 中包含 group 名称
store_path0=/home/fastdfs/fdfs_storage #指定文件存储路径
#如果有多个

libfdfsclient.so 拷贝至/usr/lib

代码语言:javascript
复制
cp /usr/lib64/libfdfsclient.so /usr/lib/

创建 nginx/client 目录

代码语言:javascript
复制
mkdir -p /var/temp/nginx/client
1.5.2.2 nginx 安装

将 nginx-1.8.0.tar.gz 拷贝到/usr/local 下 解压 nginx-1.8.0.tar.gz 进入 nginx-1.8.0 目录,执行如下配置命令: 下边红色部分表示添加 FastDFS-nginx-module 模块

代码语言:javascript
复制
./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
代码语言:javascript
复制
make
make install
1.5.2.3 nginx 配置文件

新建一个 nginx 配置文件 nginx-fdfs.conf.

添加虚拟主机:

代码语言:javascript
复制
server {
 listen 80;
 server_name 192.168.101.65;
 location /group1/M00/{
	 root /home/FastDFS/fdfs_storage/data;
	 ngx_FastDFS_module;
 } 
}

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

1.5.3 测试

通过 java 客户端上传文件,使用浏览器 http 访问文件,这里访问上传图片测试的文件:

访问 storage: http://192.168.101.5/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png

ip 地址改为 192.168.101.6 也可以访问到文件,因为同一个分组的 storage 文件互相同步。

访问 tracker: http://192.168.101.3/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png

ip 地址改为 192.168.101.4 也可以访问到文件。

使用域名访问 (推荐): nginx 对外由 vip 提供服务,使用域名访问如下: 比如 vip 对应的域名为 img.test.com: http://img.test.com/group1/M00/00/00/wKhlBVVY2M-AM_9DAAAT7-0xdqM485_big.png

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 FastDFS 安装
    • 1.1 安装 VMware 虚拟机
      • 1.2 FastDFS–tracker 安装
        • 1.2.1 下载
        • 1.2.2 FastDFS 安装环境
        • 1.2.3 安装 libevent
        • 1.2.4 安装 libfastcommon
        • 1.2.5 tracker 编译安装
        • 1.2.6 配置
        • 1.2.7 启动
      • 1.3 FastDFS–storage 安装
        • 1.3.1 安装 libevent
        • 1.3.2 安装 libfastcommon
        • 1.3.3 storage 编译安装
        • 1.3.4 配置
        • 1.3.5 启动
      • 1.4 上传图片测试
        • 1.4.1 通过 fdfs_test 程序
      • 1.5 FastDFS 和 nginx 整合
        • 1.5.1 nginx 代理
        • 1.5.2 在 Storage 上安装 nginx
        • 1.5.3 测试
    相关产品与服务
    负载均衡
    负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档