news 2026/7/3 23:22:55

使用 Docker / Docker Compose 部署 PdfDing —— 个人 PDF笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用 Docker / Docker Compose 部署 PdfDing —— 个人 PDF笔记

PdfDing 是一款开源的PDF 文档管理与阅读工具,支持标签分类、全文检索、暗色主题等实用功能,非常适合用于搭建个人或小团队的 PDF 资料库。本文将手把手教你通过两种主流方式快速部署 PdfDing:

  • 方式一:docker run(适合快速体验)
  • 方式二:docker-compose(推荐用于长期使用)

一、环境准备

在开始部署前,请确保你的系统满足以下条件:

  • 操作系统:Linux / macOS / Windows(建议使用 WSL2)
  • 已安装Docker ≥ 20.x
  • (可选)已安装Docker Compose ≥ 2.x

验证 Docker 是否正常工作:

dockerversion

若未安装,请参考 Docker 官方安装指南。


二、方式一:使用docker run快速启动(适合测试)

1️⃣ 启动命令

dockerrun --name pdfding\-p8000:8000\-v sqlite_data:/home/nonroot/pdfding/db\-v media:/home/nonroot/pdfding/media\-eHOST_NAME=127.0.0.1\-eSECRET_KEY=some_secret\-eCSRF_COOKIE_SECURE=FALSE\-eSESSION_COOKIE_SECURE=FALSE\-d\mrmn/pdfding:latest

2️⃣ 参数说明

参数说明
--name pdfding容器名称,便于管理
-p 8000:8000将容器的 8000 端口映射到宿主机
-v sqlite_data:/.../db持久化 SQLite 数据库(避免重启丢失数据)
-v media:/.../media持久化上传的 PDF 文件
HOST_NAME设置访问地址(如your-domain.com192.168.1.100
SECRET_KEYDjango 应用密钥(生产环境务必更换为强随机字符串
CSRF_COOKIE_SECURE/SESSION_COOKIE_SECURE是否仅在 HTTPS 下传输 Cookie(开发可设为FALSE,生产应为TRUE

3️⃣ 访问服务

打开浏览器,访问:

http://127.0.0.1:8000

即可看到 PdfDing 的界面,开始上传和管理你的 PDF 文档!


三、方式二:使用 Docker Compose 部署(推荐 ✅)

Docker Compose 提供更清晰的配置结构,便于版本控制、备份和升级,强烈推荐用于日常使用或团队部署

1️⃣ 创建docker-compose.yml

version:"3.8"services:pdfding:container_name:pdfdingimage:mrmn/pdfding:latestports:-"8000:8000"volumes:-sqlite_data:/home/nonroot/pdfding/db-media:/home/nonroot/pdfding/mediaenvironment:# 主题设置-DEFAULT_THEME=${DEFAULT_THEME:-dark}-DEFAULT_THEME_COLOR=${DEFAULT_THEME_COLOR:-blue}# 安全与配置-SECRET_KEY=${SECRET_KEY:-change_me_to_a_strong_random_string}-HOST_NAME=${HOST_NAME:-127.0.0.1}# 生产环境建议启用 HTTPS 后设为 TRUE-CSRF_COOKIE_SECURE=${CSRF_COOKIE_SECURE:-FALSE}-SESSION_COOKIE_SECURE=${SESSION_COOKIE_SECURE:-FALSE}restart:unless-stoppedvolumes:sqlite_data:media:

💡 建议同时创建.env文件管理敏感配置(如SECRET_KEY),避免硬编码。

2️⃣ 启动服务

docker-compose.yml所在目录执行:

dockercompose up -d

查看运行状态:

dockercomposeps

3️⃣ 访问应用

浏览器打开:

http://127.0.0.1:8000

现在你拥有了一个功能完整的 PDF 管理平台!


四、常用运维命令

操作命令
查看实时日志docker logs -f pdfding
停止服务docker compose down
更新到最新版docker pull mrmn/pdfding:latest && docker compose up -d
备份数据备份sqlite_datamedia卷(或挂载到宿主机路径)

五、生产环境安全建议(重要!)

如果你计划在内网或公网长期使用 PdfDing,请务必:

  1. 更换SECRET_KEY:使用openssl rand -hex 32生成强密钥。
  2. 启用 HTTPS
    • 通过 Nginx + Let’s Encrypt(公网)
    • 或使用私有 CA(如 step-ca,适用于内网)
  3. 设置安全 Cookie
    CSRF_COOKIE_SECURE=TRUE SESSION_COOKIE_SECURE=TRUE
  4. 限制访问 IP(如仅允许公司内网)
  5. 定期备份dbmedia数据卷

六、总结

部署方式适用场景推荐指数
docker run临时测试、快速体验⭐⭐
docker-compose日常使用、团队部署、生产环境⭐⭐⭐⭐⭐

PdfDing 轻量、开源、功能聚焦,是构建个人笔记的最佳选择。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/30 21:43:03

文献查询免费网站推荐:实用学术资源检索平台汇总

做科研的第一道坎,往往不是做实验,也不是写论文,而是——找文献。 很多新手科研小白会陷入一个怪圈:在知网、Google Scholar 上不断换关键词,结果要么信息过载,要么完全抓不到重点。今天分享几个长期使用的…

作者头像 李华
网站建设 2026/7/1 19:23:28

硕士毕业通关秘籍:paperzz 毕业论文智能写作工具,让学术告别焦虑

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertationhttps://www.paperzz.cc/dissertation 每一位硕士研究生都懂,毕业论文不仅是学术生涯的收官之作&…

作者头像 李华
网站建设 2026/6/26 17:08:47

收藏备用!SFT/ReFT/RLHF/DPO/PPO五大大模型微调技术全解析+对比

在大模型落地实践中,微调技术是让预训练模型适配特定任务、提升性能的核心手段。本文将系统对比分析SFT、ReFT、RLHF、DPO和PPO五种主流微调技术,拆解各自的核心逻辑、实现流程、优劣差异及适用场景,同时补充实操细节和技术关联点&#xff0c…

作者头像 李华
网站建设 2026/7/1 4:45:01

‌职业倦怠自救:2026年软件测试从业者心理健康管理指南

一、2026年测试岗位的心理新图景:不是变轻松了,而是更隐蔽了‌ 2026年,软件测试不再是“点点点”的重复劳动。AI测试助手已接管85%的回归测试、90%的UI兼容性验证、70%的接口自动化用例生成。表面上,测试工程师的“体力负担”大幅…

作者头像 李华
网站建设 2026/6/26 6:40:49

收藏!AI就业黄金三年攻略:从岗位选择到入局路径,程序员小白必看

过去十年,互联网行业走完了从野蛮生长的黄金时代到存量博弈的转型期,岗位竞争愈发激烈。 但在全行业都在讨论“岗位缩减”“优化调整”的当下,有一个领域却在逆势爆发,成为就业市场的新风口——AI应用与智能体时代。这绝非技术乐观…

作者头像 李华
网站建设 2026/6/26 3:03:27

游戏测试和软件测试有什么区别?

针对手游而言,游戏测试的本质是APP,所以不少手游的测试方式与APP测试异曲同工,然而也有所不同。APP更多的是具有一种工具,一款APP好不好用不重要,关键点在于实用。而游戏则具有一种玩具属性,它并不见得实用…

作者头像 李华