LINUX 自动备份脚本文件

首先我在/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

 

转载于:https://www.cnblogs.com/xred/p/3731855.html

### 回答1: Linux自动备份文件脚本可以使用bash脚本实现。 可以使用cp或rsync命令复制文件备份目录,并使用cron定期运行脚本。 示例脚本如下: ``` #!/bin/bash # 要备份的目录 src_dir="/home/user/important_files" # 备份文件存储的目录 dst_dir="/mnt/backup/important_files" # 使用rsync命令复制文件 rsync -avz $src_dir $dst_dir # 使用cron定期运行脚本 # 每天凌晨3点运行 0 3 * * * /path/to/script.sh ``` 需要注意的是,在脚本中需要指定正确的目录和文件路径。也可以按需调整备份的频率。 ### 回答2: Linux是一款开源的操作系统备份文件是非常常见的操作。使用Linux自动备份文件脚本可以让用户可以快速、方便地实现文件备份操作。以下是一个简单的备份脚本示例: 1. 创建备份目录: 为了让备份操作更为方便,可以创建一个专门用来存放备份文件的目录,例如: /backup/ 2. 编写备份脚本: 使用vi等编辑器,编写一个备份脚本文件,例如: /backup/backup.sh #!/bin/bash # 定义备份文件路径和名称 BACKUP_FILE="/backup/backup-$(date +%Y%m%d%H%M%S).tar.gz" # 定义备份的目录路径 BACKUP_PATH="/home/user/files" # 删除7天以前的备份文件 find /backup/ -mtime +7 -name "*.gz" -exec rm -rf {} \; # 开始备份 tar -czvf $BACKUP_FILE $BACKUP_PATH # 将备份文件拷贝到远程服务器 scp $BACKUP_FILE remoteuser@remoteserver:/backup/ # 删除本地备份文件 rm -rf $BACKUP_FILE 3. 设置定时任务: 为了实现定期自动备份,可以使用Linux的crontab功能,设置每天、每周或每月执行备份脚本的时间。以下是一个每天备份一次的定时任务设置示例: # 编辑定时任务 crontab -e # 在文件中添加如下内容 # 每天凌晨2点执行备份 0 2 * * * /bin/bash /backup/backup.sh 4. 测试脚本: 在设置好定时任务之后,可以手动执行备份脚本进行测试。执行命令: sh /backup/backup.sh 即可完成备份操作。备份文件将会在/backup/目录下以备份时间为文件名存放。 总之,使用Linux自动备份文件脚本可以提高文件备份操作的效率和准确性,其中需要注意定时任务的设置和备份文件的路径和名称。备份文件需要及时清理,避免占用过多的存储空间。 ### 回答3: 随着数据量的增长和日益依赖于数据,做好数据备份变得越来越重要了。而Linux自动备份脚本可以极大地提高备份的效率和可靠性。下面,我们就来谈谈如何编写一份Linux自动备份文件脚本。 第一步:确定备份计划 在编写自动备份文件脚本之前,我们需要确定备份计划,即备份的频率和备份的数据范围。根据实际情况,我们可以按天、按周或按月等周期定期备份需要备份文件。 第二步:编写备份脚本Linux系统下,我们可以使用Shell脚本实现自动备份。下面是一个简单的备份脚本示例: ``` #!/bin/bash #定义备份文件目录和备份文件存储目录 backup_dir="/home/data" store_dir="/home/backup" #定义备份文件名和备份时间 backup_file="data_$(date +%Y%m%d).tar.gz" backup_time=$(date "+%Y/%m/%d %H:%M:%S") #创建备份文件夹 if [ ! -d "$store_dir" ]; then mkdir "$store_dir" fi #打包压缩文件并拷贝到备份目录 cd "$backup_dir" && tar zcvf "$store_dir/$backup_file" ./* echo "$backup_time 备份 $backup_file 成功" >> "$store_dir/backup.log" #删除10天前的备份文件 find "$store_dir" -mtime +10 -name "*.tar.gz" -exec rm -f {} \; ``` 该脚本实现备份/home/data目录下的所有文件,并将其打包压缩成以当前日期命名的文件,并将其保存在/home/backup目录下。同时,该备份脚本备份成功的信息记录在备份日志文件中,并自动清理10天前的备份文件。 第三步:设置定时任务 为了让备份脚本实现自动化,在Linux系统下我们可以使用cron工具来设置定时任务。我们可以在终端输入crontab -e命令,然后将定时任务加入crontab配置文件中。例如,我们可以将备份脚本设置为每天凌晨1点执行: ``` 0 1 * * * sh /home/backup.sh ``` 这样,我们就成功实现Linux自动备份文件脚本,保证了数据的安全可靠性。当然,上述脚本只是一个简单的示例,具体的备份脚本需要根据实际情况进行调整和优化,以更好地适应实际需要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值