使用 B2 存储
B2 是兼容亚马逊 S3 的对象存储技术,Backblaze 是最流行的 B2 云存储提供商之一。本章我们将讨论:注册 Backblaze 的免费 B2 云存储服务、开启 Cloudflare 免流、开启 B2 存储桶的 API 访问,以及客户端的使用,包括: Backblaze B2 官方命令行、Cyberduck GUI 工具等。【为避免服务被滥用,本章将永久关闭试读功能】- 支持试读
使用B2自动备份数据库
本章将讨论使用 B2 存储来自动备份数据库。 - 支持试读
Rust 集成 B2
本章将讨论如何将 B2 集成到 Rust中。 使用 AXUM 和 B2 对象存储实现图库
本章我们将讨论使用 AXUM 和 B2 打造一个简单的图库应用。
使用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 | 日 |
%H | 24小时制的小时 |
%M | 分钟 |
%S | 秒钟 |
%F | YYYY-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