mysql备份脚本

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-02 01:14 点击:

 

mysql 备份脚本..写的很一般..高手见了不要笑俺..

#!/usr/bin/perl -w

use warnings;

use strict;

use DBI;

my $backup_dir = "/root/perl/backup";

my $backup_log = "$backup_dir/backup_log";

my $db_name = "mysql";

my $db_host = "localhost";

my $db_user = "root";

my $db_passwd = "redhat";

my $db_port = "3306";

my $mysql_bin_dir = "/usr/local/mysql/bin";

my $ftp_user = "ftp";

my $ftp_passwd = "redhat";

my $ftp_host = "192.168.1.100";

my $ftp_dir ="pub";

my @backup_db_list = qw(mysql test);

my ($sec,$min,$hour,$day,$mon,$year)=localtime;

$year += 1900;

$mon += 1;

my $time_now = "$year-$mon-$day";

my @backup_list;

mkdir "$backup_dir",0755 if !-e "$backup_dir";

open LOG,">>$backup_log";

print LOG "----------------------\nStart: $time_now\n";

my $dsn = "DBI:mysql:$db_name:$db_host:$db_port";

my %conn_attrs = (

                PrintError => 1,

                RaiseError => 1,

                AutoCommit => 1,);

my $dbh=DBI->connect($dsn,$db_user,$db_passwd,\%conn_attrs)  or print LOG "Could not connect mysql server:".DBI->errstr."\n";

foreach my $db (@backup_db_list){

        mkdir "$backup_dir/$db",0755 if !-e "$backup_dir/$db";

        chdir "$backup_dir/$db";

        my $backup_db_name = "${db}_${time_now}\.sql";

        !system "$mysql_bin_dir/mysqldump -h $db_host -u $db_user -p$db_passwd -P $db_port -B $db > $backup_db_name" or print LOG "mysqldump error:$!\n";

        system "(tar -zcvf $backup_db_name\.tar\.gz $backup_db_name) 2>&1 >/dev/null" if -e $backup_db_name;

        unlink "$backup_db_name" if -e "$backup_db_name\.tar\.gz";

        push (@backup_list,"$backup_dir/$db/$backup_db_name\.tar\.gz");

                my @all_backup_db_list = <*.*.tar.gz>;

                        foreach my $backup_file (@all_backup_db_list){

                                unlink $backup_file if (time() - (stat($backup_file))[9] > (60*60*24*5));

 }

}

$dbh->disconnect();

print "@backup_list\n";

my $ftp = Net::FTP->new($ftp_host,debug => 0) or print LOG "Count not connect ftp:$ftp_host\n";

$ftp->login($ftp_user,$ftp_passwd) or print LOG "Could not login ftp:$ftp_host\n";

$ftp->binary();

$ftp->cwd($ftp_dir);

foreach my $upload_backdb_file (@backup_list){

        $ftp->put($upload_backdb_file) or print LOG "put $upload_backdb_file faild!\n";

}

print LOG "------------------------\n---------END----------\n&quo

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • mysql-mmm
    • mysqldump命令——MySQL数据库备份还原
    • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
    • 简简单单储存过程——循环一个select结果集
    • MySQL数据库十大优化技巧
    • Mysql安装笔记
    • Mysql主主复制架构配置
    • Mysql的Procedure 参数为NULL问题分析
    • MySQL Stmt预处理提高效率问题的小研究
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1