gpt4 book ai didi

Docker部署FastDFS的实现方法

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 29 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Docker部署FastDFS的实现方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

Docker 安装fastdfs 。

挂载目录 。

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

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

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

查看网络 。

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

下载镜像 。

?
1
docker pull season /fastdfs

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

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

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

?
1
2
## 172.17.0.2为容器的ip地址
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
2
3
4
### 进行服务的配置,进入storage容器,到storage的配置文件中配置http访问的端口,配置文件在fdfs_conf目录下的storage.conf
docker exec -it storage bash
cd fdfs_conf
more storage.conf

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

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

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

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

重新启动storage容器 。

?
1
2
docker stop storage
docker start storage

看tracker容器和storage容器的关联 。

 

  。

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

Docker部署FastDFS的实现方法

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

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

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

?
1
docker exec -it fdfs_sh bash

创建一个txt文件 。

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

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

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

Windows命令 。

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

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

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

?
1
2
3
4
docker-machine ssh default
sudo sed -i "s|EXTRA_ARGS='|EXTRA_ARGS='--registry-mirror=http://hub-mirror.c.163.com |g" /var/lib/boot2docker/profile
exit
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 就没有什么问题了.

挂载文件夹 。

http://www.zzvips.com/article/156325.html 。

Fastdfs 集成SpringBoot配置 。

?
1
2
3
4
5
6
7
8
9
#FastDFS
fdfs:
   so-timeout: 1501
   connect-timeout: 601
   thumb-image:       #缩略图生成参数
     width: 200
     height: 200
   tracker-list:
     - 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
2
## 该镜像是集成Nginx的镜像
git clone https: //qbanxiaoli @github.com /qbanxiaoli/fastdfs .git

进入fastdfs目录 。

?
1
cd fastdfs

修改docker-compose.yml,修改ip 。

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

表示部署成功! 。

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

原文链接:https://juejin.im/post/5dfb64006fb9a0162712856e 。

最后此篇关于Docker部署FastDFS的实现方法的文章就讲到这里了,如果你想了解更多关于Docker部署FastDFS的实现方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com