shell编程-定时任务(备份数据库)
计划任务定时备份,删除等操作:
#crontab -e
#注意 会区分用户 默认在root用户登录用的是root权限用户的计划任务,
如果想在postgres备份 应使用postgres用户权限,
设置定时任务 su postgres
- 第一步:首先用什么权限定时任务需要切换到具体如:数据库备份:postgres用户权限或者其他数据库用户权限
- 第二步:然后再 crontab -e 下就是设置的postgres用户的定时任务
date %F 完整日期格式,等价于 %Y-%m-%d # date +%F

0 0 * * 0 /usr/bin/pg_dump -U postgres simo_dev > /opt/s_bak/simo$(date +"\%F").sql
上面的命令即是在每周日晚上 0:0点 备份数据库的定时任务:
- 第三步:返回到root用户,su
crontab -e 输入以下定时任务

即: 1)在每周日凌晨 :30分 将sql备份的数据库转化为.zip 打包文件
2)在每周日1:00,将.sql文件删除
3)在每周日1:30,将30天之前的文件删除掉,防止文件占用太多内存
30 0 * * 0 /usr/bin/zip /opt/simo_bak/simo`date +"\%F"`.zip /opt/simo_bak/simo`date +"\%F"`.sql
00 1 * * 0 /usr/bin/rm -rf /opt/simo_bak/simo`date +"\%F"`.sql
30 1 * * 0 /usr/bin/find /opt/simo_bak -maxdepth 1 -type f -mtime +30 -exec rm -rf {} \;
也可以写成sh脚本文件方便维护~
系统计划任务
如将auto-del-30-days-ago-log.sh执行脚本加入到系统计划任务,
到点自动执行 输入:
10 0 * * * /opt/soft/log/auto-del-7-days-ago-log.sh >/dev/null 2>&1
解释:设置是每天凌晨0点10分执行auto-del-7-days-ago-log.sh文件进行数据清理任务
10 0 * * * 分别对应是“分 时 日 月 周 命令”。
当分为*时,表示每分钟执行一次,
时为*时,表示每小时执行一次。
注:如果没有实时备份原因定位:cd /var/log 查看cron 的文件错误记录
shell编程-定时任务(备份数据库)的更多相关文章
- 利用shell脚本自动化备份数据库与手动备份还原数据库操作
1.在linux操作系统上手动备份数据库 mysqldump -h 服务器IP地址 -u root -p数据库密码 --databases 所要备份的数据库名称 > /路径/数据库.sql(自定 ...
- shell编程连接postgres数据库(数据备份)
第一步:通过xshell或者其他工具连接到linux服务, 第二步:创建一个脚本:touch se.sh 第三步:输入i,代表开始输入内容 输入以下命令: 脚本如下:(sql语句可以是任何复杂的sql ...
- 定时任务备份数据库与windows批处理
前言: 关于数据库备份的方法有很多,你可以在命令行执行mysqldump命令进行备份,也可以使用数据库管理工具,比如navicat进行数据库的备份. 但是以上数据库的备份都是可以单次备份,总不能要一个 ...
- shell脚本:备份数据库、代码上线
备份MySQL数据库场景:一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求:1)每天备份一次,需要备份所有的库2)把备份数据存放到/data/backup/下3 ...
- 记录一下~~~Linux配置定时任务备份数据库dmp文件
1.创建备份目录: mkdir -p /dcits/sx_xmz/sx_data_bak chown -R oracle18c:oinstall /dcits/sx_xmz/sx_data_bak 2 ...
- shell脚本定时备份数据库
脚本代码: 新建文件back_db.sh #!/bin/bash TODAYTIME="`date +%Y%m%d`" DBNAME="test mysql" ...
- SHELL脚本自动备份数据库
#!/bin/bash db_user="root" db_passwd="dddddd " db_name="mmmmmm" cd /db ...
- Shell编程—定时任务
应用:定时催收,定时下发,对新增内容入库同步, 时间:凌晨 服务器Reahat Linux: Bash HPUX:kbash? #!/bin/sh #!/bin/bash echo awk #输入重定 ...
- Centos下_MysqL5.7在使用mysqldump命令备份数据库报错:mysqldump: Got error: 1449: The user specified as a definer ('fk_system'@'localhost') does not exist when using LOCK TABLES
在阿里云服务器增加一个shell脚本定时备份数据库脚本执行任务时,测试性的执行了备份命令,如下 [root@iZ2ze503xw2q1fftv5rhboZ mysql_bak]# /usr/local ...
随机推荐
- vue axios异步请求django
1,配置请求路径 (1),vue中的请求路径要与django视图路径相同. (2),vue中的路由路径也要和django视图路径相同,比如视图路径为127.0.0.1:8000:home/index, ...
- Java反射【四、成员变量的反射和构造的反射】
获取一个类下所有字段信息 Field[] fs = c.getFields(); 获取所有字段(public) Field[] fs = c.getDeclaredFields(); 获取所有声明字段 ...
- 关于php的发展前景
php7 宣称速度比php5.6快两倍,宣称要打破一切旧规则 2015年,php 7.0发布 2016年,php 7.1发布 2017年,php 7.2发布 2018年,php 7.3发布 2019年 ...
- mysql 关于字符串搜索的函数
与like作用相似 FIND_IN_SET LOCATE POSITION
- 余数之和BZOJ1257
给出正整数n和k,计算j(n, k)=k mod 1 + k mod 2 + k mod 3 + … + k mod n的值. 例如j(5, 3)=3 mod 1 + 3 mod 2 + 3 mod ...
- QT容器类
QList<T> 是一个指针数组,可以使用下标 append(), prepend(), insert() QList<QString> list; list<<& ...
- windows下基于IIS配置ssl证书遇到的坑
前几天配置windows下基于IIS配置ssl证书 完全按照步骤执行 绑定https网址后,一直显示:无法访问此网站 检查了443端口,还有防火墙限制,没发现什么 足足困扰了我好几天 后来突然想到前不 ...
- 什么是DNS
DNS,或者说域名系统,通常是学习如何配置网站和服务器的一个非常困难的部分.了解 DNS 的工作原理将有助于诊断网络访问的问题,也有助于理解 DNS 系统背后的工作原理. 这篇文章中,我们会讨论一些基 ...
- BZOJ2330 糖果[差分约束方案+spfa?/tarjan]
以往对于差分约束理解不是太深,导致这题屡次被坑,在此记录一下细节的理解. 差分约束实际上就是利用了spfa的一个特性:只要有$dis_y>dis_x+w_{x,y}$就松弛,直到所有边关系都满足 ...
- Python文件查找
#!/usr/bin/python import os import string def get_name(path_name, file_str): dir_name = ...