news 2026/5/10 2:44:06

本地部署文档管理系统 Paperless-ngx 并实现外部访问

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
本地部署文档管理系统 Paperless-ngx 并实现外部访问

Paperless-ngx 是一款开源的文档管理系统,它可以帮助用户实现纸质文档的数字化管理,从而减少对纸张的依赖,提高工作效率。本文将详细介绍如何利用 Docker 在 Linux 系统局域网内部署 Paperless-ngx 并结合路由侠实现外网访问局域网内部署的 Paperless-ngx 。

第一步,本地部署 Paperless-ngx

1,本教程操作环境为 Linux Ubuntu 系统,Paperless-ngx 依赖 Docker 运行,我们需要先确保你的系统上已经安装了 Docker 。如果尚未安装,可以参考文档进行安装,点此查看。

2,打开 Linux 终端,安装 Docker Compose 。

sudo curl -L "https://github.com/docker/compose/releases/download/$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep -Po '"tag_name": "\K.*\d')" /usr/local/bin/docker-compose

3,输入以下命令创建并进入项目目录。

mkdir -p ~/paperless-ngx cd ~/paperless-ngx

4,在 Paperless-ngx 目录中,用 sudo vim docker-compose.yml 命令创建 docker-compose.yml 文件并输入以下内容。

version: "3.4" services: broker: image: docker.io/library/redis:7 restart: unless-stopped volumes: - redisdata:/data db: image: docker.io/library/postgres:15 restart: unless-stopped volumes: - pgdata:/var/lib/postgresql/data environment: POSTGRES_DB: paperless POSTGRES_USER: paperless POSTGRES_PASSWORD: paperless webserver: image: paperlessngx/paperless-ngx:latest restart: unless-stopped depends_on: - db - broker ports: - 8000:8000 healthcheck: test: ["CMD", "curl", "-f", "http://你的服务器 IP:8000"] interval: 30s timeout: 10s retries: 5 volumes: - data:/usr/src/paperless/data - media:/usr/src/paperless/media - ./export:/usr/src/paperless/export - ./consume:/usr/src/paperless/consume environment: PAPERLESS_REDIS: redis://broker:6379 PAPERLESS_DBHOST: db PAPERLESS_DBNAME: paperless PAPERLESS_DBUSER: paperless PAPERLESS_DBPASS: paperless PAPERLESS_SECRET_KEY: ${PAPERLESS_SECRET_KEY} PAPERLESS_ALLOWED_HOSTS: "*" volumes: data: media: pgdata: redisdata:

5,在 docker-compose.yml 同目录下使用以下命令创建 .env 文件并生成密钥。

echo "PAPERLESS_SECRET_KEY=$(openssl rand -base64 45)" > .env

6,输入以下命令启动 Paperless-ngx 。

docker compose up -d

7,输入以下命令创建管理员账户。

docker compose exec webserver createsuperuser

8,打开浏览器访问 http://你的服务器 IP:8000 ,就能看到你部署的 Paperless-ngx 登录界面了,使用刚创建的管理员账户登录即可。

第二步,外网访问本地 Paperless-ngx

安装路由侠内网穿透。

1,当前未提供网页管理,需要先在任意一台 Windows 机器安装路由侠 Windows 版本,用作跨机器管理。点此下载

2,在路由侠客户端主界面,进入“ 设备管理 ”,点击右下角的“ 添加设备 ”,此时可查看到对应的安装码,此安装码用于将设备添加到对应账号下,可选中后复制。

3,直接下载后导入:

wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar docker load -i lyx-docker-x86_64.tar

4,然后使用该镜像启动容器。

docker run --name lyx -it --restart=always --net=host -e code=这里填写安装码luyouxia/lyx

5,此时,需要等待下载和安装的过程,如果一切正常,最终可以看到一些输出,并且可以看到如下提示:

[Device] Logged in. Token: ....

这就表示安装成功了。

当前 Linux 终端这边,如果是使用的上面的命令,Docker 是运行在前台,此时可以按住 Ctrl + C ,退出路由侠,容器也将退出。现在可以使用以下命令将其放入后台持续运行:

docker start lyx

注意如果容器删除,重新 docker run , 将创建为新的设备。

需要注意的是,因为容器参数已经添加了 --restart=always ,这样开机就会自动启动,不需要再手动启动路由侠了。

6,现在回到 Windows 这边设备列表,点击右上角的 × 返回主界面,再次进入,就可以找到这个设备,可以修改名称。

7,回到主界面,点击【内网映射】。

8,注意右上角的设备名称下拉框,这里选中刚刚添加的设备名称,此时在这个界面上添加的映射,就属于刚刚这个设备。添加或修改一般需要等待 30 秒,容器中的路由侠进程就会更新并加载。切换好设备后,点击【添加映射】。

9,选择【原生端口】。

10,在内网地址填写你的服务器 IP 和 Paperless-ngx 端口 8000 后点击【创建】按钮,如下图。

11,创建好后,就可以看到一条映射的公网地址,鼠标右键点击【复制地址】。

12,在外网电脑上,打开浏览器,在地址栏输入从路由侠生成的外网地址,就可以看到内网部署的 Paperless-ngx 登录界面了。

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

计算机网络应用层理论知识全面解析

1. 应用层概述与理论基础 1.1 应用层在网络体系结构中的地位 应用层是计算机网络体系结构中的最高层,在 OSI 七层模型和 TCP/IP 协议栈中都占据着直接面向用户和应用程序的关键位置。作为整个网络体系中 "交付实际价值" 的核心层,应用层是计…

作者头像 李华
网站建设 2026/5/2 12:40:12

别再背八股文了:资深架构师眼里的 RunLoop、GCD 与线程保活真相

1. 撕开 RunLoop 的伪装:它不仅仅是一个死循环很多兄弟在面试时把 RunLoop 背得滚瓜烂熟:“它是管理事件循环的对象,让线程有事做事,没事休眠...” 听起来没毛病,但你在写代码时真的看见过它吗?在 main.m 那…

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

西门子变频器G120C:工业自动化控制的智能解决方案

西门子变频器G120C:工业自动化控制的智能解决方案 【免费下载链接】西门子变频器G120C使用手册分享 西门子变频器G120C使用手册欢迎来到西门子变频器G120C的官方使用手册页面 项目地址: https://gitcode.com/Open-source-documentation-tutorial/7ef48 想要快…

作者头像 李华
网站建设 2026/5/8 21:36:14

C/C++知识积累-Lambda表达式

目录 定义 语法结构 常见捕获列表 常见使用场景 Lambda的本质 Lambda的发展和问题 定义 C中的Lambda表达式是C11引入的新特性,允许在代码中定义匿名函数。简单而言,他就是一个匿名函数对象,通常用于简单、不需要复用、或者需要访问当前…

作者头像 李华
网站建设 2026/5/6 5:51:21

Vue2如何设计大文件上传的交互界面与用户体验?

大文件上传系统优化版(JavaVue3SpringBoot) 优化说明 经过实际测试和客户反馈,我对之前的方案进行了以下优化: 加密方案优化:改用CryptoJS实现AES加密,兼容IE9断点续传增强:增加MD5校验&…

作者头像 李华
网站建设 2026/5/4 18:25:58

BoringNotch安装配置教程:将MacBook凹口变为动态音乐控制中心

BoringNotch安装配置教程:将MacBook凹口变为动态音乐控制中心 【免费下载链接】boring.notch TheBoringNotch: Not so boring notch That Rocks 🎸🎶 项目地址: https://gitcode.com/gh_mirrors/bor/boring.notch BoringNotch是一款创…

作者头像 李华