这篇文章主要介绍“Docker部署FastDFS实例分析”,在日常操作中,相信很多人在Docker部署FastDFS实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Docker部署FastDFS实例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
docker 安装fastdfs
挂载目录
-v /e/fdfs/tracker:/var/fdfs
/e/fdfs/tracker
在 windows
中的文件夹路径为 e:\fdfs\tracker
/var/fdfs
为容器中的文件的绝对路径
查看网络
docker network ls # 网络列表 docker network create --driver bridge --subnet=192.168.127.0/24 fastdfs_fastdfs_net # 创建自定义网段 暂不使用
下载镜像
docker pull season/fastdfs
创建tracker容器 tracker服务器的端口默认是22122
## 部署流程采用bridge网络 docker run -ti -d --name trakcer -v /f/fastdfs/tracker_data:/fastdfs/tracker/data -p 22122:22122 season/fastdfs tracker
使用docker镜像构建storage容器(存储服务器,提供容量和备份服务)
## 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
此时两个服务都以启动
### 进行服务的配置,进入storage容器,到storage的配置文件中配置http访问的端口,配置文件在fdfs_conf目录下的storage.conf docker exec -it storage bash cd fdfs_conf more storage.conf
接下来,退出storage容器,并将配置文件拷贝一份出来:
docker cp storage:/fdfs_conf/storage.conf ./
将修改后的配置文件拷贝到storagee的配置目录下:
docker cp ./storage.conf storage:/fdfs_conf/
重新启动storage容器
docker stop storage docker start storage
看tracker容器和storage容器的关联
docker exec -it storage bash cd fdfs_conf fdfs_monitor storage.conf
在docker模拟客户端上传文件到storage容器
## 开启一个客户端 docker cp ./storage.conf fdfs_sh:/fdfs_conf/
更改配置文件,因为之前已经改过一次了,所以现在直接拷贝
docker exec -it fdfs_sh bash
创建一个txt文件
docker exec -it fdfs_sh bash echo hello>a.txt
进入fdfs_conf目录,并将文件上传到storage容器
cd fdfs_conf fdfs_upload_file storage.conf /a.txt
windows命令
netstat -aon|findstr "22122" # 查看端口是否禁用 netsh firewall set opmode mode=disable # 关闭防火墙 netsh firewall reset
)
windows server 2012 r2 环境 使用docker-toolbox安装 配置镜像加速
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
镜像, 官方下载地址:拷贝到本地缓存目录( 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
就没有什么问题了。
挂载文件夹
fastdfs 集成springboot配置
#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
## 添加路由 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项目
## 该镜像是集成nginx的镜像 git clone https://qbanxiaoli@github.com/qbanxiaoli/fastdfs.git
进入fastdfs目录
cd fastdfs
修改docker-compose.yml,修改ip
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命令
shelldocker-compose up -d
测试fastdfs是否搭建成功
# 进入容器内部 docker exec -it fastdfs /bin/bash
重启tracker_server
shell/usr/bin/fdfs_trackerd /etc/fdfs/tracker.conf restart
重启storage_server
shell/usr/bin/fdfs_storaged /etc/fdfs/storage.conf restart
查看storage状态
shellfdfs_monitor /etc/fdfs/client.conf
localhost:8080访问nginx
表示部署成功!
到此,关于“Docker部署FastDFS实例分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。