无图无真相,先放个效果图:

 

 

背景

使用 docker 来跑一些服务很方便,但是有的时候想管理容器里面的文件却很麻烦 -- 一般常规做法有3种:

  1. 通过数据卷或数据卷容器的方式
  2. 启动容器的时候时候启动 vsftpd 或者 sshd 等服务,并开启端口映射,然后通过 ftp/sftp 连上去管理
  3. 进入容器的终端,通过命令行管理

但是这些做法都有一定的缺陷和不便:

1和2都是需要在启动容器的时候做一些配置,如果容器已经启动了就歇菜了。而且2需要额外的端口映射,占用主机的端口。3的做法比较 geek ,而容器中通常只有基础的 shell 工具,没有一个熟悉的工具套件环境,操作比较费时费力,不够直观。

解决方案: ftp-server-for-docker

我所能想到比较好的解决方案是综合2和3的方案,构建一个不需要额外的启动配置的 FTP 服务器:ftp-server-for-docker

这是一个 docker 专用的 FTP 服务器 - 允许通过 FTP 协议来访问 docker 容器中的文件(即使 docker 容器已经启动了也可以的哟)。基于 linux shell sh 和 docker 的 docker cp.

如何安装

推荐使用 npm 安装:

npm install -g ftp-server-for-docker

如何运行

示例1

比如说在 localhost:21 上启动 FTP 服务器,并运行 test 用户通过密码 123456 来访问:

$ ftp-server-for-docker -H localhost -p 21 --users test:123456
FtpServer start listening at localhost:21

示例2

使用 ftp-server-for-docker 来浏览容器 wordpress 中的文件:

查看命令行帮助

想要知道更多使用方法,可以查看命令行帮助:

$ ftp-server-for-docker --help
Usage: ftp-server-for-docker [options] Options:
--port, -p Specify which port to listen on(default is 21) [number]
--host, -H Specify which host to bind(default is 0.0.0.0) [string]
--annoymous, -a Whether enable annoymous user [boolean]
--users, -u Specify users (in form like username:password, can be
multiple) [array]
--config, -c Specify which configuration file to use
--debug Whether enable debug mode [boolean]
-h, --help Show help [boolean]
-?, --help Show help [boolean] Examples:
ftp-server-for-docker -h localhost -p 21 Start the FTP Server on
-u test:123 localhost:21, allow user `test` to
access.

实现原理

这个 FTP 服务器网络方面采用了比较成熟的 ftpd ,而文件系统模块替换成了新写的 Docker FS.

文件系统的基本操作(stat/readdir/open/unlink...)都是通过 docker execdocker cp和临时文件来完成,比如:

  • stat 是通过 docker exec <container> stat xxx 来查看文件状态
  • readdir 是通过 docker exec <container> ls -1 --color=none 来列出目录下的文件
  • open 是通过 docker cp <container>:<path> <temp-path> 把容器中的文件拷贝到临时文件中,然后再读取的

具体实现流程参见源代码

关于 TypeScript

