域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

使用B2自动备份数据库

本章将讨论使用 B2 存储来自动备份数据库。

简介

假设有一个 PostgreSQL docker实例,它的的相关信息如下:

  • 容器名:img_axum_rs_postgresql
  • 用户名:img_axum_rs
  • 数据库名:img_axum_rs

可以使用以下 docker 命令运行此实例:

 docker run \
        --name img_axum_rs_postgresql \
        -e POSTGRES_PASSWORD=img_axum_rs \
        -e POSTGRES_USER=img_axum_rs \
        -e POSTGRES_DB=img_axum_rs \
        -e TZ=PRC \
        --restart=always \
        -p 5432:5432 \
        -d postgres:alpine

可以使用以下 docker 命令运行此实例:

那么,可以这样进行备份:

# 第一步,备份数据库
docker exec img_axum_rs_postgresql bash -c 'pg_dump -U img_axum_rs -F t img_axum_rs > /img_axum_rs.tar'

# 第二步,将数据库备份文件从容器中拷贝到宿主机
docker cp img_axum_rs_postgresql:/img_axum_rs.tar /root/img_axum_rs.tar
 b2 upload-file axum*****123 /root/img_axum_rs.tar img_axum_rs.tar

整合脚本

在整合脚本之前,我们需要了解一个知识点,在 bash 中,如何获取日期时间。因为我们希望我们的数据库备份文件总是按日期命名的。

首先,bash 中获取日期时间的命令是 date ,语法如下:

它有格式化选项有:

格式化选项说明
%Y
%m
%d
%H24小时制的小时
%M分钟
%S秒钟
%FYYYY-mm-dd 格式的日期

举例:

echo $(date +%F)
# 2023-08-06

echo $(date +%Y-%m-%d)
# 同上

echo $(date +'%F %H:%M:%S')
# 2023-08-06 20:10:02

下面正式整合脚本:

#!/bin/bash

BASENAME="img_axum_rs"
FILENAME="${BASENAME}_$(date +%Y%m%d%H%M%s).tar"
BACKUP_DIR="/root"
BACKUP_PATH="${BACKUP_DIR}/${FILENAME}"

# 备份数据库
docker exec img_axum_rs_postgresql bash -c 'pg_dump -U img_axum_rs -F t img_axum_rs > /img_axum_rs.tar'
# 将数据库备份文件从容器中拷贝到宿主机
docker cp img_axum_rs_postgresql:/img_axum_rs.tar $BACKUP_PATH
# 上传到B2
b2 upload-file axum*****123 $BACKUP_PATH $FILENAME

加上计划任务,简直是完美!Linux 自带的 crontab 工具可以执行计划任务。比如,我们想在每天零时执行一次上述脚本:

crontab -e 

加入以下内容:

0 0 * * * /root/backup-db >/dev/null 2>&1
要查看完整内容,请先登录