Muito tem se falado sobre estabilidade e confiabilidade em backups. Eu particularmente era adepto aos poderosos scripts (shell e batch), mas me rendi às facilidades do Bacula. Vou apresentar detalhadamente todo o processo de instalação e configuração da ferramenta.
A instalação ocorreu em um LinuxDebian 5 totalmente enxuto, usei o CD netinst e fiz somente a instalação dos pacotes necessários.
# apt-get update
# apt-get install ssh vim openssl make gcc build-essential libssl-dev libpq5 mysql-server libmysql++-dev perl unp apache2 php5 samba mc
Obs.: Durante a instalação do mysql-server ele irá requisitar uma senha, é recomendado que essa senha não seja configurada, porém se achar necessário configurá-la para uma melhor segurança mostrarei como se deve proceder com a configuração do Bacula, com ou sem senha do banco MySQL.
Os fontes foram baixados diretamente do site do Bacula, utilizei um pacote tarball (.gz):
# tar -xzvf bacula-3.0.3.tar.gz -C /opt
# cd /opt/bacula-3.0.3
# ./configure --with-mysql
# make
# make install
# make install-autostart
Esse último comando irá inicializar o Bacula junto com o sistema operacional, o Bacula tem 3 daemons que tem que ser inicializados, são eles:
bacula-dir
bacula-fd
bacula-sd
Criando o banco de dados:
# cd /etc/bacula
# ./create_mysql_database
# ./make_mysql_tables
# ./grant_mysql_privileges
Se você configurou uma senha para o usuário root do banco de dados, deve passá-la em cada um dos scripts acima, no seguinte formato (exemplo, com senha 123):
# ./create_mysql_database -u root -p123
Como eu sou um cara preguiçoso, acredito que todos admin também buscam facilidades, desenvolvi um script para subir e parar o daemon, fica seu critério utilizá-lo.
# touch /etc/init.d/bacula
# chmod + x /etc/init.d/bacula
[2] Comentário enviado por jgama em 08/02/2010 - 01:20h
Amigo segui os passo do teu tutorial, mas aqui usando o ubuntu-desktop 9.04 esta dando erro, conforme abaixo
root@valdir-desktop:/etc/bacula# bconsole -c /etc/bacula/bconsole.conf
Connecting to Director valdir-desktop:9101
Director authorization problem.
Most likely the passwords do not agree.
If you are using TLS, there may have been a certificate validation error during the TLS handshake.
Please see http://www.bacula.org/en/rel-manual/Bacula_Freque_Asked_Questi.html#SECTION003760000000000000000 for help.
root@valdir-desktop:/etc/bacula#
[3] Comentário enviado por jgama em 08/02/2010 - 01:34h
Estava faltado corrigir a senha no arquivo bconsole.conf
Director {
Name = correio-dir
DIRport = 9102
address = 10.0.2.252
Password = "123"
}
Agora fica nesta parte e não consigo sair
root@valdir-desktop:/etc/bacula# bconsole -c /etc/bacula/bconsole.conf
Connecting to Director valdir-desktop:9101
1000 OK: valdir-desktop-dir Versão: 3.0.3 (18 October 2009)
Digite um período para cancelar um comando.
*run
Selecionado automaticamente Catálogo: MyCatalog
Usando Catálogo "MyCatalog"
Deve ser especificado um nome para o serviço
Os recursos definidos de trabalho são.
1: Windows_GOLF
2: Linux_CORREIO
3: Restore_Linux_CORREIO
4: Restore_Windows_GOLF
Selecione o recurso do trabalho (1-4): 2
Run Backup job
JobName: Linux_CORREIO
Level: Incremental
Client: Linux_Client_CORREIO
FileSet: Linux_File_CORREIO
Pool: Default (From Recurso do Trabalho)
Storage: FileStorage (From Recurso do Trabalho)
When: 2010-02-08 01:33:08
Priority: 10
Pronto para executar ? (sim/mod/não) sim
Serviço enfileirado. JobId=2
*
[4] Comentário enviado por prgs.linux em 19/02/2010 - 08:09h
Bom dia, desculpe a demora pra lhe responder..... vi sua dúvida.... talves voçê mesmo já conseguiu resolver... mas vc pode testar se a porta esta open..
# netstat -tan | egrep -w "(9101|9102)"
Ja na segunda dúvida..quando voçe entra no console do bacula, voçe está restaurando uma maquina Windows ou Linux??..Acredito que seja o Linux.
# bconsole -c /etc/bacula/bconsole.conf
*restore
1 ## Lista o JOB
12 ## Restore
10 ## Job Selecionado, a partir do JOB listado no comando 1
mark * ## marca todos pacote
done ## Sai do console
1 ## Marca o cliente a ser restaurado
18-Mar 11:44 Slack_BKP-dir JobId 2: Begin pruning Jobs older than 1 month .
18-Mar 11:44 Slack_BKP-dir JobId 2: No Jobs found to prune.
18-Mar 11:44 Slack_BKP-dir JobId 2: Begin pruning Jobs.
18-Mar 11:44 Slack_BKP-dir JobId 2: No Files found to prune.
18-Mar 11:44 Slack_BKP-dir JobId 2: End auto prune.
você saberia me dizer por que está ocorrendo este erro?
[9] Comentário enviado por linuxblood em 19/03/2010 - 14:27h
Senhores, estou com o problema "Serviço enfileirado. JobId=22", o que pode ser?
Abaixo meu DIR para analise, ja rodei rodei e nada, obrigado:
# definicao do diretor
Director {
Name = alysson-dir
DIRport = 9101 # Porta das conexoes do diretor
QueryFile = "/etc/bacula/query.sql"
WorkingDirectory = "/var/bacula/working"
PidDirectory = "/var/run"
Maximum Concurrent Jobs = 2
Password = "bacula" # senha diretor
Messages = Mensagens
}
Catalog {
Name = MyCatalog
dbname = bacula; user = bacula; password = ""
}
Client {
Name = Windows
Address = 192.168.2.243
FDPort = 9102
Catalog = MyCatalog
Password = "bacula"
File Retention = 30 days
Job Retention = 30 days
AutoPrune = yes
}
Client {
Name = Linux
Address = 192.168.2.230
FDPort = 9102
Catalog = MyCatalog
Password = "bacula"
File Retention = 30 days
Job Retention = 30 days
AutoPrune = yes
}
###### POOL Linux ######
Pool {
Name = Default
Pool Type = Backup
Recycle = yes # Bacula can automatically recycle Volumes
AutoPrune = yes # Prune expired volumes
Volume Retention = 1d # one year
}
Pool {
Name = Linux
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderá ser utilizado novamente
Maximum Volume Bytes = 10G
Maximum Volumes = 10
Label Format = "Linux"
}
##### POOl Windows ######
Pool {
Name = Windows
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderá ser utilizado novamente
Maximum Volume Bytes = 10G
Maximum Volumes = 10
Label Format = "Windows"
}
Schedule {
Name = "Linux"
Run = Level=Full Pool=Linux Monday at 8:00pm
}
Schedule {
Name = "Windows"
Run = Level=Full Pool=Windows Monday at 8:00pm
Storage {
Name = alysson-sd
Device = FileStorage
Address = 192.168.2.230
SDPort = 9103
Password = "bacula"
Media Type = File
}
Job {
Name = Windows
Enabled = Yes
Level = Full
Type = Backup
Client = Windows
FileSet = Windows # Arquivo onde indica os arquivos a serem backupeados#
Storage = alysson-sd
Schedule = "Windows"
Pool = Default
Messages = Mensagens
Priority = 10
Write Bootstrap = "/var/bacula/working/Windows.bsr"
}
Job {
Name = Linux
Enabled = Yes
Level = Full
Type = Backup
Client = Linux
FileSet = Linux
Storage = alysson-sd
Schedule = "Linux"
Pool = Default
Messages = Mensagens
Priority = 10
Write Bootstrap = "/var/bacula/working/Linux.bsr"
}
Job {
Name = Restore_Linux
Type = Restore
Client = Linux
FileSet = Linux
Storage = alysson-sd
Messages = Mensagens
Pool = Linux
Where = /tmp/bacula-restores
}
Job {
Name = Restore_Windows
Type = Restore
Client = Windows
FileSet = Windows
Storage = alysson-sd
Messages = Mensagens
Where = c:/windows/temp/bacula-restores
Pool = Windows
}
Messages {
Name = Mensagens
# Envia todas as mensagens geradas pelo Bacula para o arquivo
#/var/log/bacula.log
syslog = all, !skipped, !saved
}
[10] Comentário enviado por riva em 19/03/2010 - 15:45h
Segue abaixo o meu bacula-dir.conf
Director { # define myself
Name = Slack_BKP-dir
DIRport = 9101 # where we listen for UA connections
QueryFile = "/etc/bacula/query.sql"
WorkingDirectory = "/var/bacula/working"
PidDirectory = "/var/run"
Maximum Concurrent Jobs = 1
Password = "123456" # Console password
# Messages = Daemon
}
Schedule {
Name = "Diario"
Run = Level = Full Pool = SegundaPool Monday at 12:00am
Run = Level = Full Pool = TercaPool Tuesday at 12:00am
Run = Level = Full Pool = QuartaPool Wednesday at 12:00am
Run = Level = Full Pool = QuintaPool Thursday at 12:00am
Run = Level = Full Pool = SextaPool Friday at 12:00am
}
Job {
Name = "Slack_BKP"
Type = Backup
Level = Full
Client = Slack_BKP-fd
FileSet = "Slack_BKP"
Messages = Standard
Storage = FileStorage_s
Pool = Default
Schedule = "Diario"
Write Bootstrap = "/var/bacula/working/Slack_BKP.bsr"
Priority = 10
}
Job {
Name = "lara"
Type = Backup
Level = Full
Client = lara-fd
FileSet = "lara"
Messages = Standard
Storage = FileStorage_l
Pool = Default
Schedule = "Diario"
Write Bootstrap = "/var/bacula/working/lara.bsr"
Priority = 10
}
Job {
Name = "rnl050"
Type = Backup
Level = Full
Client = rnl050-fd
FileSet = "rnl050"
Messages = Standard
Storage = FileStorage_r
Pool = Default
Schedule = "Diario"
Write Bootstrap = "/var/bacula/working/rnl050.bsr"
Priority = 10
}
Job {
Name = "rnl-ti1"
Type = Backup
Level = Full
Client = rnl-ti1-fd
FileSet = "rnl-ti1"
Messages = Standard
Storage = FileStorage_ti1
Pool = Default
Schedule = "Diario"
Write Bootstrap = "/var/bacula/working/rnl050.bsr"
Priority = 10
}
Job {
Name = "RestoreFiles_s"
Type = Restore
Client = Slack_BKP-fd
FileSet = "Slack_BKP"
Storage = FileStorage_s
Messages = Standard
Pool = Default
Where = /tmp/bacula-restores
}
Job {
Name = "RestoreFiles_l"
Type = Restore
Client = lara-fd
FileSet = "lara"
Storage = FileStorage_l
Messages = Standard
Pool = Default
Where = ""
}
Job {
Name = "RestoreFiles_r"
Type = Restore
Client = rnl050-fd
FileSet = "rnl050"
Storage = FileStorage_r
Messages = Standard
Pool = Default
Where = ""
}
Job {
Name = "RestoreFiles_ti1"
Type = Restore
Client = rnl-ti1-fd
FileSet = "rnl-ti1"
Storage = FileStorage_ti1
Messages = Standard
Pool = Default
Where = ""
}
FileSet {
Name = "Slack_BKP"
Include {
Options {
signature = MD5
}
File = /sbin
}
}
FileSet {
Name = "lara"
Include {
Options{
signature = MD5
}
File = "G:/teste_bkp1"
}
}
FileSet {
Name = "rnl050"
Include {
Options {
signature = MD5
}
File = "F:/OLD"
}
}
FileSet {
Name = "rnl-ti1"
Include {
Options {
signature = MD5
}
File = "C:/tst_bacula"
}
}
FileSet {
Name = "Full Set"
Include {
Options {
signature = MD5
}
# @/etc/backup.list
}
}
Storage {
Name = FileStorage_s
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_s
Media Type = File
}
Storage {
Name = FileStorage_l
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_l
Media Type = File
}
Storage {
Name = FileStorage_r
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_r
Media Type = File
}
Storage {
Name = FileStorage_ti1
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_ti1
Media Type = File
}
[11] Comentário enviado por prgs.linux em 22/03/2010 - 10:34h
Riva, desculpe a demora para responder...
manu quando vc chama o bconsole
# bconsole -c /etc/bacula/bconsole.conf
*restore
1 ## Lista o JOB
12 ## Restore
10 ## Job Selecionado, a partir do JOB listado no comando 1
mark * ## marca todos pacote
done ## Sai do console
1 ## Marca o cliente a ser restaurado
verifique se no diretorio temporario onde o bacula guarda os backups está com permissao de escrita... e se tem algum trabalho salvo la e o tamanho desse arquivo condiz com o backup realizado
[12] Comentário enviado por riva em 22/03/2010 - 16:08h
Paulo, não esquenta com demora não, ajude quando der.
o restore é realizado na máquina remota.
abaixo segue o log de restore dos dois servidores, em um o restore foi OK, no outro não. Segue também o arquivo de configuração bacula-dir.conf mais enxuto, com a configuarção só destes dois clientes (servidor 1 (rnl050-fd), eo servidor 2 (lara-fd), o restore do servidor 1 que deu pau.
O backup funciona certinho, o Schedule também funciona, só o restore que está com pau.
22-Mar 15:38 Slack_BKP-dir JobId 5: Begin pruning Jobs older than 1 month .
22-Mar 15:38 Slack_BKP-dir JobId 5: No Jobs found to prune.
22-Mar 15:38 Slack_BKP-dir JobId 5: Begin pruning Jobs.
22-Mar 15:38 Slack_BKP-dir JobId 5: No Files found to prune.
22-Mar 15:38 Slack_BKP-dir JobId 5: End auto prune.
servidor 2 :
22-Mar 15:18 Slack_BKP-dir JobId 3: Start Restore Job RestoreFiles_l.2010-03-22_15.18.14_04
22-Mar 15:18 Slack_BKP-dir JobId 3: Using Device "FileStorage_l"
22-Mar 15:18 Slack_BKP-sd JobId 3: Ready to read from volume "bkp_diario_l_0001" on device "FileStorage_l" (/mnt/bacula/COMUM).
22-Mar 15:18 Slack_BKP-sd JobId 3: Forward spacing Volume "bkp_diario_l_0001" to file:block 0:216.
22-Mar 15:19 Slack_BKP-sd JobId 3: End of Volume at file 0 on device "FileStorage_l" (/mnt/bacula/COMUM), Volume "bkp_diario_l_0001"
22-Mar 15:19 Slack_BKP-sd JobId 3: End of all volumes.
22-Mar 15:19 Slack_BKP-dir JobId 3: Bacula Slack_BKP-dir 5.0.1 (24Feb10): 22-Mar-2010 15:19:20
Build OS: i686-pc-linux-gnu slackware Slackware 13.0.0.0.0
JobId: 3
Job: RestoreFiles_l.2010-03-22_15.18.14_04
Restore Client: lara-fd
Start time: 22-Mar-2010 15:18:16
End time: 22-Mar-2010 15:19:20
Files Expected: 6,503
Files Restored: 6,503
Bytes Restored: 170,924,967
Rate: 2670.7 KB/s
FD Errors: 0
FD termination status: OK
SD termination status: OK
Termination: Restore OK
22-Mar 15:19 Slack_BKP-dir JobId 3: Begin pruning Jobs older than 1 month .
22-Mar 15:19 Slack_BKP-dir JobId 3: No Jobs found to prune.
22-Mar 15:19 Slack_BKP-dir JobId 3: Begin pruning Jobs.
22-Mar 15:19 Slack_BKP-dir JobId 3: No Files found to prune.
22-Mar 15:19 Slack_BKP-dir JobId 3: End auto prune.
bacula-dir.conf :
Director { # define myself
Name = Slack_BKP-dir
DIRport = 9101 # where we listen for UA connections
QueryFile = "/etc/bacula/query.sql"
WorkingDirectory = "/var/bacula/working"
PidDirectory = "/var/run"
Maximum Concurrent Jobs = 10
Password = "123456" # Console password
Messages = Standard
}
Schedule {
Name = "Diario_lara"
Run = Level = Full Pool = Diario_Pool_l mon-fri at 15:10
}
Schedule {
Name = "Diario_rnl050"
Run = Level = Full Pool = Diario_Pool_r mon-fri at 15:26
}
Job {
Name = "lara"
Enabled = Yes
Type = Backup
Level = Full
Client = lara-fd
FileSet = "lara"
Messages = Standard
Storage = FileStorage_l
Pool = Diario_Pool_l
Schedule = "Diario_lara"
Write Bootstrap = "/var/bacula/working/lara.bsr"
Priority = 10
}
Job {
Name = "rnl050"
Enabled = Yes
Type = Backup
Level = Full
Client = rnl050-fd
FileSet = "rnl050"
Messages = Standard
Storage = FileStorage_r
Pool = Diario_Pool_r
Schedule = "Diario_rnl050"
Write Bootstrap = "/var/bacula/working/rnl050.bsr"
Priority = 10
}
Job {
Name = "RestoreFiles_l"
Type = Restore
Client = lara-fd
FileSet = "lara"
Storage = FileStorage_l
Messages = Standard
Pool = Diario_Pool_l
Where = ""
}
Job {
Name = "RestoreFiles_r"
Type = Restore
Client = rnl050-fd
FileSet = "rnl050"
Storage = FileStorage_r
Messages = Standard
Pool = Diario_Pool_r
Where = ""
}
FileSet {
Name = "lara"
Include {
Options{
signature = MD5
}
File = "G:/teste_bkp1"
}
}
FileSet {
Name = "rnl050"
Include {
Options {
signature = MD5
}
File = "F:/OLD"
}
}
Storage {
Name = FileStorage_l
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_l
Media Type = File
}
Storage {
Name = FileStorage_r
Address = 192.168.155.183
SDPort = 9103
Password = "123456"
Device = FileStorage_r
Media Type = File
}
[13] Comentário enviado por tiago.pacato em 25/03/2010 - 10:14h
Instalei o servidor bacula em uma maquina normal com hds de 250 gb, os backups estão sendo feitos normalmente, os catalagos criados, tudo ok. a dúvida é, para passar os backups que ja foram feitos nessa maquina para uma maquina nova que acabamos de adquirir, o que eu poderia fazer? para não perder o que ja foi feito no servidor bacula antigo.
[14] Comentário enviado por prgs.linux em 26/03/2010 - 15:05h
Thiago , vou ser sincero.. ainda nao fiz esse teste. Poderia tentar restaurar esses arquivos em uma maquina XYX, e logo após envia-los para o novo servidor, se por acaso eu descobrir como voçê envia essas informaçoes para o bacula eu posto aqui, mesmo por que nao será tarefa muito simples , uma vez que ele guarda as referencias dele num banco de dados MYSQL.
Só que num estar fazendo o backup :S
quando tento a forma manual com o bconsole -c /etc/bacula/bconsole.conf
da esse erro.
Connecting to Director debian:9101
08-Abr 13:28 bconsole JobId 0: Fatal error: bsock.c:129 Unable to connect to Director daemon on debian:9101. ERR=Conexão recusada
bacula-dir.conf
Director { # define myself
Name = debian-dir
DIRport = 9101 # where we listen for UA connections
QueryFile = "/etc/bacula/scripts/query.sql"
WorkingDirectory = "/var/lib/bacula"
PidDirectory = "/var/run/bacula"
Maximum Concurrent Jobs = 20
Password = "123" # Console password
Messages = Mensagens
}
Client {
Name = Linux_Client_Debian
Address = 10.68.16.26
FDPort = 9102
Catalog = MyCatalog
Password = "123" # password for FileDaemon
File Retention = 30 days # 30 days
Job Retention = 30 months # six months
AutoPrune = yes # Prune expired Jobs/Files
}
Pool {
Name = Default
Pool Type = Backup
Recycle = yes # Bacula can automatically recycle Volumes
AutoPrune = yes # Prune expired volumes
Volume Retention = 1d # one year
}
Pool {
Name = SegundaPoolDebian
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderáer utilizado novamente
Maximum Volume Jobs = 10
Maximum Volumes = 10
Label Format = "Segunda_Debian"
}
Pool {
Name = TercaPoolDebian
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderáer utilizado novamente
Maximum Volume Jobs = 10
Maximum Volumes = 10
Label Format = "Terca_Debian"
}
Pool {
Name = QuartaPoolDebian
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderáer utilizado novamente
Maximum Volume Jobs = 10
Maximum Volumes = 10
Label Format = "Quarta_Debian"
}
Pool {
Name = QuintaPoolDebian
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderáer utilizado novamente
Maximum Volume Jobs = 10
Maximum Volumes = 10
Label Format = "Quinta_Debian"
}
Pool {
Name = SextaPoolDebian
Pool Type = Backup
Recycle = yes
AutoPrune = yes
Volume Retention = 6d # o volume poderáer utilizado novamente
Maximum Volume Jobs = 10
Maximum Volumes = 10
Label Format = "Sexta_Debian"
}
Schedule {
Name = "Diario_Debian"
Run = Level=Full Pool=SegundaPoolDebian Monday at 12:00pm
Run = Level=Full Pool=TercaPoolDebian Tuesday at 12:00pm
Run = Level=Full Pool=QuartaPoolDebian Wednesday at 12:00pm
Run = Level=Full Pool=QuintaPoolDebian Thursday at 12:00pm
Run = Level=Full Pool=SextaPoolDebian Friday at 12:00pm
}
Job {
Name = Restore_Linux_Debian
Type = Restore
Client = Linux_Client_Debian
FileSet = Linux_File_Debian
Storage = FileStorage
Messages = Mensagens
Pool = Default
Where = /tmp/bacula-restores
}
Messages {
Name = Mensagens
# Envia todas as mensagens geradas pelo Bacula para o arquivo
#/var/log/bacula.log
syslog = all, !skipped, !saved
}
===============
bacula-sd.conf
Storage { # definition of myself
Name = debian-dir
SDPort = 9103 # Director's port
WorkingDirectory = "/var/lib/bacula"
Pid Directory = "/var/run/bacula"
Maximum Concurrent Jobs = 20
}
Director {
Name = debian-dir
Password = "123"
}
Device {
Name = "FileStorage"
Media Type = File
Archive Device = /tmp/bacula
LabelMedia = yes; # lets Bacula label unlabeled media
Random Access = Yes;
AutomaticMount = yes; # when device opened, read it
RemovableMedia = no;
AlwaysOpen = no;
}
Messages {
Name = Standard
director = debian-dir = all
# operator = root = mount
}
=========================
bacula-fd.conf
Director {
Name = debian-dir
Password = "123"
}
FileDaemon { # this is me
Name = debian-fd
FDport = 9102 # where we listen for the director
WorkingDirectory = /var/lib/bacula
Pid Directory = /var/run/bacula
Maximum Concurrent Jobs = 1
}
Messages {
Name = Standard
director = debian-dir = all, !skipped !restored
}
========================
bconsole.conf
Director {
Name = debian-dir
DIRport = 9101
address = debian
Password = "123"
[16] Comentário enviado por LinuxTec em 15/04/2010 - 08:48h
Bom dia amigo, antes de tudo gostaria de agradecer a sua contribuição com a VOL e que Deus te ilumine sempre, será que podia me ajudar, administro uma rede e me deparei com o bacula, tenho 4 Clientes nele, Backup, Firewall, Mail, Samba tudo funcionando normal, quando adcionei meu server de aplicação chamado sistemas ele ta pau na comunicação com o bacula-fd.conf mais está identica a dos outros server que está funcionando poderia me dar uma luz, estou oline das 07:30 as 18:00, MSN Claudio@linuxtec.com.br.
Vou passar o erro que dispara por email:
12-Apr 20:30 backup-dir JobId 1511: No prior Full backup Job record found.
12-Apr 20:30 backup-dir JobId 1511: No prior or suitable Full backup found in catalog. Doing FULL backup.
12-Apr 20:30 backup-dir JobId 1511: Start Backup JobId 1511, Job=sistemas.2010-04-12_20.30.00.05
12-Apr 20:30 backup-dir JobId 1511: Using Device "FileStorage"
12-Apr 20:30 sistemas-fd JobId 1511: Fatal error: Failed to connect to Storage daemon: backup:9103
12-Apr 20:30 sistemas-fd JobId 1511: Error: bsock.c:182 gethostbyname() for host "backup" failed: ERR=Non-recoverable errors, FORMERR, REFUSED, or NOTIMP.
12-Apr 20:30 backup-dir JobId 1511: Fatal error: Socket error on Storage command: ERR=No data available
12-Apr 20:30 backup-dir JobId 1511: Error: Bacula backup-dir 2.4.4 (28Dec08): 12-Apr-2010 20:30:02
Build OS: i486-pc-linux-gnu debian 5.0
JobId: 1511
Job: sistemas.2010-04-12_20.30.00.05
Backup Level: Full (upgraded from Incremental)
Client: "sistemas-fd" 2.4.4 (28Dec08) i486-pc-linux-gnu,debian,5.0
FileSet: "sistemas" 2010-03-09 20:30:00
Pool: "Full-Pool-sistemas" (From Job FullPool override)
Storage: "File" (From Job resource)
Scheduled time: 12-Apr-2010 20:30:00
Start time: 12-Apr-2010 20:30:02
End time: 12-Apr-2010 20:30:02
Elapsed time: 0 secs
Priority: 10
FD Files Written: 0
SD Files Written: 0
FD Bytes Written: 0 (0 B)
SD Bytes Written: 0 (0 B)
Rate: 0.0 KB/s
Software Compression: None
VSS: no
Storage Encryption: no
Volume name(s):
Volume Session Id: 3
Volume Session Time: 1271079565
Last Volume Bytes: 0 (0 B)
Non-fatal FD errors: 0
SD Errors: 0
FD termination status:
SD termination status: Waiting on FD
Termination: *** Backup Error ***
[17] Comentário enviado por LinuxTec em 05/05/2010 - 10:34h
Cara vi seu post e acho que pode me ajudar, sou iniciante com bacula e estava sem espaço no meu server, dentro de /home/backup é onde ele guarda os jobs e backups que roda na madrugada eu deletei varios para ganhar espaço após isso 3 serves ao tentar coletar o bacup das partições da o seguinte erro.
Assunto: Bacula: Intervention needed for samba.2010-05-05_10.22.00.02
Corpo do Email:
05-May 10:22 backup-sd JobId 1632: Job samba.2010-05-05_10.22.00.02 waiting. Cannot find any appendable volumes.
Please use the "label" command to create a new Volume for:
Storage: "FileStorage" (/home/backup)
Pool: Full-Pool-samba
Media type: File
Ou seja ele diz que o trabalho foi interrompido pois, Trabalho espera samba.2010-05-05_10.22.00.02. Não é
possível encontrar todos os volumes adicionável.
Eu devo criar um volume chamado samba.2010-05-05_10.22.00.02 é isso e como crio no bconsole
[19] Comentário enviado por parrera em 08/10/2010 - 10:15h
Muito bom tutorial.
Estou instalando o bacula em um servidor de arquivos(Maquina1), ela será simultaneamente catalogo, storage e cliente. Será cliente pq só o
conteúdo dela é que me interessa backupiar. É storage espelhados pq têm um segundo disco(Maquina2) onde o primeiro disco das duas máquinas foi bakupiado. É catalogos espelhados para aumentar a disponibilidade e tolerância a falha do sistema de backup do meu laboratório. Se uma das máquinas cair, seja a Maquina1 ou a Maquina2, a outra continuará mantendo o serviço de backup.
Deu pra entender pessoal?
Tenho uma maquina(Maquina1) que quero fazer o backup de um HD dela, esta maquina possui um outro HD o qual sera armazenado o backup e uma outra maquina na rede(Maquina2) terá um outro HD que será espelho desse HD de backup da Maquina1.
Minha pergunta é a seguinte, nas duas maquinas devo configurar os arquivos bacula-dir.conf, bacula-fd.conf, bacula-sd.conf e bconsole.conf? Como implemento esse espelhamento dos 2 HD's que ficarão para backup(2 maquinas distintas, uma é cliente dela mesma e a outra só tem um HD para caso de falha de alguma das 2 máquinas)?
[21] Comentário enviado por diegop em 28/09/2011 - 15:07h
Boa tarde galera, muito bom esse seu tutorial Paulo, parabéns.
Consegui instalar e configurar o bacula, o backup funciona normalmente, mas o restore não, pode me ajudar? Não sei o que estou fazendo de errado.
Segue meu bacula-dir.conf:
Director {
Name = alpha-dir
DIRport = 9101
QueryFile = "/etc/bacula/scripts/query.sql"
WorkingDirectory = "/var/lib/bacula"
PidDirectory = "/var/run/bacula"
Maximum Concurrent Jobs = 1
Password = "admin"
Messages = Daemon
}
JobDefs {
Name = "DefaultJob"
Type = Backup
Level = Incremental
Client = alpha-fd
FileSet = "file-dados"
Schedule = "diario"
Storage = storage
Messages = Standard
Pool = pool-dados
Priority = 10
}
############## BACKUPS DADOS ################
Job {
Name = "backup-diario-dados"
Type = Backup
Client = alpha-fd
Level = Incremental
FileSet="file-dados"
Schedule = "diario"
Storage = storage
Messages = Standard
Pool = pool-dados
Priority = 10
}
Job {
Name = "backup-mensal-dados"
Type = Backup
Client = alpha-fd
Level = Full
FileSet="file-dados"
Schedule = "mensal"
Storage = storage
Messages = Standard
Pool = pool-dados
Priority = 10
}
############## BACKUPS BANCO ################
Job {
Name = "backup-diario-banco"
Type = Backup
Client = alpha-fd
Level = Incremental
FileSet="file-banco"
Schedule = "diario"
Storage = storage
Messages = Standard
Pool = pool-banco
Priority = 11
RunBeforeJob = "/etc/bacula/scripts/make_catalog_backup bacula bacula"
RunAfterJob = "/etc/bacula/scripts/delete_catalog_backup"
Write Bootstrap = "/var/lib/bacula/BackupCatalog.bsr"
}
Job {
Name = "backup-mensal-banco"
Type = Backup
Client = alpha-fd
Level = Full
FileSet="file-banco"
Schedule = "mensal"
Storage = storage
Messages = Standard
Pool = pool-banco
Priority = 11
RunBeforeJob = "/etc/bacula/scripts/make_catalog_backup bacula bacula"
RunAfterJob = "/etc/bacula/scripts/delete_catalog_backup"
Write Bootstrap = "/var/lib/bacula/BackupCatalog.bsr"
}
############## RESTORES ################
Job {
Name = "restore-dados"
Type = Restore
Client=alpha-fd
FileSet="file-dados"
Storage = storage
Pool = pool-dados
Messages = Standard
Where = /restore/dados
}
Job {
Name = "restore-banco"
Type = Restore
Client=alpha-fd
FileSet="file-banco"
Storage = storage
Pool = pool-banco
Messages = Standard
Where = /restore/banco
}