这个项目中的主要源代码都使用 TypeScript -- 都是在 src/*.ts 中,通过 tsc 编译后生成成 lib/*.js,最终npm打包的只有 lib/*.js 没有 src/*.ts.

这是我第一次使用 TypeScript. TypeScript 的强类型带来很多方便,也带来很多不便。综合而言,TypeScript 让我想起了曾经使用过的 C#,结合 Visual Studio Code 来用还是利大于弊。TypeScript 能在编辑和编译的时候就检查出很多类型问题,而且智能提示确实很棒。

常见问题

  1. FileZilla 无法列出目录结构 -- 可以尝试配置传输模式为 主动模式,被动模式还有问题,正在解决ing...
  2. 中文目录显示乱码 -- 已知问题,正在解决ing...

如有其他问题,欢迎来提 issue, 当然更欢迎 fork 并解决后来提 PR.

原文地址:http://www.clarencep.com/2017/04/15/ftp-server-for-docker/ 转载请注明出处。

无需安装 vsftpd , 直接使用 FTP 来管理 docker 容器中的文件的更多相关文章

  1. [docker] 管理docker容器中的数据

    之前我们介绍了Docker的基本概念(前面的没翻译...),了解了如何使用Docker镜像进行工作,并且学习了网 络和容器之间的链接.这一节我们将讨论如何管理容器中及容器之间的数据. 我们将查看下面两 ...

  2. Docker 容器中相关软件安装

    Docker 容器中相关软件安装 1.介绍 我们从docker hub下载的centos镜像是只有很少的命令,需要单独安装我们所需的相关软件. 2.安装软件 安装yum-utils软件包 该软件包是辅 ...

  3. 在Docker容器中安装jdk和spark

    在Docker容器中安装jdk和spark 1.下载jdk和spark 可以使用迅雷等专业下载软件下载jdk和spark软件包,注意是linux版,这里直接给出下载地址: JDK下载地址 JDK进入后 ...

  4. Docker容器中用户权限管理

    在Linux系统中有一部分知识非常重要,就是关于权限的管理控制:Linux系统的权限管理是由uid和gid负责,Linux系统会检查创建进程的uid和gid,以确定它是否有足够的权限修改文件,而非是通 ...

  5. 管理和安装 chart - 每天5分钟玩转 Docker 容器技术(168)

    安装 chart 当我们觉得准备就绪,就可以安装 chart,Helm 支持四种安装方法: 安装仓库中的 chart,例如:helm install stable/nginx 通过 tar 包安装,例 ...

  6. Jenkins(2)docker容器中安装python3

    前言 使用docker安装jenkins环境,jenkins构建的workspace目录默认是在容器里面构建的,如果我们想执行python3的代码,需进容器内部安装python3的环境. 进jenki ...

  7. 在docker容器中安装和使用,linux版的powershell

    powershell 传教士 原创文章.始于 2016-09-18 ,2016-10-27修改powershell docker官网.允许转载,但必须保留名字和出处,否则追究法律责任 1 在任意版本的 ...

  8. Docker容器中安装vim

    我在docker中安装了jexus.使用vim编辑default配置文件的时候提示 vim: command not found 原因是docker中没有安装vim命令 如果你直接输入  apt-ge ...

  9. docker容器中安装vi命令

    在使用docker容器时,有时候里边没有安装vim,敲vim命令时提示说:vim: command not found,这个时候就需要安装vim,可是当你敲apt-get install vim命令时 ...

随机推荐

  1. ThinkPHP重写路由,掩藏public/index.php

    在thinkPHP项目中,为了掩藏 public/index.php 路径时,需要修改相关的 Apache httpd.confi 文件.ThinkPHP .htaccess文件 修改 Apache ...

  2. vue :src本地图片不读取

    修改方式: 使用require(‘文件名’)

  3. pandas中获取数据框的行、列数

    获取数据框的行.列数 # 获取行数 df.shape[0] # 获取行数 len(df) # 获取列数 df.shape[1]

  4. JAVA学习7:在Maven仓库中添加Oracle JDBC驱动

    由于Oracle授权问题,Maven3不提供Oracle JDBC driver,为了在Maven项目中应用Oracle JDBC driver,必须手动添加到本地仓库. 一.首先要得到Oracle ...

  5. sql 查询目标数据库中所有的表以其关键信息

    1.查询目标库中的所有表 SELECT obj.name tablename, ---表名 schem.name schemname, ---表所属的方案 idx.rows, ---一共有几行数组 C ...

  6. SqlHelper中SqlHelperParameterCache类的用法介绍

    SqlHelper类中提供了三种可以用来管理SqlParameter参数的共享方法.下面来一一讲解: 1.CacheParameterSet 将SqlParameter参数数组存储到本地缓存中 2.G ...

  7. iOS设备的屏幕分辨率

    全部列在这里吧.方便自己方便别人.保持更新…… iPhone: iPhone 1G320x480 iPhone 3G320x480 iPhone 3GS320x480 iPhone 4640x960 ...

  8. Node.js中http-server的使用

    Node.js中http-server的使用 使用阿里的npm镜像 国外的npm太慢了.查看一下自己使用的源: npm config get registry 应该显示https://registry ...

  9. 2018年12月份最热门的Java开源项目

    1 JavaGuide https://github.com/Snailclimb/JavaGuide     Star 14726 这是一份Java学习指南,涵盖大部分Java程序员所需要掌握的核心 ...

  10. Apache 反向代理 丢失Authorization

    我后端API的服务器是Tomcat,而后端API验证是通过存放在头部Authorization的token值进行验证的. 我在测试Apache作为前端html解析的服务器时, 利用反向代理,把Api请 ...