当前位置: 首页 > article >正文

Linux 下自动化之路:达梦数据库定期备份并推送至 GitLab 全攻略

目录

环境准备

生成SSH 密钥对

数据库备份并推送到gitlab脚本

设置定时任务


环境准备

服务器要有安装达梦数据库(达梦安装这里就不示例了),git

安装Git

1、首先,确保包列表是最新的,运行以下命令:

sudo yum update

2、安装Git包,运行以下命令:

sudo yum install git

3、安装完成后,你可以通过运行以下命令来检查Git版本,确认安装成功:

git --version

生成SSH 密钥对

详情请看

Linux服务器生成SSH 密钥对与 GitLab 仓库进行交互

这种方式以更安全地进行代码的版本控制和管理操作,可以防止密码泄露风险

数据库备份并推送到gitlab脚本

#!/bin/bash

# DM8数据库连接信息
DB_USER="SYSDBA"
DB_PASSWORD="SYSDBA"
DB_HOST="127.0.0.1"
DB_PORT="5236"
# 导出多个模式使用号隔开
DB_SCHEMAS="user"

# dexp 工具路径
DMDBMS_PATH="/home/dmdba/dmdbms/bin"

# 备份文件保存路径和文件名
BACKUP_DIR="/data/dm8_back"
BACKUP_FILE="${BACKUP_DIR}/dm8_backup_$(date +%Y%m%d%H%M%S).dmp"
BACKUP_LOG_FILE="${BACKUP_DIR}/dm8_backup_$(date +%Y%m%d%H%M%S).log"

# GitLab仓库相关信息
GITLAB_REPO_URL="git@127.0.0.1:implcenter/project/test/database.git"
GITLAB_BRANCH="master"

# 执行数据库备份
echo "开始备份DM8数据库..."

# 设置库文件的搜索路径
export LD_LIBRARY_PATH=$DMDBMS_PATH:$LD_LIBRARY_PATH

# 使用 dexp 命令进行逻辑备份,使用变量 $DEXP_PATH
$DMDBMS_PATH/dexp $DB_USER/$DB_PASSWORD@$DB_HOST:$DB_PORT SCHEMAS=$DB_SCHEMAS FILE=$BACKUP_FILE LOG=$BACKUP_LOG_FILE DIRECTORY=Y FULL=Y


# 检查备份命令是否成功
if [ $? -eq 0 ]; then
    echo "数据库备份成功,备份文件:${BACKUP_FILE}"
else
    echo "数据库备份失败,请检查错误信息。"
    exit 1
fi

# 进入备份文件所在目录
cd "${BACKUP_DIR}" || exit 1

git init || echo "git初始化失败"

# 配置 Git 用户信息(如果还未配置)
git config --global user.name "xx"
git config --global user.email "122312@163.com"

# 检查本地是否存在分支,如果不存在则创建并关联远程分支
if [! -z "$(git branch -a | grep remotes/origin/${GITLAB_BRANCH})" ] && [! -z "$(git branch | grep ${GITLAB_BRANCH})" ]; then
    echo "本地已存在与远程对应的分支,继续推送。"
else
    echo "本地不存在与远程对应的分支,创建并关联。"
    git checkout -b "${GITLAB_BRANCH}" "origin/${GITLAB_BRANCH}"
fi

# 添加备份文件到 Git 仓库
echo "将备份文件添加到GitLab仓库..."
git remote add origin "$GITLAB_REPO_URL"
git pull remote "$GITLAB_BRANCH"
git add "${BACKUP_FILE}"

# 提交备份文件到 Git 仓库
git commit -m "备份文件上传:$(date +%Y%m%d%H%M%S)"

# 推送备份文件到 GitLab 仓库
echo "推送备份文件到GitLab仓库..."
git push origin $GITLAB_BRANCH --force

# 检查推送命令是否成功
if [ $? -eq 0 ]; then
    echo "备份文件成功上传到GitLab仓库。"
else
    echo "备份文件上传到GitLab仓库失败,请检查错误信息。"
    exit 1
fi

修改变量信息,将脚本保存到服务器 /data/dm8_back/backDatabase.sh

设置定时任务

1、编辑crontab文件

crontab -e

2、添加crontab任务

文件中添加一行(每个月的 1 号,0 点 0 分执行一次)

0 0 1 * * /bin/bash /data/dm8-back/backDatabase.sh

3、查看crontab任务列表

crontab -l

完成!!


http://www.kler.cn/a/413239.html

相关文章:

  • mac下Gpt Chrome升级成GptBrowser书签和保存的密码恢复
  • 斐波那契堆与二叉堆在Prim算法中的性能比较:稀疏图与稠密图的分析
  • v-for产生 You may have an infinite update loop in a component render function
  • 788页页大型集团财务集中管控平台项目总体规划方案全文深入解读
  • 【设计模式】【行为型模式(Behavioral Patterns)】之责任链模式(Chain of Responsibility Pattern)
  • 深入浅出摸透AIGC文生图产品SD(Stable Diffusion)
  • 开箱即用!合合信息的智能文档处理“百宝箱”
  • 华三堆叠配置实验
  • Java对象集合使用Java 8的Stream API合并数据
  • 华为云国内版与国际版的差异
  • ML 系列:第 31 节— 机器学习中的协方差和相关性
  • 01-go入门
  • 游戏引擎学习第21天
  • 设计模式:12、中介者模式
  • 跨域问题?同源策略大全
  • 代码随想录算法训练营第十一天(LeetCode150.逆波兰表达式求值;LeetCode239.滑动窗口最大值;LeetCode347.前K个高频元素)
  • 欢迪迈手机商城:基于SpringBoot的多平台支持
  • Qt之详解QLockFile 文件锁
  • React的ts文件中通过createElement拼接一段内容出来
  • 以太事件解析 #7 事件侦听_02
  • 第四十篇 DDP模型并行
  • Android基本概念及控件
  • 23种设计模式-享元(Flyweight)设计模式
  • 基于SSM的婴幼儿用品商城系统+LW示例参考
  • C#里怎么样快速使用LINQ实现查询?
  • k8s集群增加nfs-subdir-external-provisioner存储类