找回密码
立即注册
搜索
热搜: Java Python Linux Go
发回帖 发新帖

4866

积分

0

好友

666

主题
发表于 4 小时前 | 查看: 3| 回复: 0

什么是 DBackup ?

DBackup 是一个开源的数据库备份自动化工具,支持 MySQL 、PostgreSQL、MongoDB、SQLite、Redis 和 Microsoft SQL Server 等多种数据库。它能帮助你轻松实现数据库的定时备份、加密存储和便捷恢复。

主要特点

  • 多数据库支持:支持 MySQL、MariaDB、PostgreSQL、MongoDB、SQLite、Redis、MSSQL 等 7 种数据库
  • 多种存储后端:支持 S3、Cloudflare R2、Google Drive、Dropbox、OneDrive、SFTP、FTP、WebDAV、SMB、Rsync 等 13+ 种存储适配器
  • AES-256-GCM 加密:使用开放标准的 AES-256-GCM 加密算法保护备份数据,支持密钥轮换和离线恢复
  • 智能保留策略:支持 GVS(Grandfather-Father-Son)轮换策略,可按目的地设置保留规则
  • Cron 定时调度:支持简单模式和 Cron 模式两种调度方式
  • 9 种通知渠道:支持 Discord、Slack、Teams、Telegram、Gotify、ntfy、Webhook、Twilio SMS、Email 等通知
  • SSO/OIDC 认证:支持 Authentik、PocketID、Keycloak 等身份提供商
  • RBAC 访问控制:支持用户组和细粒度的权限管理
  • 开源免费:基于 GPL-3.0 协议开源,可免费使用和修改

应用场景

  • 个人开发者:为本地数据库提供自动化备份解决方案
  • 中小企业:集中管理多个数据库的备份任务,确保数据安全
  • 运维团队:通过 Web 界面统一监控和恢复数据库

DBackup 是一个功能完善的数据库备份管理平台,特别适合需要在私有环境中管理数据库备份的用户。

安装

在群晖 NAS 上以 Docker 方式部署。在注册表中搜索 skyfay,选择第一个 skyfay/dbackup,版本选择 latest

本文写作时,latest 版本对应为 v1.4.6

在 Docker 注册表中搜索 skyfay/dbackup 并选择 latest 版本

docker 文件夹中,创建一个新文件夹 dbackup,并在其中建两个子文件夹 databackups。需要给 backups 目录新增 Everyone 的读写权限。

设置 backups 目录的 Everyone 读写权限

文件夹 装载路径 说明
docker/dbackup/data /data 存放所有持久化数据(数据库、存储、证书)
docker/dbackup/backups /backups 用于本地备份文件(可选)

Docker 存储空间映射:backups 和 data 目录

端口

本地端口不冲突就行,不确定的话可以用命令查一下:

# 查看端口占用
netstat -tunlp | grep 端口号
本地端口 容器端口
4004 3000

配置端口映射:本机 4004 → 容器 3000

环境

可变
ENCRYPTION_KEY 使用 openssl rand -hex 32 生成
BETTER_AUTH_URL http://192.168.0.197:4004,其中 192.168.0.197 是你群晖主机的 IP
BETTER_AUTH_SECRET 使用 openssl rand -base64 32 生成
DISABLE_HTTPS true,因为我们只在局域网中通过 IP 访问

环境变量说明

  • ENCRYPTION_KEY 用于加密备份文件,必须是 32 字节的十六进制字符串,使用 openssl rand -hex 32 生成
  • BETTER_AUTH_URL 设置应用访问地址,首次配置后保持不变,其中 192.168.0.197 为群晖主机的 IP
  • BETTER_AUTH_SECRET 用于会话加密,使用 openssl rand -base64 32 生成
  • DISABLE_HTTPS 设置为 true 禁用 HTTPS,使用 HTTP 访问,因为我们只在局域网中使用

环境变量设置界面,前三项高亮

下拉找到 DISABLE_HTTPS,默认值为 false,需要改为 true

将 DISABLE_HTTPS 改为 true

更多环境变量的说明,请参考官方文档:https://dbackup.app/user-guide/installation#environment-variables

命令行安装

docker cli 安装

如果你熟悉命令行,用 docker cli 更快捷:

# 新建文件夹 dbackup 和 子目录
mkdir -p /volume1/docker/dbackup/{data,backups}

# 进入 dbackup 目录
cd /volume1/docker/dbackup

# 修改目录权限
chmod a+rw backups

