挖到宝。Docker部署轻量又好看的 Markdown 博客系统:PaperGrid

之前分享过如何用 Halo 2.0 搭建自己的博客站,不过对一部分用户来说,这类项目功能虽然完整,但也显得偏重了一些。相比之下,有些人更喜欢轻量、简洁,甚至只想要一个能稳定托管内容的小站。

最近我发现了一个新的博客项目 PaperGrid,整体风格比较轻量,支持 Markdown 编辑,前端表现也不错,同时还有一定的可玩性。这篇文章就简单聊聊,如何把它部署起来并用起来。

对我个人来说,博客其实已经替代笔记。把想法、折腾过程和使用体验记录下来,不只是方便自己以后回看,也能分享给有同样需求的人。像 PaperGrid 这样部署不算复杂、界面也比较清爽的项目,用来搭一个属于自己的记录空间,确实挺合适。

项目说明

完整项目名:xywml/PaperGrid,可于GitHub搜索。

作者的话:

项目正在快速开发中,欢迎部署使用,Star,反馈。

目前主要特性

  • Next.js App Router + React 19

  • Prisma ORM

  • NextAuth 认证

  • 管理后台(文章、标签、分类、评论、用户、系统设置、文件管理)

  • 文件管理(本地图片上传、预览、删除、URL 回填)

  • MDX 内容支持、代码高亮、数学公式与图表

  • 国际化与深色模式

  • 内置多套前台主题,可在 管理后台 -> 样式 一键切换(纸格笔记 / 终端机能 / 清透视窗 / 像素账本)

  • 可添加智能AI助手

部署流程

以威联通NAS为例,通过Docker Compose的方式进行部署。

部署代码如下,可实现快速启用:

services:

   papergrid:

      image: ghcr.io/xywml/papergrid:latest

      container_name: papergrid

      ports:

         - "6066:3000"

      environment:

         DATABASE_URL: "file:/data/db.sqlite"

         # 可选:AI 向量索引单独文件

         # AI_VECTOR_DATABASE_URL: "file:/data/ai-index.sqlite"

         # SQLITE_JOURNAL_MODE: "DELETE"

         # 先用 NAS IP + 端口,后面如果加反代/域名,再改成正式地址

         NEXTAUTH_URL: "http://192.168.100.138:6066"

         NEXT_PUBLIC_APP_URL: "http://192.168.100.138:6066"

         # 生产环境建议设置

         NEXTAUTH_SECRET: "请替换成一串足够长的随机字符串"

         # 本地媒体与缓存

         MEDIA_ROOT: "/data/uploads"

         NEXT_CACHE_DIR: "/data/.next-cache"

         # 首次初始化可选

         # INIT_ADMIN_TOKEN: "请替换为随机字符串"

         # ADMIN_INIT_PASSWORD: "请替换为强密码"

         # 先不开 OAuth / SMTP,跑通后再补

         NEXT_PUBLIC_DEFAULT_LOCALE: "zh"

         # 内网不反代的话,Host 校验放行

         AUTH_TRUST_HOST: "true"

      volumes:

         - /share/Container/boke/data:/data

      restart: unless-stopped

      logging:

         driver: "json-file"

         options:

            max-size: "10m"

            max-file: "5"

完整的环境变量如下,大家也可自行创建.env文件:

DATABASE_URL="file:./dev.db"

# 可选:为 AI 向量索引单独使用 SQLite 文件(推荐生产启用)

# AI_VECTOR_DATABASE_URL="file:/data/ai-index.sqlite"

# 可选:AI 向量索引使用的 SQLite 日志模式;默认 DELETE(稳定优先)

# SQLITE_JOURNAL_MODE="DELETE"

NEXTAUTH_URL="http://localhost:6066"

NEXTAUTH_SECRET="your-secret-key-change-this-in-production"

# Local media storage

MEDIA_ROOT="/data/uploads"

MEDIA_MAX_UPLOAD_MB="10"

MEDIA_MAX_INPUT_PIXELS="40000000"

MEDIA_RESOLVE_CACHE_TTL_MS="30000" # 媒体元数据缓存(ms)

INIT_ADMIN_TOKEN=""

ADMIN_INIT_PASSWORD=""

GITHUB_CLIENT_ID=""

GITHUB_CLIENT_SECRET=""

GOOGLE_CLIENT_ID=""

GOOGLE_CLIENT_SECRET=""

CLOUDINARY_CLOUD_NAME=""

CLOUDINARY_API_KEY=""

CLOUDINARY_API_SECRET=""

SMTP_HOST=""

SMTP_PORT="465"

SMTP_SECURE="true"

SMTP_USER=""

SMTP_PASS=""

# 可选:多个收件人用逗号分隔;留空则自动发给所有管理员邮箱

EMAIL_TO=""

# 可选:回复通知邮件拒收名单(逗号/换行分隔)

EMAIL_REPLY_DENYLIST=""

# 可选:退订链接签名密钥(不填则回退到 NEXTAUTH_SECRET) EMAIL_UNSUBSCRIBE_SECRET=""

# 可选:退订链接有效期(天)

EMAIL_REPLY_UNSUBSCRIBE_EXPIRE_DAYS="365"

GOTIFY_URL=""

GOTIFY_TOKEN=""

NEXT_PUBLIC_APP_URL="http://localhost:6066"

NEXT_PUBLIC_DEFAULT_LOCALE="zh"

# 可选:日志级别(fatal/error/warn/info/debug/trace/silent)

# LOG_LEVEL="info"

# 自定义 Head 注入 – CSP 放行域名

# 在管理后台「样式 → 自定义 Head 注入」添加外部脚本后,需将脚本域名加到此处,否则浏览器会因 CSP 拦截

# HEAD_INJECT_SCRIPT_ORIGINS="https://stats.example.com,https://www.googletagmanager.com"

# 可选:关闭 script-src 'unsafe-inline'(默认保留以兼容旧部署,确认无内联脚本后可设为 false)

# CSP_ALLOW_UNSAFE_INLINE_SCRIPT="false"

打开Container Station,创建新的应用程序。

使用展示

部署完毕后,浏览器输入NAS_IP:6066即可访问服务,界面如下。

点击右上角的登录,可进入登录界面。默认管理员账号邮箱:admin@example.com,默认密码

密码:admin123。初次登录,建议立即修改。

新建文章,这个文章编辑器,比我现在Halo上的好用~

各种配置,在后台也都支持,可DIY的程度也蛮高。

最后

总的来说,PaperGrid 比较适合喜欢轻量化、自建自由度又比较高的用户。它不像一些传统博客系统那么「重」,但基础功能和可玩性并不弱,尤其是对喜欢 Markdown 写作、希望自己折腾页面风格和功能的人来说,还是很有吸引力的。对于想在 NAS 上快速搭一个个人博客、知识库或者简单内容站点的朋友来说,确实是一个值得尝试的新选择。

感谢观看,本文完。

更多游戏资讯请关注:电玩帮游戏资讯专区

电玩帮图文攻略 www.vgover.com