Simples sistema de backup com acesso remoto

Simples, reúne todas as informações que você delega importantes, exige que você altere todo o programa para atender suas necessidades, mas de quebra você pode ter acesso as essas informações pela web através de um sistema seguro de acesso remoto e sem nenhum esforço, pois o script realiza o backup automaticamente para o servidor de backup.

[ Hits: 52.840 ]

Por: William França em 01/02/2007


Lógica operacional




A matéria foi realizada com experiências em servidores rodando a distribuição Debian GNU/LINUX Sarge, você poderá adaptá-lo às suas necessidades. Me preocupo em dar a lógica, exemplos e conceitos de segurança e programação estruturada e você se preocupa em adaptar tudo isso a sua necessidade.

O conceito lógico é o seguinte:

O script 1 varre o sistema em busca de informações, compacta os arquivos e salva em um ambiente seguro no web server do servidor. Para isso será necessário que o Apache esteja funcionando em todos os servidores que você instalar este script ou um servidor FTP, entretanto nos limitaremos neste artigo apenas ao servidor web e daremos todo o suporte para que ele se torne um ambiente seguro.

O script B é um irmão do script 1, toda máquina que o script 1 estiver o 2 também estará, pois ele é o agente que dá suporte na manutenção do sistema, ele pode ser tanto um script de cron como um script alojado na pasta init.d, que é executado a cada boot ("não se esqueça que me baseio sempre na distro Debian"). Darei todos os exemplos mastigados para você digerir.

O script 3 ficará instalado no servidor de backup, ele vai se conectar no web server de todos os servidores e fará o download dos arquivos, este servidor de backup também precisa do servidor web apache e o módulo php configurado para que o acesso remoto possa ser realizado, ou poderá usar um outro servidor web que se conectará ao servidor de backup, ou por http ou por ftp, você decide, o nosso foco será sempre métodos http.

Nos próximos tópicos ensinarei:
  • Como criar um ambiente seguro;
  • Como criar o script 1;
  • Diferentes formas de se criar o Script 2;
  • Como criar o script 3 ;
  • Segurança da Informação;
  • Considerações finais.

    Próxima página

Páginas do artigo
   1. Lógica operacional
   2. Preparando um ambiente seguro
   3. Script 1 - varrendo o sistema em busca de informações
   4. Script 2 - manutenção do sistema
   5. Script 3 - servidor de backup
   6. Sistema PHP - segurança da informação
   7. Considerações finais
Outros artigos deste autor

Relatório de sistema via browser (shell script + CGI)

Leitura recomendada

Script GitPratico para criar repositórios remotos sem logar no GitHub

Brincando com pseudoterminais e redirecionamentos

Conheça o projeto BASHSRC

flock - Gerenciador de lockfiles

Relatório do sistema (Shel Script + PHP)

  
Comentários
[1] Comentário enviado por aprendiz_ce em 01/02/2007 - 18:08h

Show de bola!

Parabéns pelo seu artigo.

[2] Comentário enviado por thigux em 05/02/2007 - 10:24h

Mtu bom porem ao inves de
<form method="post" action="index.php">

nao seria

<form method="post" action="admin.php">???

[3] Comentário enviado por williamcrazy em 05/02/2007 - 10:54h

Correto thiagux cometi um peuqeno engano no arquibo login.inc a seção está setada como deptec ao envés de jlff e o location tá setando o index.php ao envés do admin.php então logo a baixo disponibilizarei a correção:

<?
session_start();

if (empty($_SESSION['jlff']) || $_SESSION['jlff']!="beta")
{
header("Location: admin.php");
exit;
}

?>

[4] Comentário enviado por thigux em 06/02/2007 - 08:43h

pode ser problema de algo aqui mas fiquei na duvida entao ta ai abaixo e vlw pela ajuda como disse adaptei pra outra coisa aqui e ta funcionando se quer saber alem do sisteminha de backup ja montei uma pequena intranet.

