LINUX 自动备份怎么实现?

LINUX 自动备份怎么实现?,第1张

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

1. 写个自动备份的脚本autobackup.sh,内容如下

#!/bin/bash

mysqldump -p databasename >mydata.sql

2. 更改其为可执行文件 chmod +x autobackup.sh

3. 通过crontab让系统自动运行这个脚本就好了,如crontab -e

0 0 * * * /路径到/autobackup.sh

第一个0表示分钟,第二个0表示0小时也就是零辰第三个*表示每天,第四个*表示每月,第五个*表示每周

linux自动备份网站和数据库,到另外服务器上,为当前用户创建定时任务两台服务器111,和117服务器,每天完成111服务器上网站和数据库自动备份到117服务器上1:我的111服务器上是当前用户:sxA:

查看当前用户的计划任务:crontab

-l是查看当前用户的任务用

vi

crontab

-e

是为sxw用户创建一个计划任务第一行:每天3点运行/home/sxw/rsync201.sh

shell脚本,第二行:和第三行是每天下午7点运行tar包,gaokaotong和phpcms文件第三行:每天7点22分运行/homesxw/back_up.sh

shell脚本,注意:这里是当前用户sxw,所以要shell脚本路径要有用户sxw权限,在这里/home/sxw/back_up

shell脚本,是当前用户sxw用户的家目录。B:

111服务器上/home/sxw/back_up.sh脚本code:-bash-3.2$

vim

/home/sxw/back_up.sh#!/bin/shecho

开始备份数据库mysqldump

-u

jeecms

-pjeecms1234

gktcms

>

gktcms.sqlmysqldump

-u

jeecms

-pjeecms1234

phpcms

>

phpcms.sqlecho

备份数据库完成,复制到117服务器端scp

-P

10022

gktcms.sql

zk@114.113.145.117:/home/zkscp

-P

10022

phpcms.sql

zk@114.113.145.117:/home/zkscp

-r

-P

10022

/opt/www/www2/phpcms.tar.gz

zk@114.113.145.117:/home/zk/scp

-r

-P

10022

/opt/www/www2/gaokaotong.tar.gz

zk@114.113.145.117:/home/zk/echo

发送完成C:

还要在111上做ssh信任,这个可参照ssh资料。很简单,只需要建立两个密钥。2:

117服务器上/homezk/自动就会多出两个tar包文件,phpcms.tar.gz

和gaokaotong.tar.gz这里每天自动保存两个文件,phpcms.tar.gz

gaokaotong.tar.gz文件

这里做了一个shell脚本,保存前两天的文件,跟上述111服务器上的建立计划任务一样:A:

查看117的计划任务:

crontabl

-lB:

在查看/home/zk/back.sh

的shell编写code:[zk@DB2~]$

vi

/home/zk/back.sh#!/bin/shTARFILE=/home/zk/phpcms.tar.gzif

[

-f

$TARFILE

]then

mv

/home/zk/phpcms.tar.gz

/home/zk/phpcms_$(date

+%Y%m%d).tar.gz

#remove

date

file

DATE_B=$(date

-d2

day

ago

+%Y%m%d)

FILENAME=/home/zk/phpcms_$DATE_B.tar.gz

if

[

-f

$FILENAME

]then

rm

-rf

/home/zk/phpcms_$DATE_B.tar.gz

else

echo

没有可删除文件

fielse

echo

没有源文件fi~

结束。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10053788.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-04
下一篇2023-05-04

发表评论

登录后才能评论

评论列表(0条)

    保存