如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

2025-03-04 05:50

本文主要是介绍如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N...

Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

使用 Docker 部署 FTP 和 Nginx 通过 HTTP 访问 FTP 里的文件,这是一个常见的需求,通常用于将存储在 FTP 服务器上的文件通过 Web 方式提供访问。

以下是如何操作的详细步骤:

1. 部署 FTP 服务器 (vsftpd)

我们使用 fauria/vsftpd 镜像,因为它配置简单且常用。

创建存储目录: 在宿主机上创建一个目录用于 FTP 存储文件。

mkdir -p /path/to/ftp/data

/path/to/ftp/data 替换为你希望使用的实际路径。

运行 vsftpd 容器:

docker run -d -p 21:21 -p 20:20 -p 21100-21110:21100-21110 \
    -v /path/to/ftp/data:/home/vsftpd \
    -e FTP_USER=ftpuser -e FTP_PASS=ftppass \
    -e PASV_ENABLE=YES -e PASV_MIN_PORT=21100 -e PASV_MAX_PORT=21110 \
    --name ftpserver fauria/vsftpd
  • -p 21:21 -p 20:20: 映射 FTP 的控制端口 (21) 和数据端口 (20)。
  • -p 21100-21110:21100-21110: 映射被动模式的端口范围。被动模式对于 Docker 环境很重要。
  • -v /path/to/ftp/data:/home/vsftpd: 将宿主机目录挂载到容器内的 FTP 用户目录。
  • -e FTP_USER=ftpuser -e FTP_PASS=ftppass: 设置 FTP 用户名和密码。请务必修改为你自己的用户名和密码。
  • -e PASV_ENABLE=YES -e PASV_MIN_PORT=21100 -e PASV_MAX_PORT=21110: 启用被动模式并指定端口范围,这对于在 Docker 容器中使用 FTP 非常重要。
  • --name ftpserver: 为容器命名。

验证 FTP 连接: 使用 FTP 客户端(如 FileZilla)连接到你的服务lzFKycdha器。

2. 部署 Nginx

创建 Nginx 配置文件: 创建一个名为 nginx.conf 的文件,内容如下:

user  root; # 用户使用root,否则没有权限访问FTP用户上传的文件
worker_processes  auto;

error_log  /var/log/nginx/error.log notice;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    Access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    #include /etc/nginx/conf.d/*.conf;  # 注释掉这句,否则里面的默认配置会覆配置盖下面的server配置
        server {
                listen       80;
                listen  [::]:80;
                server_name  localhost; # 修改为你的域名或 IP 地址

                location / {
                        root   /ftp/data; # Nginx 访问的根目录,稍后会通过挂载 FTP 数据目录实现
                        iandroidndex  index.html index.htm;
                }

                error_page   500 502 503 504  /50x.html;
                location = /50x.html {
                        root   /ftp/data;
                }
        }
}

运行 Nginx 容器:

Bash

docker run -d -p 80:80 js
    -v /path/to/ftp/data:/ftp/data \
    -v $(pwd)/nginx.conf:/etc/nginx/conf.d/default.conf \
    --name webserver nginx:latest
  • -p 80:80: 映射 Nginx 的 80 端口。
  • -v /path/to/ftp/data:/ftp/data: 关键步骤! 将 FTP 数据目录挂载到 Nginx 容器内的 /ftp/data 目录。这样 Nwww.chinasem.cnginx 就可以访问 FTP 上的文件了。
  • -v $(pwd)/nginx.conf:/etc/nginx/conf.d/default.conf: 将我们创建的 Nginx 配置文件挂载到容器内。
  • --name webserver: 为China编程容器命名。
  • nginx:latest: 使用最新的 Nginx 镜像。

3. 访问 FTP 文件

