Docker快速搭建 file-transfer-go:极简文件传输工具部署教程

简介: Docker快速搭建 file-transfer-go:极简文件传输工具部署教程

一、file-transfer-go介绍

1.1 file-transfer-go简介

file-transfer-go是一个基于 Go(后端信令与 P2P 协调)和 React(前端界面)构建的端到端 WebRTC 应用,专注于安全、高效、无需中转服务器的数据传输。它支持文件、文本和桌面共享,所有数据直接在用户之间传输,不经过任何中间服务器,确保隐私与安全。

1.2 file-transfer-go主要特点

  • 📁 多文件同时传输:支持一次性选择并并行传输多个文件,提升批量分享效率。
  • 📝 即时文字传输:可快速发送纯文本消息,无需等待连接建立完成即可预览内容。
  • 🖥️ 实时桌面共享:通过 WebRTC 实现低延迟屏幕共享,适用于远程协作或演示场景。
  • 🔗 连接状态同步:UI 实时反映 Peer 连接状态(如连接中、已连接、断开等),提升用户体验。
  • 🔒 端到端加密:所有传输内容使用 DTLS/SRTP(WebRTC 内建)及可选应用层加密,确保数据无法被窃听或篡改。
  • 📱 响应式设计:前端采用现代化 React 响应式布局,适配手机、平板和桌面设备。
  • 🖥️ 多平台单文件部署:后端使用 Go 编译为单一可执行文件,支持 Linux、macOS 和 Windows,部署简单无依赖。

二、本次实践规划

2.1 本地环境规划

本次实践为个人测试环境,操作系统版本为 Ubuntu 24.04.2 LTS。

hostname IP地址 操作系统版本 Docker版本 部署项目 备注
jeven 192.168.3.88 Ubuntu 24.04.2 LTS 28.5.0 file-transfer-go ——

2.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署file-transfer-go文件传输工具。

三、本地环境检查

3.1 检查Docker服务状态

检查Docker服务是否正常运行,确保Docker正常运行。

root@jeven:~# systemctl status docker
● docker.service - Docker Application Container Engine
     Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; preset: enabled)
     Active: active (running) since Tue 2025-12-02 00:51:31 CST; 1min 11s ago
TriggeredBy: ● docker.socket
       Docs: https://docs.docker.com
   Main PID: 75393 (dockerd)
      Tasks: 32
     Memory: 34.1M (peak: 34.8M)
        CPU: 1.248s
     CGroup: /system.slice/docker.service

在这里插入图片描述

3.2 检查Docker版本

检查Docker版本

root@jeven:~# docker -v
Docker version 28.5.0, build 887030f

3.3 检查docker compose 版本

检查Docker compose版本,确保2.0以上版本。

root@jeven:~# docker compose version
Docker Compose version v2.39.4

四、拉取file-transfer-go文件传输工具镜像

下载file-transfer-go文件传输工具镜像,执行以下命令:

docker pull matrixseven/file-transfer-go:latest

在这里插入图片描述

五、部署file-transfer-go服务

5.1 创建部署目录

  • 创建部署目录
mkdir -p /data/file-transfer-go/  && cd /data/file-transfer-go

5.2 docker compose方式部署

如果使用docker-cli方式部署,可参考以下命令:

docker run -d -p 8080:8080 --name file-transfer-go matrixseven/file-transfer-go:latest

新建及编辑docker-compose.yaml文件,宿主机映射端口可自行设置,注意防止端口冲突。

vim docker-compose.yaml
version: '3'

services:
  file-transfer-go:
    image: matrixseven/file-transfer-go:latest
    container_name: file-transfer-go
    restart: unless-stopped
    ports:
      - 7500:8080

5.3 创建file-transfer-go容器

执行以下命令,创建file-transfer-go容器。

docker compose up -d

在这里插入图片描述

5.4 查看file-transfer-go容器状态

检查file-transfer-go容器运行状态,确保file-transfer-go容器正常启动。

root@jeven:/data/file-transfer-go# docker compose ps
WARN[0000] /data/file-transfer-go/docker-compose.yaml: the attribute `version` is obsolete, it will be ignored, please remove it to avoid potential confusion
NAME               IMAGE                                 COMMAND      SERVICE            CREATED         STATUS         PORTS
file-transfer-go   matrixseven/file-transfer-go:latest   "./server"   file-transfer-go   2 minutes ago   Up 2 minutes   0.0.0.0:7500->8080/tcp,[::]:7500->8080/tcp

在这里插入图片描述

5.5 检查file-transfer-go容器日志

检查容器运行日志,确保file-transfer-go服务正常运行。

docker compose logs

在这里插入图片描述

六、访问file-transfer-go服务

6.1 访问file-transfer-go首页

浏览器地址: http://<个人的服务器IP>:7500,访问file-transfer-go初始页。如果无法访问,请确保宿主机的防火墙已关闭或已放行相关端口,对于云服务器还需配置相应的安全组规则。

在这里插入图片描述

6.2 发送文件

选择文件传输——发送文件,将本地上传到file-transfer-go。

在这里插入图片描述

6.3 生成取件码

上传文件后,我们点击【生成取件码】,我们可以通过复制文件链接来接收文件。

在这里插入图片描述

6.4 接收文件

  • 分享链接访问:将分享链接复制到内网中另外一台电脑,则可以看到已建立连接,直接点击【开始传输】即可。

在这里插入图片描述
在这里插入图片描述

七、总结