se quiser ver ou me ajudar ou mesmo apenas amizade de Linux thiagom128@hotmail.com

Só mais uma coisa eu testei aqui e independente da senha ele abria a tela pois adaptei seu codigo a outra coisa aqui e so mudei o admin.php no meu caso e tipo será q ta certinho esse index.php com o config.php tem alguma correção ou no seu ele autentica a senha ??

[5] Comentário enviado por williamcrazy em 06/02/2007 - 15:52h

Veja bem quando eu montei este script ele funcionou perfeitamente, você pode prestar atenção em algum detalhe que pode ter algo fora dos eixos, pois quando o fiz foi pensando que talvez a pessoa não tivesse disponivel um banco de dados, entretanto como você disse que tem agora uma intranet você pode usar a tecnologia mysql hehehe!!!
Aqui todos os funcionáriso tem seu login e senha cadastrados num banco de dados, vou te mostrar um exemplo não é o mesmo que eu uso mais é bem mais simples e bastante eficaz:

conexao.php

<?
//abre uma conexao com o mysql
$conexao = mysql_connect("HOST do SERVER", "USUARIO", "SENHA") or die (' Impossível conecta ao mysql, veja: ' . mysql_error());
mysql_select_db("BANCO DE DADOS QUE TEM A TABELA USUARIOS") or die (' O banco de dados não existe ');
?>

---------------------------------------------------

ogin.html

<form action="login.php" method="post" name="users" id="users">
<p>Logn dos usuários:</p>
<p align="center">
<input name="textfield" type="text" value="usuario">
<br>
<br>
<input name="textfield2" type="password" value="senha">
<br>
<br>
<input type="submit" name="Submit" value="Login">
</p>
</form>

----------------------------------------------------------------------------


ogin.php

<?
//conecta ao mysql
include "conexao.php";
//pega usuário e senha
$usuario = $_POST["usuario"];
$senha = $_POST["senha"];
//verifica se está tudo correto
$resultado = mysql_query("SELECT * FROM usuarios WHERE usuario = '$usuario' AND senha = '$senha' ");
//verifica se encontrou registros
if(mysql_num_rows($resultado)==0)
{
echo "<center><font face = verdana size = 2>ERRO! usuário ou senha inválidos!<br><br><a href = \"index.php\">Voltar</a></font></center>";
}
else
{
//usuário e senha corretos
$_SESSION['user'] = $usuario;
$_SESSION['pass'] = $senha;
//redireciona para admin
header("Location: admin.php");
}
?>

-------------------------------------------------------------------------

verifica.php

<?
//primeiro verifica se os cookies existem
if(isset($_SESSION["user"]))
{
}
else
{
header("Location: index.php");
}
if(isset($_SESSION["pass"]))
{
}
else
{
header("Location: index.php");
}
//verifica se eles não estão vazios
if(empty($_SESSION["user"]) or empty($_SESSION["pass"]))
{
header("Location: index.php");
}
else
{
}
//verifica se eles são corretos
$nome_usuario = $_SESSION["user"];
$pass_usuario = $_SESSION["pass"];
$resultado = mysql_query("SELECT * FROM usuarios WHERE usuario = '$nome_usuario' AND senha = '$pass_usuario' ");
//verifica se houve ocorrencia
if(mysql_num_rows($resultado)==0)
{
header("Location: index.php");
}
else
{
}
?>


----------------------------------------------------------------------

adm.php

<?
include "verifica.php";
?>


e esse include "verifica.php"; voc~e pode colocar em toda página que necessitar de autenticação para manter a segurança.

