Jump to content

Fazer Backup Do Mysql Via Ftp


Recommended Posts

Olá pessoal,

Alguém sabe onde encontro um script que possa ser agendado via cron para gerar backups do banco de dados MySQL, enviando o arquivo gerado via FTP remoto, de preferência compactado?

Preciso realizar backups do banco de dados do WHMCS algumas vezes ao dia, porém não encontrei um script eficaz para realizar estes backups automaticamente via Cron.

Link to comment
Share on other sites


<?php


# Mude as configurações abaixo


$banco_sql = "BANCO DE DADOS";

$usuario_sql = "USUARIO DO BANCO DE DADOS";

$senha_sql = "SENHA DO USUARIO";

$diretorio_sql = "DIRETORIO TEMP ONDE SALVAR O BD";

# Insira o cominho completo para o diretório. Ex.: /home/USUARIO


$ip_ftp = "IP DO SERVIDOR FTP";

$usuario_ftp = "USUARIO DO SERVIDOR";

$senha_ftp = "SENHA DO USUARIO";

$diretorio_ftp = "PASTA DENTRO DO DIRETORIO HOME";

# Pra salvar na raiz, digite apenas uma barra "/"


# Não mude mais nada a partir daqui


	system("mysqldump -u {$usuario_sql} -p{$senha_sql} -h localhost {$banco_sql} > {$diretorio_sql}/{$banco_sql}.sql");


$arquivo = $diretorio_sql."/".$banco_sql.".sql";


if(!file_exists($arquivo)){

		die('O banco de dados nao foi exportado!');

	}


	$conn_id	= ftp_connect($ip_ftp);

	ftp_login($conn_id, $usuario_ftp, $senha_ftp) or die('Nao foi possivel se conectar ao servidor FTP!');


	ftp_pasv($conn_id, 1);


		ftp_chdir($conn_id, $diretorio_ftp) or die('Nao foi possivel entrar no diretorio: ' .$diretorio_ftp);


		$filename = basename($arquivo);


	ftp_delete($conn_id, $filename);

		ftp_put($conn_id, $filename, $arquivo, FTP_BINARY) or die('Nao foi possivel enviar o arquivo');


	ftp_close($conn_id);


	system("rm -f {$arquivo}");


?>

Não há bem nem mal que dure para sempre. Um dia tudo acaba.

Link to comment
Share on other sites

Guest
This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...

Important Information

Do you agree with our terms?