通过本次实践,我们成功使用Docker和Docker Compose快速部署了file-transfer-go文件传输工具,验证了其轻量、高效和易用的特性。整个过程无需复杂配置,仅需编写简单的compose文件即可启动服务,极大提升了部署效率。通过浏览器访问服务界面,能够便捷地完成文件上传、取件码生成与接收等操作,满足临时文件分享需求。该方案适用于个人或团队在内网或公网环境中快速搭建安全、临时的文件传输服务。

相关文章
|
2天前
|
弹性计算 人工智能 Linux
阿里云ECS/轻量服务器部署 OpenClaw 图文攻略:Slack集成+千问Qwen3.6-Plus与Coding Plan配置教程
本文完整覆盖2026年**阿里云轻量服务器/ECS云服务器部署OpenClaw、本地MacOS/Linux/Windows11全平台搭建、千问Qwen3.6-Plus付费API与免费Coding Plan双模型配置、Slack全球协作工具集成**四大核心流程,搭配全场景高频问题排查方案,所有命令均为实测可直接复制,无需复杂操作即可完成部署。
169 18
|
23天前
|
传感器 机器学习/深度学习 算法
复杂三维山地环境下小龙虾优化算法COA求解多无人机动态避障路径规划研究附MATLAB代码
🌿 往期回顾可以关注主页,点击搜索 智能优化算法 神经网络预测 雷达通信 无线传感器 电力系统 信号处理 图像处理 路径规划 元胞自动机 无人机 物理应用 机器学习系列 车间调度系列 滤波跟踪系列 数据分析系列 图像处理系列 ✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:
|
17天前
|
传感器 算法 前端开发
迷宫中的领航者:揭秘SLAM背后的数学逻辑
SLAM(同步定位与建图)是机器人实现空间感知的基石:在未知环境中,它 simultaneously 解决“我在哪”与“环境长什么样”这一鸡生蛋蛋生鸡的难题。本文系统解析其经典架构、数学本质(SE(3)、李代数)、前端里程计(特征/直接法)、后端优化(滤波→图优化)、闭环检测、多传感器融合、语义与神经表示等前沿演进,展现从几何建图到空间智能的恢弘跃迁。(239字)
241 6
|
29天前
|
供应链 安全 Shell
ExifTool元数据解析漏洞机制与macOS供应链防御研究
本文深度剖析ExifTool高危漏洞CVE-2026-3102:攻击者通过构造恶意图像元数据,在macOS下利用`-n`参数触发远程代码执行。漏洞源于解析逻辑缺陷,非传统内存破坏,隐蔽性强。文章揭示“文件即武器”新范式,提出补丁更新、输入验证、沙箱隔离与最小权限等纵深防御方案,并附PoC与实操脚本。(239字)
117 18
|
29天前
|
数据采集 JSON API
从踩坑到高效落地:关键词搜索京东商品列表API的实操心得
本指南聚焦京东商品列表API实操,详解jd.item_search接口调用要点:涵盖必填参数(app_key、timestamp、sign等)、关键词/分页/价格筛选配置及核心响应字段(SKU、标题、售价、销量等),助开发者快速对接,高效获取合规商品数据。(239字)
217 22
|
20天前
|
机器学习/深度学习 人工智能 机器人
大模型应用:稀疏注意力 vs 滑动窗口:大模型扩窗技术完全解析.58
本文详解大模型“扩窗”核心技术:滑动窗口注意力(快而局部,适合中短文本)与稀疏注意力(兼顾局部+跨步+首尾,支持超长上下文)。二者均通过降低O(n²)计算复杂度至线性,解决大模型长文本处理的内存与算力瓶颈,推动其从聊天工具升级为长文档分析、代码全量理解等实用AI。
321 26
|
21天前
|
Ubuntu Linux Docker
超全 Docker 镜像源配置指南|Windows/Mac/Linux一键搞定,拉镜像再也不卡顿
Docker拉取官方镜像慢到离谱,要么超时报错,要么中途断连,折腾半天连基础镜像都拉不下来,直接拖慢整个开发进度。 其实解决办法很简单——配置专属镜像源!今天给大家带来镜像源全平台配置教程,覆盖Linux(Ubuntu/CentOS通用)、Windows/Mac版Docker Desktop,甚至Mac专属轻量工具OrbStack,一步一图+命令复制即用,彻底告别镜像拉取卡顿!
1639 9
|
8天前
|
机器学习/深度学习 存储 人工智能
大模型应用:批量文档摘要与分类实践:本地合同、报告数据处理与导出.70
本方案基于Qwen 1.5 7B大模型,实现本地化批量文档处理:自动读取Word/PDF,经TextSplitter智能分块、Schema引导式提示,生成标准化摘要与多标签分类,最终导出CSV。全程离线运行,保障敏感数据安全,显著提升合同、报告等高频文档的处理效率与准确性。
180 16
|
28天前
|
JavaScript Linux API
【OpenClaw保姆级教程】阿里云/Win11/MacOS/Linux部署+4个核心Skill搞定80%工作
“花两天部署好OpenClaw,结果只会聊天?让它搜竞品数据说‘无法联网’,让它整理Excel说‘没有功能’”——这是2026年无数OpenClaw用户的共同吐槽。正如参考文章中跨境电商从业者的经历,很多人误以为部署完OpenClaw就万事大吉,却忽略了核心:OpenClaw本身只是“空壳框架”,真正让它从“废物”变“神器”的,是Skills(技能插件)。
775 19