oracle 备份软件——定时备份(python apscheduler)

2023-12-07 04:32

本文主要是介绍oracle 备份软件——定时备份(python apscheduler),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

延续前面提到的监控系统,这里我们想实现oracle的自动备份?这怎么实现呢,这里就谈谈

监控软件如何实现oracle的定时备份,这里使用了python apscheduler 定时库,关于apscheduler 网上有很多介绍,这里就不详细介绍,直接上代码

web:

通过web可以自己定义rman的备份任务,具体如下:

 

 

我们这里选择如下

配置

显示结果如下:

以上就是前端的界面,那后端如何实现呢?

后端我是采用flask的框架,具体的代码实现如下:

@blueprint.route('/addJobs/', methods=['PUT'])
@require_permission('oracle_bru_manage')
def saveBackup():form, error = JsonParser('f_instances_id','f_bak_name','f_bak_type','f_bak_control','f_bak_local_dir','f_compressed','f_redundancy_control','f_redundancy_num','f_tracking','f_archive_control','f_archive_num','f_offline','f_channel','f_bak_level','f_bak_plan','f_bak_interval','f_bak_week','f_start_time','f_bak_comment','f_bak_person').parse()if error is None:backupInfo = t_oracle_backup_jobs(**form)res = backupInfo.save()if res:scheduler.addJob(form.f_bak_plan, form.f_bak_name, custom_time(form.f_start_time), form.f_bak_interval)return json_response(data='保存成功', message='success')else:return json_response(data=error, message='err')# 新增定时任务API
def addJob(trig, job_name, job_time, interval_time):scheduler.print_jobs()if trig == 1:scheduler.add_job(func=__name__ + ":runJob", id=job_name, args=[job_name, 1], trigger='date',run_date=job_time, replace_existing=True)elif trig == 2:print(interval_time)scheduler.add_job(func=__name__ + ":runJob", id=job_name, args=[job_name, 1], trigger='interval',minutes=int(interval_time), start_date=job_time, replace_existing=True)scheduler.print_jobs()

 这里为了测试,把间隔按天改成按分钟,也就是每隔1分钟会自动执行一次定时job

为了每次重启的时候能能自动从数据库表里面读取到定时任务,这里定义了一个initJob 初始化函数,这样每次重启flask的时候就会自动加载备份任务,具体如下:

def initJob():result = t_oracle_backup_jobs.query.all()for job in result:addJob(job.f_bak_plan, job.f_bak_name, custom_time(job.f_start_time), job.f_bak_interval)

 具体看如下运行日志:

 这里也把具体执行的rman 命令也打印出来

 

这篇关于oracle 备份软件——定时备份(python apscheduler)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/464500

相关文章

Python+Tkinter实现Windows Hosts文件编辑管理工具

《Python+Tkinter实现WindowsHosts文件编辑管理工具》在日常开发和网络调试或科学上网场景中,Hosts文件修改是每个开发者都绕不开的必修课,本文将完整解析一个基于Python... 目录一、前言:为什么我们需要专业的Hosts管理工具二、工具核心功能全景图2.1 基础功能模块2.2 进

Python多重继承慎用的地方

《Python多重继承慎用的地方》多重继承也可能导致一些问题,本文主要介绍了Python多重继承慎用的地方,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录前言多重继承要慎用Mixin模式最后前言在python中,多重继承是一种强大的功能,它允许一个

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Django之定时任务django-crontab的实现

《Django之定时任务django-crontab的实现》Django可以使用第三方库如django-crontab来实现定时任务的调度,本文主要介绍了Django之定时任务django-cront... 目录crontab安装django-crontab注册应用定时时间格式定时时间示例设置定时任务@符号

Python中edge-tts实现便捷语音合成

《Python中edge-tts实现便捷语音合成》edge-tts是一个功能强大的Python库,支持多种语言和声音选项,本文主要介绍了Python中edge-tts实现便捷语音合成,具有一定的参考价... 目录安装与环境设置文本转语音查找音色更改语音参数生成音频与字幕总结edge-tts 是一个功能强大的

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

Python datetime 模块概述及应用场景

《Pythondatetime模块概述及应用场景》Python的datetime模块是标准库中用于处理日期和时间的核心模块,本文给大家介绍Pythondatetime模块概述及应用场景,感兴趣的朋... 目录一、python datetime 模块概述二、datetime 模块核心类解析三、日期时间格式化与

Java调用Python的四种方法小结

《Java调用Python的四种方法小结》在现代开发中,结合不同编程语言的优势往往能达到事半功倍的效果,本文将详细介绍四种在Java中调用Python的方法,并推荐一种最常用且实用的方法,希望对大家有... 目录一、在Java类中直接执行python语句二、在Java中直接调用Python脚本三、使用Run

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT