废话不多说,直接开撸

首先是一些准备工作:


1.关闭防火墙

service iptables stop

--- fastdfs虽然在docker部署,但是使用的是主机网络,所以关闭防火墙。

2  下载fastdfs镜像

docker pull season/fastdfs

3

cd /var

mkdir /fdfs

所有的文件存放在/var/fdfs中 目录清晰

3.1

下载nginx

wget http://nginx.org/download/nginx-1.15.9.tar.gz

3.2

安装git  直接去github上下载所需要的包也可以

yum install git
git clone https://github.com/happyfish100/fastdfs.git
git clone https://github.com/happyfish100/libfastcommon.git

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

下图三个文件都需要下载

3.3 解压nginx

tar -zxvf nginx-1.15..tar.gz 
//新建文件夹 存放fastdfs配置文件
mkdir fdfs_conf

目录如下

4 至此准备工作已经OK,接下来就是重点了,如何配置fastdfs以及整合nginx

4.1 启动一个临时的tracker 拷贝storage.conf tracker.conf 至/var/fdfs/fdfs_conf:

docker run  -d --name tracker  --net=host season/fastdfs tracker
docker ps
//查询到容器id
docker cp (容器ID):/fdfs_conf/tracker.conf `pwd`(当前路径)
docker cp (容器ID):/fdfs_conf/storage.conf `pwd`(当前路径)

vim storage.conf 修改tracker_server=实际ip:22122  http.server_port=8888

启动 tracker 和 storage  实际应用应该是多个tracker 多个storage  这里只做演示用,并没有配置多个,其实一个会配置了,其余都一样的,具体集群配置方法自行百度,这里不再赘述。

 docker run -ti -d --name trakcer -v /var/fdfs/tracker_data:/fastdfs/tracker/data -v /var/fdfs/fdfs_conf/tracker.conf:/fdfs_conf/tracker.conf  --net=host season/fastdfs tracker

docker run -ti --name storage -v /var/fdfs/fdfs_conf/storage.conf:/fdfs_conf/storage.conf -v /var/fdfs/storage_data:/fastdfs/storage/data -v /var/fdfs/store_path1:/fastdfs/store_path --net=host  season/fastdfs storage

至此,如果发现它在疯狂输出mkdir.. fastdfs就配置好了,就是这么简单。

接下来就是测试了,测试的话我上了一套简单的java springboot代码, 直接放上代码连接,不再赘述,因为本章主要是讲服务器端的配置。

从浏览器上传后,我们去linux服务器看一下,

上传成功了,然后就剩下通过nginx反向代理http请求了。

接着往下看:

进入/var/fdfs/libfastcommon

执行如下命令:

./make.sh
./make.sh install

接着进入/var/fdfs/fastdfs

执行如下命令:

./make.sh
./make.sh install

然后下载并安装 安装nginx所需依赖:

yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel

进入nginx解压出来的目录

cd nginx-1.15.
./configure --add-module=/var/fdfs/fastdfs-nginx-module/src

make; make install

OK,一切顺利的话 你在/usr/local/ 目录下就可以看到nginx了。

然后将 /var/fdfs/fastdfs/conf 目录下的所有文件copy到 /etc/fdfs中

