`
snihcel
  • 浏览: 4392 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

linux文档自动备份脚本

阅读更多
本文引自:SQL吧|企业网站源码下载(www.sql8.net) 原文参考:http://www.sql8.net/a/course/caozuoxitong/liunx/2014/0820/30541.html



首先我在/root/backup 目录下建立一个文件夹,

  #mkdir /root/backup/mysqlbackup

  以后在每天五点钟,就会有一个文件保存在这里.

  接着新建文件

  #vim /root/mysqlautobak

  输入:

  filename=` date +%Y%m%d `

  mysqldump --all-databases -uroot -p(mysql密码)> /root/backup/mysqlbackup/mysql$file.sql

  

  保存退出!

  让它可以执行

  #chomd +X /root/mysqlautobak

  接着开始完crontab了

  #vi /etc/crontab

  

  添加一行

  

  01 5 * * * root /root/mysqlautobak

  保存退出.

  重新启动你的crond服务进程

  # /etc/rc.d/init.d/crond restart


===============================================================================

hp unix 自动全备份脚本(shell)
                                     

说明:每天夜里10点自动备份并且压缩,保留2天备份,在备份完当天后删除前天的备份。在一切执行之后,发邮件通知,邮件内容有删除文件和备份文件名称及备份开始时间,结束时间。
使用方法:nohup backup.sh &

filename:backup.sh
reportlist=""
while [ 1 ]
do
hou=`date +%H`
backdate=`date +%Y%m%d`
if [ $hou -eq 22 ]
then
begintime=`date +%Y-%m-%d:%H-%M`
cd /data_log2/for_test
log_txt=`ls -al -crt log.txt | awk '{print $9}' | wc -l`
if [ $log_txt -gt 0 ]
then
        mv log.txt log.txt.bak
fi

exp owner=user file=/data_log2/for_test/tmp_now.dmp
compress /data_log2/for_test/tmp_now.dmp
mv tmp_now.dmp.Z report_$backdate.dmp.Z
echo "---------report database backuped----------- ">> log.txt
echo "filename="report_$backdate.dmp.Z >>log.txt

delfile=`ls -al -crt *.Z | awk '{print $9}' | head -1`
count=`ls -al -crt *.Z | awk '{print $9}' | wc -l`

if [ $count -gt 2 ]
then
        rm `ls -al -crt *.Z | awk '{print $9}' | head -1`
        echo "----------- old backup deleted ---------" >> log.txt
        echo "the deleted backup filename="$delfile >> log.txt
fi

echo "-----------------beigin time----------------" >> log.txt
echo $begintime >> log.txt
echo "-----------------end    time----------------" >> log.txt
echo `date +%Y-%m-%d:%H-%M` >> log.txt

rm log.txt.bak

mailx -s "10.203.116.23 daily database backup" -r ")" $reportlist < log.txt
fi

sleep 3600
done

======================================================================================
1 给我自己的服务器写的一段自动备份的shell
#!/bin/bash

#指定要备份的系统目录
SYSTEM_DIR=/home

#指定要备份的目录MAIL_DIR=mailbox       #邮件目录
WEBSITE_DIR=www/html                    #WEB目录
DATABASE_DIR=databases                  #数据库目录

#指定备份文件的前缀
MAIL_PREFIX=mail
WEBSITE_PREFIX=web
DATABASE_PREFIX=database

#有朋友的一台WIN2K服务器,我在上面开了ftp,把备份文件传到他的服务器上,相当于我实现了个双机备份

#ftp服务器的IP
FTP_SERV=211.144.155.111
#ftp用户名
FTP_USER=username
#ftp密码
FTP_PASS=12345678

#备份文件存放目录
BACKUP_DIR=/home/backup

#格式化一下日期,备份文件时用日期来做文件名的
DATE=`date +%Y%m%d`

#开始备份邮件
if [ -f ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ]; then #如果当天的邮件已经备份,那没跳过
    echo `date +%Y-%m-%d`'s mail backup file is existing
else #如果没有备份,那么用tar命令来打包邮件目录
    tar -czvf ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${MAIL_DIR}
fi

#开始备份网站目录,备份过程同上
if [ -f ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ]; then
    echo `date +%Y-%m-%d`'s webebsite backup file is existing
else
    tar -czvf ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${WEBSITE_DIR}
fi

#开始备份数据库目录,备份过程同上
if [ -f ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ]; then
    echo `date +%Y-%m-%d`'s database backup file is existing
else
    tar -czvf ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ${SYSTEM_DIR}/${DATABASE_DIR}
fi

#开始把备份文件传输到另一台服务器上
ftp -i -n $FTP_SERV <<AUTO_FTP
user $FTP_USER $FTP_PASS
passive
binary
put ${BACKUP_DIR}/${MAIL_PREFIX}${DATE}.tar.gz ${MAIL_PREFIX}${DATE}.tar.gz
put ${BACKUP_DIR}/${WEBSITE_PREFIX}${DATE}.tar.gz ${WEBSITE_PREFIX}${DATE}.tar.gz
put ${BACKUP_DIR}/${DATABASE_PREFIX}${DATE}.tar.gz ${DATABASE_PREFIX}${DATE}.tar.gz
AUTO_FTP

别忘了,还有最后一步,就是在crontab里加上个任务,这样你就不用每次备份都一步步地敲那些琐碎的命令了。


我的网站,希望大家多多交流

===================================
linux下:

MySQL :: Linux 下自动备份数据库的 shell 脚本
Linux 服务器上的程序每天都在更新 MySQL 数据库,于是就想起写一个 shell 脚本,结合 crontab,定时备份数据库。其实非常简单,主要就是使用 MySQL 自带的 mysqldump 命令。

脚本内容如下:
#!/bin/sh
# File: /home/mysql/backup.sh
# Database info
DB_NAME="test"
DB_USER="username"
DB_PASS="password"

# Others vars
BIN_DIR="/usr/local/mysql/bin"
BCK_DIR="/home/mysql/backup"
DATE=`date +%F`

# TODO
$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS $DB_NAME | gzip > $BCK_DIR/db_$DATE.gz


然后使用将此脚本加到 /etc/crontab 定时任务中:

01 5 * * 0 mysql /home/mysql/backup.sh

好了,每周日凌晨 5:01 系统就会自动运行 backup.sh 文件备份 MySQL 数据库了。

/home/www/inc/back

分享到:
评论

相关推荐

    文件自动备份脚本ForLinuxWithSVN

    "文件自动备份脚本ForLinuxWithSVN"就是一个这样的解决方案,它结合了Linux操作系统和Subversion(SVN)版本控制系统,实现了文件的自动、增量备份,以达到高效且节省资源的目的。 首先,让我们了解Linux系统。...

    windows&linux svn自动化全备份&增量备份脚本

    - **linux下-SVN全量和增量备份脚本.docx**:这份文档可能包含了详细的Linux环境下编写SVN备份脚本的步骤和示例代码。 - **svnBackupBat.rar**:这是一个Windows批处理脚本的压缩包,可能包含全备份和增量备份的bat...

    suse linux 定时备份脚本

    文档中提到的是如何在 SUSE Linux 系统上创建一个定时备份脚本,具体步骤包括: 1. 生成密钥对:使用 ssh-keygen 命令生成一个密钥对,用于安全地连接到另一个服务器。 2. 发布密钥:将生成的密钥拷贝到目标服务器...

    oracle数据库自动备份脚本带说明

    "oracle数据库自动备份脚本带说明"的标题表明这是一个关于如何自动化执行Oracle数据库备份的脚本,这对于系统管理员来说是非常实用的工具。下面我们将详细探讨Oracle数据库的备份策略、自动备份脚本的工作原理以及...

    Linux 下数据库备份脚本

    本文档将详细介绍如何在Linux环境下使用`exp`和`expdp`两种方法来实现Oracle数据库的备份。 #### 二、环境配置与准备 1. **环境变量配置**: - `ORACLE_BASE`:Oracle软件的基础目录,例如`/u01/app/oracle`。 -...

    shell 自动备份oracle 脚本

    在IT行业中,数据库的定期备份是确保数据安全和业务连续性的重要环节。Oracle数据库作为业界...因此,了解并掌握如何编写和维护这样的shell自动备份脚本对于任何管理Oracle数据库的IT专业人员来说都是至关重要的技能。

    mysql上线自动备份脚本

    ### MySQL自动备份脚本知识点详解 #### 一、脚本背景及目的 本文介绍的MySQL自动备份脚本主要用于在线环境中对MySQL数据库进行定期备份,并同时实现了本地与远程FTP服务器的双重备份策略。此脚本已经经过了长时间的...

    Linux下定时备份MySQL数据库的Shell脚本.pdf

    例如,以下命令表示每天凌晨3点执行备份脚本: ``` 0 3 * * * root /usr/sbin/DataBackup ``` #### 四、注意事项 - **变量定义**:Linux下的Shell脚本定义变量时,变量名与等号之间不能有空格。 - **特殊字符**...

    最全最强悍的linux自动备份+自动删除老的备份脚本知识.pdf

    这份文档"最全最强悍的linux自动备份+自动删除老的备份脚本知识.pdf"提供了两个脚本,分别用于自动备份文件系统和MySQL数据库,并且在备份完成后会自动删除7天前的旧备份。以下是对这两个脚本的详细解析: 1. **...

    windows-linux的oracle自动备份命令及说明文档

    本文档将详细介绍Windows和Linux环境下,如何利用Oracle提供的工具进行自动备份,并提供相应的命令及说明文档。 首先,我们来看Windows环境下的自动备份。在提供的压缩包中,有一个名为`oraclebackdb.bat`的批处理...

    db2备份脚本.rar

    本压缩包"db2备份脚本.rar"提供了三种不同模式的自动备份脚本以及定期清理脚本,旨在帮助管理员实现高效、自动化的DB2数据库备份。 1. **备份模式**: - **离线全量备份**:这是最基础的备份方式,它会备份整个...

    最全最强悍的linux自动备份+自动删除老的备份脚本.pdf

    该文档提供的是一份Linux系统下的自动备份脚本,名为`Ysy_backup.sh`,它能够定期备份指定的文件或目录,并自动删除超过一定天数(在这个例子中是7天)的旧备份。脚本分为两部分,分别针对文件/目录备份和MySQL...

    MYSQL服务器自动备份脚本(可设置保留天数)

    总结起来,这个MySQL服务器自动备份脚本涵盖了数据库的导出、压缩、过期备份的清理以及计划任务的配置,是一个全面且实用的解决方案。通过定期执行这样的脚本,你可以确保在任何数据丢失的情况下都有恢复点可用,...

    mongodb4.2全量定时增量备份python脚本

    总的来说,这个Python脚本提供了一个自动化备份解决方案,它不仅执行全量备份,还能根据`oplog`实现增量备份,大大减少了备份所需的时间和存储空间。这对于大型数据库和高并发环境来说尤其重要,因为它允许在不影响...

    Linux环境下rman备份的实例脚本

    本文档介绍了在Linux环境下使用RMAN进行数据库备份的实例脚本。RMAN(Recovery Manager)是Oracle数据库中的一个备份和恢复工具,用于管理和维护数据库的备份和恢复。 背景 _target database_是指目标数据库,位于 ...

    Linux(Centos)全自动异地备份数据(WEB+Mysql).pdf

    在这里,它被用来定时执行自动备份脚本。 7. Shell脚本编写:Shell脚本是编写在Linux系统中自动执行任务的有效方法。它可以帮助用户执行一系列命令,实现自动化流程。文档中提到了编写一个名为autobackup.sh的Shell...

    windows脚本SFTP上传文件至备份服务器方案

    本文档将详细介绍如何通过编写Windows脚本来实现文件的自动归档、压缩以及通过SFTP方式上传至备份服务器的过程。 #### 背景 在之前的项目中,通常使用SyncBackSE工具来完成文件的自动归档和压缩,并将其上传到备份...

    linuxoracle自动备份脚本实用.pdf

    要使这个脚本自动化,可以使用Linux的Cron计划任务系统。在本例中,使用`crontab`命令为Oracle用户设置任务: ```bash crontab -u oracle -e * 3 * * * /home/bakup/bakup.sh ``` 这将在每天凌晨3点执行`/home/...

    linux环境下oracle备份脚本.pdf

    这份文档主要涉及的是如何使用RMAN(Recovery Manager)工具创建自动化的备份脚本。RMAN是Oracle数据库提供的一种用于管理数据库备份和恢复的命令行工具。 首先,我们来看全量备份脚本。全量备份是指对整个数据库或...

Global site tag (gtag.js) - Google Analytics