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 ]; thenecho "数据库备份成功,备份文件:${BACKUP_FILE}"
elseecho "数据库备份失败,请检查错误信息。"exit 1
fi# 进入备份文件所在目录
cd "${BACKUP_DIR}" || exit 1git 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})" ]; thenecho "本地已存在与远程对应的分支,继续推送。"
elseecho "本地不存在与远程对应的分支,创建并关联。"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 ]; thenecho "备份文件成功上传到GitLab仓库。"
elseecho "备份文件上传到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.mzph.cn/news/887562.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

极狐GitLab 17.6 正式发布几十项与 DevSecOps 相关的功能【一】

GitLab 是一个全球知名的一体化 DevOps 平台,很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版,专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料: 极狐GitLab 官网极狐…

<项目代码>YOLOv8 停车场空位识别<目标检测>

YOLOv8是一种单阶段(one-stage)检测算法,它将目标检测问题转化为一个回归问题,能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法(如Faster R-CNN),YOLOv8具有更高的…

【智能制造-46】人机工程(工厂自动化)

工作空间设计 设备布局规划 根据人体测量学数据,合理安排自动化设备、生产线和工作区域的布局。例如,考虑工人的操作空间和活动范围,确保他们能够舒适地接近和操作设备。在汽车装配车间,机器人和工人的工作区域应划分明确&#…

Spring Boot 集成 Knife4j 的 Swagger 文档

在开发微服务应用时,API 文档的生成和维护是非常重要的一环。Swagger 是一个非常流行的 API 文档工具,可以帮助我们自动生成 RESTful API 的文档,并提供了一个友好的界面供开发者测试 API。本文将介绍如何在 Spring Boot 项目中集成 Knife4j …

一线大厂面试集锦

String 为什么要设计成不可变的 String被设计成不可变的有以下几个原因: 线程安全:由于String是不可变的,多个线程可以同时访问同一个String对象而无需担心数据被修改。这使得String在多线程环境下是线程安全1. 的。 2.缓存Hash值:由于String是不可变的,它的hashcode可以…

JavaScript:遍历一个对象数组,获取每个对象中 mainKeyId 对应的值,并以这个值作为新属性的键名,给该对象添加一个新属性。

假设我们有一个对象数组,每个对象包含一个 mainKeyId 字段,以 mainKeyId 的值作为新的键名,并给它添加一个新的属性。可以通过以下代码实现: 示例代码: const arr [{ mainKeyId: key1, name: Item 1, value: 10 },{…

php CURL请求502

增加 pm.max_children 的值 当前值为 50,如果并发请求较多,可能会耗尽子进程资源,导致 502。增加到 100 或更高(根据服务器内存和负载能力调整)。 2. 调整 request_terminate_timeout 当前为 100 秒,适合…

微信小程序中会议列表页面的前后端实现

题外话:想通过集成腾讯IM来解决即时聊天的问题,如果含语音视频,腾讯组件一年5万起步,贵了!后面我们改为自己实现这个功能,这里只是个总结而已。 图文会诊需求 首先是个图文列表界面 同个界面可以查看具体…

git(Linux)

1.git 三板斧 基本准备工作: 把远端仓库拉拉取到本地了 .git --> 本地仓库 git在提交的时候,只会提交变化的部分 就可以在当前目录下新增代码了 test.c 并没有被仓库管理起来 怎么添加? 1.1 git add test.c 也不算完全添加到仓库里面&…

【动手学电机驱动】STM32-FOC(8)MCSDK Profiler 电机参数辨识

STM32-FOC(1)STM32 电机控制的软件开发环境 STM32-FOC(2)STM32 导入和创建项目 STM32-FOC(3)STM32 三路互补 PWM 输出 STM32-FOC(4)IHM03 电机控制套件介绍 STM32-FOC(5&…

对于相对速度的重新理解 - 插一句

因为发了太多的公式,系统提示插入图片太频繁,下一个部分稍后再写。 这里要强调一下: 狭义相对论的平方和形式,其实就是因为分不清虚数单位的大小才写成这个样子。或者用物理语言来说,就是认为所有惯性系的“光速”都…

5G NR:带宽与采样率的计算

100M 带宽是122.88Mhz sampling rate这是我们都知道的,那它是怎么来的呢? 采样率 子载波间隔 * 采样长度 38.211中对于Tc的定义, 在LTE是定义了Ts,在NR也就是5G定义了Tc。 定义这个单位会对我们以后工作中的计算至关重要。 就是在…

【湿度数据处理】中国地面气候资料日值数据集(V3.0)(MATLAB全代码)

【湿度数据处理】中国地面气候资料日值数据集 处理1:数据范围筛选处理2:缺测数据筛查处理3:缺测数据插补参考基于此博客完成各要素数据提取后-【数据集处理】中国地面气候资料日值数据集(V3.0)(含MATLAB全代码),进行后续数据筛选及缺测处理,此处以湿度数据为例。 提取到的…

vue2 - 20.json-server

json-server 目标:基于 json-server 工具,准备后端接口服务环境 1. 安装全局工具 json-server (全局工具仅需要安装一次)【官网】 yarn global add json-server 或 npm i json-server -g yarn global add json-server npm i …

MySQL面试-1

InnoDB中ACID的实现 先说一下原子性是怎么实现的。 事务要么失败,要么成功,不能做一半。聪明的InnoDB,在干活儿之前,先将要做的事情记录到一个叫undo log的日志文件中,如果失败了或者主动rollback,就可以通…

大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本

点一下关注吧!!!非常感谢!!持续更新!!! Java篇开始了! 目前开始更新 MyBatis,一起深入浅出! 目前已经更新到了: Hadoop&#xff0…

leetcode_有序数组中的单一元素

540. 有序数组中的单一元素 - 力扣&#xff08;LeetCode&#xff09; 二分查找 使用条件 &#xff1a; 有序 &#xff0c; log n class Solution { public:int singleNonDuplicate(vector<int>& nums) {int left 0, right nums.size() - 1, mid;while (left <…

Python中的简单爬虫

文章目录 一. 基于FastAPI之Web站点开发1. 基于FastAPI搭建Web服务器2. Web服务器和浏览器的通讯流程3. 浏览器访问Web服务器的通讯流程4. 加载图片资源代码 二. 基于Web请求的FastAPI通用配置1. 目前Web服务器存在问题2. 基于Web请求的FastAPI通用配置 三. Python爬虫介绍1. 什…

USRP:B205mini-i

USRP B205mini-i B205mini-i都是采用工业级的FPGA芯片(-I表示industrial-grade)&#xff0c;所以价格贵。 这个工业级会让工作温度从原来 0 – 45 C 变为 -40 – 75 C. 温度的扩宽&#xff0c;会让工作的稳定性变好。但是前提是你需要配合NI的外壳才行&#xff0c;你如果只买一…

React 常见问题解答:设置、安装、用户事件和最佳实践

在本文中&#xff0c;我们将回答您在开始使用 React 时可能会问的 9 个常见问题。 1、开始使用 React 需要哪些技能和知识&#xff1f; 在深入研究 React 之前&#xff0c;您应该对以下内容有深入的了解&#xff1a; HTML、CSS 和 JavaScript &#xff08;ES6&#xff09;&a…