系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > server > anz > 详细页面

Docker部署FastDFS的实现方法

时间:2019-12-21来源:系统城作者:电脑系统城

Docker 安装fastdfs

挂载目录

-v /e/fdfs/tracker:/var/fdfs

/e/fdfs/tracker 在 windows 中的文件夹路径为 E:\fdfs\tracker

/var/fdfs 为容器中的文件的绝对路径

查看网络


 
  1. docker network ls # 网络列表
  2.  
  3. docker network create --driver bridge --subnet=192.168.127.0/24 fastdfs_fastdfs_net # 创建自定义网段 暂不使用

下载镜像


 
  1. docker pull season/fastdfs

创建tracker容器 Tracker服务器的端口默认是22122


 
  1. ## 部署流程采用bridge网络
  2. docker run -ti -d --name trakcer -v /f/fastdfs/tracker_data:/fastdfs/tracker/data -p 22122:22122 season/fastdfs tracker

使用docker镜像构建storage容器(存储服务器,提供容量和备份服务)


 
  1. ## 172.17.0.2为容器的ip地址
  2. docker run -tid --name storage -v /f/fastdfs/storage_data:/fastdfs/storage/data -v /f/fastdfs/store_path:/fastdfs/store_path -p 8080:8080 -p 23000:23000 -p 80:80 -e TRACKER_SERVER:172.17.0.2:22122 -e GROUP_NAME=group1 season/fastdfs storage

此时两个服务都以启动


 
  1. ### 进行服务的配置,进入storage容器,到storage的配置文件中配置http访问的端口,配置文件在fdfs_conf目录下的storage.conf
  2. docker exec -it storage bash
  3. cd fdfs_conf
  4. more storage.conf

接下来,退出storage容器,并将配置文件拷贝一份出来:


 
  1. docker cp storage:/fdfs_conf/storage.conf ./

将修改后的配置文件拷贝到storagee的配置目录下:


 
  1. docker cp ./storage.conf storage:/fdfs_conf/

重新启动storage容器


 
  1. docker stop storage
  2. docker start storage

看tracker容器和storage容器的关联

 

 


 
  1. docker exec -it storage bash
  2. cd fdfs_conf
  3. fdfs_monitor storage.conf

 

在docker模拟客户端上传文件到storage容器


 
  1. ## 开启一个客户端
  2. docker cp ./storage.conf fdfs_sh:/fdfs_conf/

更改配置文件,因为之前已经改过一次了,所以现在直接拷贝


 
  1. docker exec -it fdfs_sh bash

创建一个txt文件


 
  1. docker exec -it fdfs_sh bash
  2. echo hello>a.txt

进入fdfs_conf目录,并将文件上传到storage容器


 
  1. cd fdfs_conf
  2.  
  3. fdfs_upload_file storage.conf /a.txt

Windows命令


 
  1. netstat -aon|findstr "22122" # 查看端口是否禁用
  2. netsh firewall set opmode mode=disable # 关闭防火墙
  3. netsh firewall reset

https://hub.docker.com/r/qbanxiaoli/fastdfs)

Windows Server 2012 R2 环境 使用docker-toolbox安装 配置镜像加速


 
  1. docker-machine ssh default
  2. sudo sed -i "s|EXTRA_ARGS='|EXTRA_ARGS='--registry-mirror=http://hub-mirror.c.163.com |g" /var/lib/boot2docker/profile
  3. exit
  4. docke-machine restart default

Docker安装提示:Error response from daemon: client is newer than server

解决方式:用命令 docker version 查看client(客户端)的版本,再就简单粗暴将客户端版本改为与服务端版本一致即可(export DOCKER_API_VERSION=1.22)复制代码

DockerToolbox提示:default Boot2Docker ISO is out-of-date

解决办法:通过下载、拷贝最新版本的 boot2docker.iso 文件,放到安装目录和缓存目录下,可以解决此问题。

下载最新的版的 boot2docker.iso 镜像, 官方下载地址:https://github.com/boot2docker/boot2docker/releases拷贝到本地缓存目录( C:\Users\admin.docker\machine\cache\ )下, 并拷贝到本地的安装目录( C:\Program Files\Docker Toolbox )下, 再次运行 -Docker 再次运行 -Docker Quickstart Termina l终端控制台, 已经能够正常创建```default``虚拟机了。

