0

0

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

星夢妙者

星夢妙者

发布时间:2025-07-22 10:10:31

|

604人浏览过

|

来源于php中文网

原创

paperless-ngx是一个开源的文档管理系统,能够将纸质文档转化为可在线搜索的档案,从而减少纸张使用。它内置了ocr功能,可以自动对上传的扫描文档进行ocr处理,识别并转换文档中的文字为可编辑和可搜索的文本格式。系统还会对文档进行分类和索引,方便用户随时搜索和查看。

本文将介绍如何在本地部署Paperless-ngx并实现远程公网访问。由于本地部署后仅限于局域网访问,无法在异地访问,因此我们将结合cpolar内网穿透工具来实现远程访问。

cpolar是一款功能强大的内网穿透软件,支持在Windows、MacOS和Linux等多种操作系统上运行。它可以将本地内网服务器的HTTP、HTTPS、TCP协议端口映射到公网地址端口,允许公网用户轻松访问内网服务,无需将服务部署到公网服务器上。

本文采用Docker进行部署,设备需要提前安装好Docker和Docker Compose。如果没有安装,可以参考Docker官方教程进行安装:Docker官方安装教程。

Paperless-ngx的部署需要使用多个外部服务,如数据库等。通过Docker Compose,可以一次性部署所有所需服务,简化了安装过程。下面开始进行安装。

  1. 部署Paperless-ngx

在Linux中创建一个文件夹,并进入该文件夹:

mkdir -p /usr/local/ngx && cd /usr/local/ngx

在该文件夹下创建docker-compose.yml文件:

sudo vim /usr/local/ngx/docker-compose.yml

将以下参数复制到docker-compose.yml文件中:

version: "3.6"
services:
  broker:
    image: docker.io/library/redis:7
    restart: unless-stopped
    volumes:
      - redisdata:/data
  db:
    image: docker.io/library/mariadb:10
    restart: unless-stopped
    volumes:
      - dbdata:/var/lib/mysql
    environment:
      MARIADB_HOST: paperless
      MARIADB_DATABASE: paperless
      MARIADB_USER: paperless
      MARIADB_PASSWORD: paperless
      MARIADB_ROOT_PASSWORD: paperless
  webserver:
    image: ghcr.io/paperless-ngx/paperless-ngx:latest
    restart: unless-stopped
    depends_on:
      - db
      - broker
    ports:
      - "8000:8000"
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost: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_DBENGINE: mariadb
      PAPERLESS_DBHOST: db
      PAPERLESS_DBUSER: paperless
      PAPERLESS_DBPASS: paperless
      PAPERLESS_DBPORT: 3306
volumes:
  data:
  media:
  dbdata:
  redisdata:

保存后,运行以下命令启动服务:

docker compose up -d

启动后,输入docker ps命令,可以看到运行的Paperless-ngx服务,对外访问端口为8000。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

然后,设置登录的用户名和密码,运行以下命令:

docker compose run --rm webserver createsuperuser

按照提示设置用户名、邮箱和密码。本例中设置的用户名为jon,可以根据需要自行设置。设置完成后,按提示输入邮箱和密码,设置成功后会提示successful。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

  1. 本地访问Paperless-ngx

服务运行并设置好登录用户名和密码后,使用Linux局域网IP加端口8000,即可看到Paperless-ngx的登录界面。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

输入设置的用户名和密码即可登录成功。本地访问成功后,接下来安装cpolar内网穿透工具,实现远程访问。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

  1. Linux安装Cpolar

在本地Docker中成功部署了Paperless-ngx服务,并在局域网访问成功后,接下来在Linux上安装Cpolar内网穿透工具。通过Cpolar将本地端口映射到HTTP公网地址,可以轻松实现远程访问,无需注册域名和购买云服务器。以下是安装Cpolar的步骤:

使用一键脚本安装命令:

curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash

安装完成后,可以通过以下方式操作cpolar服务。首先执行加入系统服务设置开机启动,然后启动服务:

