news 2026/6/9 21:06:15

使用 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/5 8:15:02

收藏级|Java开发者AI大模型转型全攻略:保Java攻AI,筑牢AI时代竞争力

本文专为Java开发者量身定制AI大模型转型指南,深度拆解转型核心优势与潜在坑点,规划低门槛、可落地的渐进式转型路径,提供技术栈平滑过渡方案,重点分享数学基础补强技巧与Java工程经验的AI迁移方法,同步推荐阶梯式实战…

作者头像 李华
网站建设 2026/6/6 8:05:47

学生成绩学分制管理系统的设计与实现任务书

学生成绩学分制管理系统的设计与实现任务书 一、任务名称 学生成绩学分制管理系统的设计与实现 二、任务主体 本次任务面向计算机相关专业学习者,需独立完成学生成绩学分制管理系统的全流程设计与开发,通过实践将软件开发理论、数据库技术、Web开发技术与…

作者头像 李华
网站建设 2026/6/6 8:01:43

面试 Java 基础八股文十问十答第十九期

面试 Java 基础八股文十问十答第十九期 作者:程序员小白条,个人博客 相信看了本文后,对你的面试是有一定帮助的!关注专栏后就能收到持续更新! ⭐点赞⭐收藏⭐不迷路!⭐ 1)HashMap的扩容操作是…

作者头像 李华