你好!欢迎阅读我的博文,你可以跳转到我的个人博客网站,会有更好的排版效果和功能。

此外,本篇博文为本人Pushy原创,如需转载请注明出处:https://pushy.site/posts/1532055928

1. 准备工作

1.1 下载工具

该部署教程的所有工具都能在https://pan.baidu.com/s/1U8nXJycYqGo1ChStbszr1w找到

1.2 安装libevent

libevent是一个基于事件触发的网络库,能够对并发编程提供支持,避免竞态条件,同时具有高性能、由时间驱动的优点。

$ sudo apt-get install libevent-dev

2. 开始部署

2.1 安装libfastcommon

解压libfastcommon后进入文件进行编译:

$ unzip libfastcommon-master.zip
$ cd libfastcommon-master
$ ./make
$ sudo ./make install

2.2 安装Tracker服务

解压fastdfs压缩包进入文件夹进行编译:

$ tar -zxvf fastdfs-5.10.tar.gz
$ ./make.sh
$ sudo ./make.sh install

编译完了之后/etc/fdfs文件夹下会有Fastdfs的配置文件,如果没有该文件夹,则把FastDFS根目录下的/conf目录下的所有的配置文件都复制到/etc/fdfs

配置Tracker

文件下下的tracker.conf.sample是配置的实例文件,需要复制一份并命名为tracker.conf,然后修改配置文件:

$ sudo cp tracker.conf.sample tracker.conf
$ sudo vim tracker.conf

base_path修改为自己的路径,并且该绝对路径必须存在,这里修改为/home/pushy/fastdfs,修改好了之后保存文件。

启动Tracker

$ sudo /usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf start

启动完成后,通过netstat -unltp查看端口的监听情况,可以看到22122端口正常被监听,说明Tracker服务安装成功了:

2.3 安装Storage服务

配置storage

同样复制storage.conf.sample文件为storage.conf到当前文件夹,并且修改配置文件:

$ sudo cp storage.conf.sample storage.conf
$ sudo vim storage.conf
  • 修改storage服务日志存放路径base_path,路径必须存在,这里修改为/home/pushy/fastdfs

  • 修改图片保存的路径store_path0,路径必须存在,这里修改为/home/pushy/fastdfs;然后修改指定Tracker服务器的ip及端口号,这里的ip号不能修改为localhost,而是通过ifconfig查看的局域网ip,端口默认为22122

启动storage服务

$ sudo /usr/bin/fdfs_storaged /etc/fdfs/storage.conf

同样通过netstat -unltp命令查看storege服务23000端口的监听情况,如果正常监听则说明启动成功

我们安装配置并启动了 Tracker 和 Storage 服务,也没有报错了。那他俩是不是在通信呢?我们可以监视一下:

$ /usr/bin/fdfs_monitor /etc/fdfs/storage.conf

如果出现下图的情况则说明安装成功,而且Tracker 和 Storage正常通信。

测试服务

还是将配置文件复制一份:

$ sudo cp client.conf.sample client.conf
$ sudo vim client.conf

修改client.conf配置文件,修改将客户端日志文件保存路径base_path,这里修改为:/home/pushy/fastdfs/client;并且修改Tracker的服务器IP和地址。

执行命令进行上传测试:

$ /usr/bin/fdfs_upload_file /etc/fdfs/client.conf ~/test.jpg

如果返回ID号则测试成功

group1/M00/00/00/wKiRiVtQBwmAF4AEACsWhwfBzc0490.jpg

3. 安装 Nginx 和配置映射

网上的大多数教程都手动编译Nginx并且添加fastdfs-nginx-module插件,实际上不需要该插件也是可以正常的映射,访问图片的。

3.1 安装Nginx

$ sudo apt-get install nginx

3.2 配置映射

$ sudo cd /etc/nginx/conf.d
$ sudo vim fastdfs.conf

添加下面的server配置,直接通过alias映射到storage的路径下:

server {
listen 80;
server_name storage.example.com;
location /group1/M00/ {
# 这里配置前面配置的storage data的路径
alias /home/pushy/fastdfs/data/;
}
}

重启Nginx:

$ nginx -s reload

重启好了之后就可以通过http://storage.example.com/group1/M00/00/00/wKiRiVtQBwmAF4AEACsWhwfBzc0490.jpg访问到图片了