cp -r /var/fdfs/fastdfs/conf/* /etc/fdfs/

将 /var/fdfs/fastdfs-nginx-module/src 目录中的 mod_fastdfs.conf 复制到/etc/fdfs

/etc/fdfs目录中的所有文件是nginx 整合fastdfs-nginx-module所用到的配置文件

vim /etc/fdfs/storage.conf

修改其中内容为:

base_path=/var/fdfs/store_path
store_path0=/var/fdfs/store_path
tracker_server=192.168.6.78:
http.server_port=8888 //需要与nginx监听的端口一致

vim /etc/fdfs/tracker.conf

修改其中内容为:

base_path=/var/fdfs/tracker_data

vim /etc/fdfs/mod_fastdfs.conf

修改其中内容为:

tracker_server=192.168.6.78:
store_path0=/var/fdfs/store_path url_have_group_name = true //请求路径是否携带组信息

接下来就剩下最后一步了,配置nginx

ngxinx 配置文件

vim /usr/local/nginx/conf/nginx.conf
server {
listen ;
server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location ~/group([-])/M00 {
# root /var/fdfs/storage_path;
ngx_fastdfs_module;
}

然后启动nginx:

cd /usr/local/nginx/sbin
./nginx //重新加载
./nginx -s reload
//停止
./nginx -s stop

启动完成后进行测试

OK!!!万事大吉~~~~  需要客户端测试上传文件代码的同学下方留言。

docker+fastdfs+nginx 实现分布式大文件存储系统以及视频缓存播放的更多相关文章

  1. FastDFS+Nginx轻量级分布式

    一 简介 FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的问题.特别适合以文件为载体的在线 ...

  2. 对于Nginx+PHP实现大文件上传时候需要修改的参数

    post_max_size表示POST表单提交的最大大小upload_max_filesize 表示文件上传的最大大小. 通常post_max_size设置的值必须必upload_max_filesi ...

  3. 使用docker+consul+nginx集成分布式的服务发现与注册架构

    一.环境说明: 1.一台虚拟机,该系统已经装好了docker: ip 192.168.10.224 虚拟网卡,与主机互通 操作系统rhel6 内核 2.6.32  64位 docker版本 1.7.1 ...

  4. centos6.5安装配置fastdfs+nginx实现分布式图片服务器

    一.准备 yum groupinstall -y "Development Tools"yum install -y wget libevent-devel pcre-devel ...

  5. DJANGO技巧两则:模拟MKDIR -P及配合NGINX上传大文件不使超时

    这都是在开发当哪遇到的问题,网上转转,作个记录: http://blog.chinaunix.net/uid-25525723-id-1596574.html http://bookshadow.co ...

  6. nginx上传大文件,413错误解决

    在nginx里增加了配置. client_max_body_size 500m; proxy_connect_timeout 600; proxy_read_timeout 600; proxy_se ...

  7. nginx+php设置大文件请求上传(502及504问题处理)

    502问题 php-fpm 修改项: request_terminate_timeout 位置: eg: /etc/php5/fpm2/pool.d/www.conf ; The timeout fo ...

  8. 使用Nginx配置服务静态文件(图片,文本,视频等)

    安装Nginx 安装Nginx较为简单,请参考下方链接或自行百度. 参考链接:https://blog.csdn.net/qq_26666947/article/details/112272058 以 ...

  9. php无法上传大文件完美解决方案

    php.ini无法上传大文件完美解决办法 1.打开php.ini(打开方式就不用说了,百度一大堆) 2.查找post_max_size 表单提交最大数值,此项不是限制上传单个文件的大小,而是针对整个表 ...

随机推荐

  1. docker完整配置nginx+php+mysql

    首先了解一个方法: 使用docker exec进入Docker容器 docker在1.3.X版本之后还提供了一个新的命令exec用于进入容器,这种方式相对更简单一些,下面我们来看一下该命令的使用: s ...

  2. 一丢丢学习之webpack4 + Vue单文件组件的应用

    之前刚学了一些Vue的皮毛于是写了一个本地播放器https://github.com/liwenchi123000/Local-Music-Player,如果觉得ok的朋友可以给个star. 就是很简 ...

  3. tomcat在windows及linux环境下安装

    下载tomcat 下载地址: https://tomcat.apache.org/download-90.cgi 7,8,9的版本都可以下,这里下载最新版本 注意:Binary是编译好的,可以直接使用 ...

  4. luogu3346 诸神眷顾的幻想乡 (广义SAM)

    首先,让每一个叶节点做一次树根的话,每个路径一定至少有一次会变成直上直下的 于是对于每个叶节点作为根产生的20个trie树,把它们建到同一个广义SAM里 建法是对每个trie dfs去建,last就是 ...

  5. Security+认证812分轻松考过(备战分享)

    2019.02.12,开工第一天,我参加了security+考试并顺利通过了考试,812分的成绩有点出乎我的意料,据我所知我周围还没有人考过800分的.怀着愉悦的心态分享下我的备考经历和考试经验. 备 ...

  6. Vue(基础八)_导航守卫(组件内的守卫)

    一.前言 主要通过一个例子演示三个钩子的作用: 1.beforeRouteEnter()                                                         ...

  7. js值类型转换(boolean/String/number),js运算符,if条件,循环结构,函数,三种弹出框

    js值类型转换 number | string | boolean boolean类型转换 num = 0; var b1 = Boolean(num); console.log(b1) 转化为数字类 ...

  8. 求复变函数的 Taylor 展式与 Laurent 展式[华中师范大学2010年复变函数复试试题]

    设 $$\bex f(z)=\frac{1}{(z-1)(z-2)}. \eex$$ (1) 求 $f(z)$ 在 $|z|<1$ 内的 Taylor 展式. (2) 求 $f(z)$ 在圆环 ...

  9. 2.12 for循环

    for循环 像while循环一样,for可以完成循环的功能. 在Python中 for循环可以遍历任何序列的项目,如一个列表或者一个字符串等. for循环的格式 for 临时变量 in 列表或者字符串 ...

  10. 命令框下上传到gitee

    git常用命令 C:\Users\Administrator>cd www/p2p设置账号C:\Users\Administrator\www\p2p>git config --globa ...