# 加入系统服务设置开机启动
sudo systemctl enable cpolar
# 启动cpolar服务
sudo systemctl start cpolar
# 重启cpolar服务
sudo systemctl restart cpolar
# 查看cpolar服务状态
sudo systemctl status cpolar
# 停止cpolar服务
sudo systemctl stop cpolar

Cpolar安装并成功启动服务后,通过局域网IP加9200端口(例如:【https://www.php.cn/link/eda9c67d6a20358927319cf3510402df web配置界面,接下来在web界面进行配置。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

  1. 配置公网地址

点击左侧仪表盘的隧道管理——创建隧道,创建一个Paperless-ngx的公网HTTP地址隧道:

ToonMe
ToonMe

一款风靡Instagram的软件,一键生成卡通头像

下载
  • 隧道名称:可自定义命名,注意不要与已有的隧道名称重复
  • 协议:选择HTTP
  • 本地地址:8000(本地访问的地址)
  • 域名类型:免费选择随机域名
  • 地区:选择China
  • 点击创建

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

隧道创建成功后,点击左侧的状态——在线隧道列表,查看所生成的公网访问地址。有两种访问方式,一种是HTTP和HTTPS,接下来进行远程访问。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

  1. 远程访问

使用上面Cpolar生成的HTTP公网地址,在任意设备的浏览器进行访问,即可成功看到Paperless-ngx的界面,无需云服务器和公网IP即可实现远程访问。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

小结

在前述过程中,我们使用了cpolar生成的隧道,其公网地址是随机生成的。这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址由随机字符生成,不太容易记忆(例如:3ad5da5.r10.cpolar.top)。另外,这个地址在24小时内会发生随机变化,更适合于临时使用。

我一般会使用固定二级子域名,原因是我希望将网址发送给同事或客户时,它是一个固定、易记的公网地址(例如:paperless-ngx.cpolar.cn),这样更显正式,便于团队协作。

  1. 固定Cpolar公网地址

由于以上使用cpolar所创建的隧道使用的是随机公网地址,24小时内会随机变化,不利于长期远程访问。因此我们可以为其配置二级子域名,该地址为固定地址,不会随机变化(ps:cpolar.cn已备案)。

登录cpolar官网,点击左侧的预留,选择保留二级子域名,设置一个二级子域名名称,点击保留。保留成功后复制保留的二级子域名名称。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

保留成功后复制保留成功的二级子域名的名称。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

返回登录cpolar web UI管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到所要配置的隧道,点击右侧的编辑。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

修改隧道信息,将保留成功的二级子域名配置到隧道中:

  • 域名类型:选择二级子域名
  • Sub Domain:填写保留成功的二级子域名
  • 点击更新(注意,点击一次更新即可,不需要重复提交)

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

更新完成后,打开在线隧道列表,此时可以看到公网地址已经发生变化,地址二级名称变成了我们自己设置的二级子域名名称。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

  1. 固定地址访问

最后,使用固定的公网HTTP地址访问,可以看到同样访问成功。这样一个固定且永久不变的公网地址就设置好了,随时随地都可以远程访问本地Paperless-ngx服务,无需公网IP和云服务器。

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

相关专题

更多
windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

601

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1104

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

792

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

452

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2349

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

800

2023.08.10

windows boot manager
windows boot manager

windows boot manager无法开机的解决方法:1、系统文件损坏,使用Windows安装光盘或USB启动盘进入恢复环境,选择修复计算机,然后选择自动修复;2、引导顺序错误,进入恢复环境,选择命令提示符,输入命令"bootrec /fixboot"和"bootrec /fixmbr",然后重新启动计算机;3、硬件问题,使用硬盘检测工具进行扫描和修复;4、重装操作系统。本专题还提供其他解决

1509

2023.08.28

windows锁屏快捷键
windows锁屏快捷键

windows锁屏快捷键是Windows键+L、Ctrl+Alt+Del、Windows键+D、Windows键+P和Windows键+R。本专题为大家提供windows相关的文章、下载、课程内容,供大家免费下载体验。

1633

2023.08.30

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

3

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号