参考资料

Linux下FastDFS图片服务器的搭建

FastDFS安装全过程记录

FastDFS之——集群的安装、 配置、 使用

Nginx安装

FastDFS部署安装全过程的更多相关文章

  1. FastDFS安装全过程记录(V5.05)

    FastDFS安装全过程记录 1.安装准备 HA虚拟IP:192.168.1.208 HA软件:Keepalived 操作系统:CentOS 7 用户:root 数据目录:/data/fastdfs ...

  2. 01.FastDFS的安装部署

    1.FastDFS简介 (1)FastDFS的功能介绍 FastDFS是一个开源的分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负 ...

  3. Android 开发环境在 Windows7 下的部署安装

    Android SDK Android SDK 为 Android 应用的开发.测试和调试提了必要的API库和开发工具. ADT Bundle 下载 如果你是一个android 开发新手,推荐你下载使 ...

  4. Windows系统下部署安装一个/多个Tomcat8

    首先从http://tomcat.apache.org/上下载Tomcat8.0压缩版的,解压到指定路径后即可.  第一:在Windows系统中安装部署单个Tomcat         对于这种情况, ...

  5. Zabbix监控windows部署安装

    Zabbix agent 在windows上安装部署 1.  下载与解压 地址: http://www.zabbix.com/downloads/2.4.0/zabbix_agents_2.4.0.w ...

  6. Hadoop 2.2.0部署安装(笔记,单机安装)

    SSH无密安装与配置 具体配置步骤: ◎ 在root根目录下创建.ssh目录 (必须root用户登录) cd /root & mkdir .ssh chmod 700 .ssh & c ...

  7. FASTDFS 5X安装

    FASTDFS 5X安装 http://www.wingdevops.com/?p=603 流行的开源分布式文件系统有很多,FastDFS 是国人在mogileFS的基础上进行改进的key-value ...

  8. CentOS 6.0图解网络安装全过程

    转自CentOS 6.0图解网络安装全过程 国内镜像站点(东北大学.网易) 网易镜像站点:http://mirrors.163.com/centos/6.0/isos/ 中科大镜像站点:http:// ...

  9. _00024 尼娜抹微笑伊拉克_云计算ClouderaManager以及CHD5.1.0群集部署安装文档V1.0

    笔者博文:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...

随机推荐

  1. POJ 2250

    #include <iostream> #include <stack> #define MAXN 150 #include <string> using name ...

  2. Centos7下安装zabbix 3.0.19

    参考网站: https://www.cnblogs.com/xiewenming/p/7732144.html https://www.cnblogs.com/clsn/p/7885990.html  ...

  3. (转)python 之路,200行Python代码写了个打飞机游戏!

    原文:https://www.cnblogs.com/alex3714/p/7966656.html

  4. tensorflow进阶篇-3

    #-*- coding:utf-8 -*- #Tensorflow的嵌入Layer import numpy as np import tensorflow as tf sess=tf.Session ...

  5. 【数组】Spiral Matrix

    题目: Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spira ...

  6. 关于mpvue和wafer2-client-sdk的 微信登录失败,请检查网络状态

    关于mpvue和wafer2-client-sdk的登录使用. 错误形式: <script> // import {get} from './util' import qcloud fro ...

  7. android activity和fragment的生命周期图

    Activity的生命周期: Fragment的生命周期:

  8. IDEA Community(社区版)再谈之无奈之下还是去安装旗舰版

    不多说,直接上干货! 前言 相信很多人,跟我一样,一开始,接触spark,肯定会首选IntelliJ IDEA的社区版Community. IntelliJ IDEA号称当前Java开发效率最高的ID ...

  9. ruby执行周期性任务

    1.前言      无论是用ruby做系统管理,还是用rails做web开发,都可能遇到周期性任务,它们按照一定时间周期(1小时,2天......)持续地触发.在ruby中,我认为一次性任务使用sid ...

  10. b-树和b+树以及mysql索引

    b-树(m阶): 1.根节点至少有2个子节点; 2.中间节点包含k个子节点和k-1个元素,m/2 <= k <= m; 3.每个节点中的元素从小到大排列,节点当中k-1个元素正好是k个孩子 ...