现在,你可以通过浏览器访问服务器的 IP 地址 (例如 http://your_server_ip) 来浏览 FTP 上的文件。Nginx 将会提供一个文件列表,你可以点击链接下载文件。

使用 Docker Compose (推荐)

使用 Docker Compose 可以更方便地管理多个容器。

创建一个名为 docker-compose.yml 的文件,内容如下:

version: "3.9"
services:
  ftpserver:
    image: fauria/vsftpd
    ports:
      - "21:21"
      - "20:20"
      - "21100-21110:21100-21110"
    volumes:
      - ./ftpdata:/home/vsftpd # 注意使用相对路径
    environment:
      - FTP_USER=ftpuser
      - FTP_PASS=ftppass
      - PASV_ENABLE=YES
      - PASV_MIN_PORT=21100
      - PASV_MAX_PORT=21110
    restart: always

  webserver:
    image: nginx:latest
    ports:
      - "80:80"
    volumes:
      - ./ftpdata:/ftp/data # 共享同一个数据卷
      - ./nginx.conf:/etc/nginx/nginx.conf # 挂载配置文件
    depends_on:
      - ftpserver # 依赖于 ftpserver 启动
    restart: always
volumes:
 ftpdata: #定义数据卷

在该文件所在目录下运行 docker-compose up -d 即可同时启动 FTP 和 Nginx 容器。

关键点和注意事项:

  • 被动模式 (PASV): 在 Docker 环境中,FTP 客户端通常需要使用被动模式。确保正确配置被动模式的端口范围。
  • 数据卷: 使用数据卷来共享 FTP 和 Nginx 容器之间的文件。这是实现此功能的关键。
  • 安全性: 上述配置只是一个基本的示例。在生产环境中,你需要考虑安全性问题,例如使用 SFTP 而不是 FTP,配置防火墙,限制访问权限等。
  • 端口映射: 确保宿主机上没有其他服务占用这些端口。
  • 文件权限: 确保 FTP 容器和 Nginx 容器都具有访问共享目录的正确权限。

希望以上步骤能够帮助你成功搭建 FTP 和 Nginx 服务,并通过 HTTP 访问 FTP 上的文件。使用 Docker Compose 可以大大简化部署和管理过程,强烈推荐使用。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153631

相关文章

解读docker运行时-itd参数是什么意思

《解读docker运行时-itd参数是什么意思》在Docker中,-itd参数组合用于在后台运行一个交互式容器,同时保持标准输入和分配伪终端,这种方式适合需要在后台运行容器并保持交互能力的场景... 目录docker运行时-itd参数是什么意思1. -i(或 --interactive)2. -t(或 --

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Python中配置文件的全面解析与使用

《Python中配置文件的全面解析与使用》在Python开发中,配置文件扮演着举足轻重的角色,它们允许开发者在不修改代码的情况下调整应用程序的行为,下面我们就来看看常见Python配置文件格式的使用吧... 目录一、INI配置文件二、YAML配置文件三、jsON配置文件四、TOML配置文件五、XML配置文件

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

Ubuntu 22.04 服务器安装部署(nginx+postgresql)

《Ubuntu22.04服务器安装部署(nginx+postgresql)》Ubuntu22.04LTS是迄今为止最好的Ubuntu版本之一,很多linux的应用服务器都是选择的这个版本... 目录是什么让 Ubuntu 22.04 LTS 变得安全?更新了安全包linux 内核改进一、部署环境二、安装系统

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

Keepalived+Nginx双机配置小结

《Keepalived+Nginx双机配置小结》本文主要介绍了Keepalived+Nginx双机配置小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1.1 软硬件要求1.2 部署前服务器配置调优1.3 Nginx+Keepalived部署1.3

nginx upstream六种方式分配小结

《nginxupstream六种方式分配小结》本文主要介绍了nginxupstream六种方式分配小结,包括轮询、加权轮询、IP哈希、公平轮询、URL哈希和备份服务器,具有一定的参考价格,感兴趣的可... 目录1 轮询(默认)2 weight3 ip_hash4 fair(第三方)5 url_hash(第三