O grande lance do Software livre é exatamente esse, temos a liberdade de alterar os sistemas para atender á nossa real necessidade enquanto a microsoft manipula e faz lavagem cerebral nos seus clientes nós temos o poder da adaptabilidade gerando cada vez mais produtos com depenho melhorado, segurança reforçada, usabilidade adequada, somos uma imensa comunidade global enquanto empresas que vendem seus produtos de codigo fechado são apenas meias duzia de programadores bem pagos para fazerem produtos mal feitos, é claro sempre há excessões mais o Software livre extamante para isso, para dar liberdade e quebrar todas as excessões, hehehehe :-)
Bom Trabalho espero ter ajudado.

[6] Comentário enviado por thigux em 06/02/2007 - 16:13h

Opa mtu bom....mas aqui to usando sem BD mesmo to vendo se implemento isso pois ficaria mais facil a manipulação aqui .se souber algo q nao precise de BD melhor..mas vou tentar implementar em casa isso pois na empresa ainda estou Ganhando o direito de colocar linux

[7] Comentário enviado por heberbd em 06/02/2007 - 22:59h

Cara tenho uma situação diferente, tenho que fazer backup apenas de alguns arquivos no diretorio e tenho vários diretorios desse mesmo jeito.
Ex:

/home/teste1/*.pas
/home/teste2/src/*.jar
/home/teste3/*.doc

e tbm queira colocar esses diretorios em um arquivo para ficar fácil para os usuários atualizarem a lista de backup.

Será que você tem uma solução para esse problema????

Valeu....

[8] Comentário enviado por williamcrazy em 10/02/2007 - 10:53h

Não sei se entendi direito, mais ´não é tão complicado assim, pelo o que eu entendi voc~e tem alguns usuarios e cad um tem o seu diretorio você que fazer backup apenas de alguns arquivos e cada usuario poderá acessar apenas o seu propio arquivo de backup, bom vai dá um pouco de trabalho mais vamos lá.
A lógica é simples e praticamente a mesma, você vai criar um script de busca neste escript você coloca o que você quer igual no teu exemplo:
/home/teste1/*.pas
/home/teste2/src/*.jar
/home/teste3/*.doc
Dai você faz um script de recepção no qual fará a compactção de cada usuario gerando um arquivo .tar.gz para cada usuario ai neste mesmo script você cria um diretorio para cada usuario no servidor de backup, coloca cada tar.gz dentro da seu respectivo diretorio, n o sistema em php você cria uma conta de usuario para cada usuario, faça com que o seu script php redirecione cada login para a sua respectiva conta se puder fazer isso através de um banco de dados, melhor ainda,
ai quando o usuario fulanodetal acessar a sua conta ele vai ter uma pagina na qual você disponibilizará que ele acesse os arquivos de backup dele.

filedownload='/home/ftc/public_html/users-backup/'
database1='/home/ftc/public_html/backup/1'
database2='/home/ftc/public_html/backup/2'
database3='/home/ftc/public_html/backup/3'

mkdir $filedownlod/usuario1
mkdir $filedownlod/usuario2
mkdir $filedownlod/usuario3


cp /home/teste1/*.pas $database1
cp /home/teste2/src/*.jar $database2
cp /home/teste3/*.doc $database3

nome1='backup_usuario1'
nome2='backup_usuario2'
nome3='backup_usuario3'

ext='tar.gz'
tar -cvzf $nome1.tar.gz $database1
tar -cvzf $nome2.tar.gz $database2
tar -cvzf $nome3.tar.gz $database3

mv $nome.$ext $filedownload/usuario1
mv $nome.$ext $filedownload/usuario2
mv $nome.$ext $filedownload/usuario3

Ta ai uma ideia básica é claro eu fiz com pressa então faça os ajustes e com as noções do restante do tutorial você consigará terminar o sistema
sem maiores problemas

Na seção script 3 foi escretia pensando nessa mesma situação eu tava conferindo e você pode notar que segue a mesmas linha de raciocinio que eu idealizei agora:

http://www.vivaolinux.com.br/artigos/verArtigo.php?codigo=6040&pagina=5

Então é isso, memantenha informado qualquer duvida será um prazer ajudar e Viva o linux!!!!



Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts