mongodb 按条件进行备份和恢复

在宝塔面板环境下,可以在定时任务设置备份mongodb
但是存在缺陷,mongodb如果存储日志,一定时间后会特别巨大,全量备份会导致服务器卡死并很快耗尽磁盘空间,按一定的条件对进行,按天备份数据是必须的。我们用过自己编写shell脚本来实现。

sudo -u root #!/bin/bash
now=$(date +%Y-%m-%d)
#yesterday=2024-05-15
yesterday=$(date -d "yesterday" +"%Y-%m-%d")
whereday="{\"day\":\"$yesterday\"}"
dir=/www/backup/database/mongodb/table_day_backup/$yesterday
if [ ! -d "$dir" ]; then
    mkdir -p $dir
fi
cd $dir

echo "当前日期是: $whereday -> "
source  /www/backup/database/mongodb/.env

mongodump --host $MONGO_DB_HOST --port $MONGO_DB_PORT \
          --username $MONGO_DB_USERNAME --password $MONGO_DB_PASSWORD \
          --db ad_db --collection  production_websocket_client_logs \
          --query  $whereday \
          --out  $dir 
zip -r $yesterday'.zip'  ./* 

首先在.env文件里面指定mongdb的链接信息

--db ad_db 指定备份的数据库

--collection websocket_client 指定备份发集合

--query $whereday 这里指定筛选数据的条件是 按天

--out $dir 指定备份文件输出的目录

这样我们就实现了对库下的一个集合,按天进行备份。

如果某一天数据丢失需要进行还原

sudo -u root #!/bin/bash

source  /www/backup/database/mongodb/.env
day=2024-05-15
dir=/www/backup/database/mongodb/table_day_backup/$day/audi/production_websocket_client_logs.bson
echo $dir

mongorestore  --host $MONGO_DB_HOST --port $MONGO_DB_PORT \
              --username $MONGO_DB_USERNAME --password $MONGO_DB_PASSWORD \
              --db ad_db --collection  back_websocket_client $dir 
相关推荐
王ASC9 分钟前
ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值。ojdbc8版本23.2.0.0驱动BUG【已解决】
数据库·sql·oracle
Dlwyz19 分钟前
问题: redis-高并发场景下如何保证缓存数据与数据库的最终一致性
数据库·redis·缓存
如意机反光镜裸1 小时前
如何快速将Excel数据导入到SQL Server数据库
数据库
不爱学习的啊Biao1 小时前
初识mysql数据库
数据库·mysql·oracle
宛唐羁客2 小时前
ODBC连接PostgreSQL数据库后,网卡DOWN后,客户端进程阻塞问题解决方法
网络·数据库
吴半杯3 小时前
Redis-monitor安装与配置
数据库·redis·缓存
是桃萌萌鸭~4 小时前
mysqldbcompare 使用及参数详解
数据库·mysql
gma9994 小时前
brpc 与 Etcd 二次封装
数据库·c++·rpc·etcd
Yz98764 小时前
hive复杂数据类型Array & Map & Struct & 炸裂函数explode
大数据·数据库·数据仓库·hive·hadoop·数据库开发·big data
小鹿撞出了脑震荡4 小时前
SQLite3语句以及用实现FMDB数据存储的学习
数据库·学习·sqlite