# 运行容器
docker run -d \
   --name=dbackup \
   --restart=always \
   -p 4004:3000 \
   -v $(pwd)/data:/data \
   -v $(pwd)/backups:/backups \
   -e ENCRYPTION_KEY="f762ba8c44596a4473ea57d1136cef9f6140a90638a8118ad23bd1f5b029a8ce" \
   -e BETTER_AUTH_SECRET="vWy7fLro59hBT/kORnhWZJUe6Z5fK1Mlm6Mg4EXQ5Ck=" \
   -e BETTER_AUTH_URL="http://192.168.0.197:4004" \
   -e DISABLE_HTTPS="true" \
   skyfay/dbackup:latest

docker-compose 安装

也可以用 docker-compose,将下面的内容保存为 docker-compose.yml 文件:

version: '3.8'

services:
  dbackup:
    image: skyfay/dbackup:latest
    container_name: dbackup
    restart: always
    ports:
      - "4004:3000"
    volumes:
      - ./data:/data   # All persistent data (db, storage, certs)
      - ./backups:/backups   # Optional: used for local backups
    environment:
      - ENCRYPTION_KEY=f762ba8c44596a4473ea57d1136cef9f6140a90638a8118ad23bd1f5b029a8ce   # openssl rand -hex 32
      - BETTER_AUTH_URL=http://192.168.0.197:4004
      - DISABLE_HTTPS=true
      - BETTER_AUTH_SECRET=vWy7fLro59hBT/kORnhWZJUe6Z5fK1Mlm6Mg4EXQ5Ck=   # openssl rand -base64 32
      # All additional environment variables: https://dbackup.app/user-guide/installation#environment-variables

然后通过 SSH 登录到你的群晖,执行下面的命令:

# 新建文件夹 dbackup 和 子目录
mkdir -p /volume1/docker/dbackup/{data,backups}

# 进入 dbackup 目录
cd /volume1/docker/dbackup

# 修改目录权限
chmod a+rw backups

# 将 docker-compose.yml 放入当前目录

# 一键启动
docker-compose up -d

File Station 中 dbackup 目录的结构

运行

在浏览器中输入 http://群晖IP:4004 就能看到登录界面。

DBackup 登录页面

第一次需要注册用户,密码不能少于 8 个字符。

DBackup 注册页面,填入姓名、邮箱和密码

登录后的主界面一览。

DBackup 仪表盘总览

进入 Quick Setup 进行快速设置。

Quick Setup 向导欢迎页

Database Source

第一步,选择数据库的类型。支持的数据库非常多。

选择数据库类型:MySQL、MariaDB、PostgreSQL、MongoDB 等

这里以群晖自带的 MariaDB 为例,填写连接信息并测试。

配置 MariaDB 数据源,输入主机、端口、用户、密码

如果测试通过,即可保存。

数据源创建成功提示

Storage Destination

第二步,选择存储的类型。除了本地文件系统,还支持大量云存储和网络协议。

选择存储目标:本地文件系统、S3、Google Drive、SFTP 等

Local Filesystem 为例,Base Path 设为容器内的备份路径 /backups

配置本地文件系统目标,Base Path 为 /backups

测试不报错就可以保存了。

存储目标创建成功

其他设置

Encryption 是可选的,如果你暂时不需要加密,可以直接 Skip

加密设置页面,可选择跳过

Notifications 也不是必须的,可以根据你的需要勾选。

通知渠道选择:Discord、Telegram、Email 等

最后是设置备份计划,支持预设和 Cron 表达式。

创建备份任务:设置数据源、目标、调度

一切就绪,任务会自动执行。你还可以随时创建其他备份任务。

设置完成界面,可以运行首次备份或管理任务

根据需求持续添加新的备份计划。

Jobs 管理界面,查看所有备份任务

注意事项

  1. 加密密钥重要:请妥善保存 ENCRYPTION_KEY,丢失它意味着失去对所有加密数据(数据库密码、DBackup 中存储的 API 密钥)的访问权限。
  2. 端口冲突:如果 4004 端口被占用,需要修改主机端口。
  3. 备份保留策略:建议根据存储空间设置合适的保留策略,避免备份过多占用空间。

参考文档

DBackup - Self-hosted database backup automation
地址:https://github.com/Skyfay/DBackup  

skyfay/dbackup - Docker Hub
地址:https://hub.docker.com/r/skyfay/dbackup  

DBackup 官方文档
地址:https://dbackup.app




上一篇:AI时代,C++程序员还有未来吗?2026年自救指南
下一篇:DeepSeek首轮融资200亿美元:阿里腾讯抢投,梁文锋回应“不是养不起,是不够健康”
您需要登录后才可以回帖 登录 | 立即注册

手机版|小黑屋|网站地图|云栈社区 ( 苏ICP备2022046150号-2 )

GMT+8, 2026-4-25 10:37 , Processed in 1.229598 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2025-2026 云栈社区.

快速回复 返回顶部 返回列表