如果还是提示上述错误的话,那是因为 boot2docker.iso 的版本不是最新版,在启动的时候会联网检查下载最新的 boot2docker.iso ,但是 github 访问速度特别慢导致卡死,所以断网跳过检查这一步,加载到 boot2docker.iso 之后,后续在打开 docker 就没有什么问题了。

挂载文件夹

https://www.jb51.net/article/176813.htm

Fastdfs 集成SpringBoot配置


 
  1. #FastDFS
  2. fdfs:
  3. so-timeout: 1501
  4. connect-timeout: 601
  5. thumb-image: #缩略图生成参数
  6. width: 200
  7. height: 200
  8. tracker-list:
  9. - 192.168.118.162:22122

docker for windows 容器内网通过独立IP直接访问的方法

通过配置路由表实现ip互通

查看 route print


 
  1. ## 添加路由
  2. route -p add 172.17.0.0 MASK 255.255.255.0 10.0.75.2

docker for windows 容器内网通过独立IP直接访问的方法

Docker 部署FastDfs--方式二

 -v /e/fdfs/tracker:/var/fdfs

/e/fdfs/tracker 在 windows 中的文件夹路径为 E:\fdfs\tracker

/var/fdfs 为容器中的文件的绝对路径

clone项目


 
  1. ## 该镜像是集成Nginx的镜像
  2. git clone https://qbanxiaoli@github.com/qbanxiaoli/fastdfs.git

进入fastdfs目录


 
  1. cd fastdfs

修改docker-compose.yml,修改ip


 
  1. shellversion: '3.0'
  2. services:
  3. fastdfs:
  4. build: .
  5. image: qbanxiaoli/fastdfs
  6. # 该容器是否需要开机启动+自动重启。若需要,则取消注释。
  7. restart: always
  8. container_name: fastdfs
  9. ports:
  10. - 8080:8080
  11. - 22122:22122
  12. - 23000:23000
  13. environment:
  14. # 使用东八区的时间
  15. TZ: Asia/Shanghai
  16. # nginx服务端口,默认8080端口,可修改
  17. WEB_PORT: 8080
  18. # tracker_server服务端口,默认22122端口,可修改
  19. FDFS_PORT: 22122
  20. # fastdht服务端口,默认11411端口,可修改
  21. FDHT_PORT: 11411
  22. # docker所在宿主机IP内网地址,默认使用eth0网卡的地址
  23. IP: 192.168.118.93
  24. volumes:
  25. # 将本地目录映射到docker容器内的fastdfs数据存储目录,将fastdfs文件存储到主机上,以免每次重建docker容器,之前存储的文件就丢失了。
  26. - /e/fastdfs/fastdfs:/var/local
  27. # 由于windows和unix识别不了host网络,目前需要新建网段,强制指定容器ip与宿主机ip一致
  28. networks:
  29. fastdfs_net:
  30. ipv4_address: 192.168.118.93
  31.  
  32. networks:
  33. fastdfs_net:
  34. driver: bridge
  35. driver_opts:
  36. parent: eth0
  37. ipam:
  38. config:
  39. - subnet: 192.168.118.0/24

执行docker-compose命令


 
  1. shelldocker-compose up -d

测试fastdfs是否搭建成功


 
  1. # 进入容器内部
  2. docker exec -it fastdfs /bin/bash

重启tracker_server


 
  1. shell/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart

重启storage_server


 
  1. shell/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart

查看storage状态


 
  1. shellfdfs_monitor /etc/fdfs/client.conf

localhost:8080访问nginx

表示部署成功!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

分享到:

相关信息

  • Nginx主机域名配置实现

    一、配置多个端口访问不同文件 二、配置不同域名访问不同文件 三、配置不同域名访问同个文件...

    2023-03-17

  • Nginx配置-日志格式配置方式

    上线了一个小的预约程序,配置通过Nginx进行访问入口,默认的日志是没有请求时间的,因此需要配置一下,将每一次的请求的访问响应时间记录出来,备查与优化使用....

    2023-03-17

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载