Docker部署FastDFS的实现方法

Docker 安装fastdfs

挂载目录

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

/e/fdfs/trackerwindows 中的文件夹路径为 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 

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

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 镜像, 官方下载地址: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配置

#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/trackerwindows 中的文件夹路径为 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

表示部署成功!

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

(0)

相关推荐

  • 详解Docker与FastDFS的安装命令及使用

    Docker特点 1)上手快 用户只需要几分钟,就可以把自己的程序"Docker 化".Docker 依赖于"写时复制" (copy-on-write)模型,使修改应用程序也非常迅速,可以说达到"随心所致,代码即改" 的境界. 随后,就可以创建容器来运行应用程序了.大多数 Docker 容器只需要不到 1 秒中即可 启动.由于去除了管理程序的开销,Docker 容器拥有很高的性能,同时同一台宿主机中也 可以运行更多的容器,使用户尽可能的充分利用系

  • 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 # 创建自定义网段 暂

  • centos6使用docker部署kafka项目的方法分析

    本文实例讲述了centos6使用docker部署kafka项目的方法.分享给大家供大家参考,具体如下: 目录结构: /kafka     /Dockerfile     /start.sh     /Readme     /kafka_2.11-0.10.2.1.tgz Dockfile FROM centos MAINTAINER qiongtao.li hnatao@126.com ADD ./kafka_2.11-0.10.2.1.tgz /opt ADD ./start.sh /star

  • Docker 部署 Mysql8.0的方法示例

    1. 参照官网,安装docker 2.拉取mysql镜像 (默认拉取最新的镜像)8.0.11 docker pull mysql 3.在宿主机创建持久化 mysql data 及mysql.cnf mkdir /usr/local/mysqlData/test/cnf mkdir /usr/local/mysqlData/test/data vi /usr/loal/mysqlData/test/cnf/mysql.cnf 设置本地文件共享: Docker -> Preferences... -

  • docker部署LNMP架构的方法

    环境要求: IP hostname 192.168.1.1 node1 项目规划: 容器网段:172.16.10.0/24 NGINX:172.16.10.10 MySQL:172.16.10.20 PHP:172.16.10.20 网站根目录:/www nginx配置文件:/conf mysql持久化目录:/var/lib/mysql 提前准备服务配置文件: nginx <strong>docker run -itd --name test nginx #运行test容器 docker cp

  • 使用docker部署dubbo项目的方法步骤

    1.首先用springboot构建一个简单的dubbo测试程序,并引入相关依赖 编写公共接口api 编写provider实现UserSvice的方法,并暴露服务 编写provider的配置文件 编写Consumer 通过调用provider的服务获取user信息并返回 consumer的配置文件 测试程序已完成 在本地启动,看看程序是否能正常调用服务 启动zookeeper 先启动provider端再启动consumer端 通过dubbo的控制台看到我们的服务已经注册成功 通过访问本地,看到我们

  • docker搭建fastdfs环境的方法步骤

    fastdfs是一个开源的分布式文件系统,在实际使用中,通过源码编译安装过程非常复杂,但是通过docker快速构建却非常容易.下面介绍通过docker安装fastdfs的方法. docker镜像的选择也挺重要的,我最开始选择season/fastdfs,发现有些麻烦,有的版本好像带nginx比如1.2,有的版本又不带nginx比如latest.我使用season/fastdfs镜像安装没有成功过,但是使用delron/fastdfs镜像就成功了,而且只需要启动两个容器,一个tracker,一个s

  • 使用Docker部署Angular项目的方法步骤

    Docker 部署 Angular 项目有两种方法,一种是服务端渲染,这个官方文档已有说明,另一种就是使用 node 镜像编译后放入 web 服务器.由于在 node 环境,所以使用 express 最为便捷了. 创建 server.js const express = require('express'); const app = express(); const config = { root: __dirname + '/dist', port: process.env.PORT || 4

  • 如何使用docker部署前端应用的方法步骤

    docker 变得越来越流行,它可以轻便灵活地隔离环境,进行扩容,方便运维管理.对开发者也更方便开发,测试与部署. 最重要的是, 当你面对一个陌生的项目,你可以照着 Dockerfile,甚至不看文档(文档也不一定全,全也不一定对)就可以很快让它在本地跑起来. 现在很强调 devops 的理念,我把 devops 五个大字放在电脑桌面上,格物致知了一天.豁然开朗,devops 的意思就是写一个 Dockerfile 去跑应用(开玩笑. 这里介绍如何使用 Docker 部署前端应用.千里之行,始于

  • Docker 部署Django项目的方法示例

    使用docker部署django项目也很简单,挺不错,分享下 环境 默认你已安装好docker环境 django项目大概结构 (p3s) [root@opsweb]# tree opsweb opsweb ├── apps ├── logs ├── manage.py ├── media ├── opsweb ├── README.md ├── requirements.txt └── static 编写Dockerfile 这里指定 Python 版本为docker官方提供的 "0.0.0.0

  • Docker 部署 MongoDB容器的方法

    目录 Docker是什么 部署 1. 拉取镜像 2. 查看镜像 3. 运行容器 4. 创建用户 5. 连接 DB 6. UI Docker是什么 " Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口." MongoDB 是一个免费的开源跨平台面向文档的 NoSQL 数据库程序. 下面给大家介绍Docker 部署 MongoDB的详细教程

随机推荐