Date: Thu, 03 Jul 2008 19:59:58 +0300 From: "Ivaylo Bonev" <ibb_orac@mbox.contact.bg> To: "freebsd-questions@freebsd.org" <freebsd-questions@freebsd.org> Subject: FreeBSD and Bacula Message-ID: <op.udp6sbun7237r4@laptop>
index | next in thread | raw e-mail
[-- Attachment #1 --] I want to use FreeBSD 7.0 for Backup server. After little searching, my decision was to use Bacula (because of Windows client). After installation of latest version (Bacula 2.4.0) and active googling, reading very carefuly Onlamp article of Bacula server on FreeBSD (http://www.onlamp.com/pub/a/onlamp/2004/01/09/bacula.html) and configuring File, Storage and Director files, I was astonished by the fact that Bacula cannot start from provided scripts in /usr/local/etc/rc.d/ directory. No messages in log, no error messages in console, ps aux| grep 'bacula' say nothing, nothing! I put bacula_dir_enable="YES" bacula_fd_enable="YES" bacula_sd_enable="YES" and after restart on console shows this error: 03-Jul 17:09 bacula-dir: ERROR TERMINATION at parse_conf.c:483 Config error: Could not find config Resource bacula-fd referenced on line 30 : Client = bacula-fd : line 30, col 20 of file /usr/local/etc/bacula-dir.conf Client = bacula-fd All Bacula .conf files are attached. Is there a bug, or misconfigured .conf files? -- Windows: "Where do you want to go today?" Linux: "Where do you want to go tomorrow?" FreeBSD: "Are you guys coming, or what?" [-- Attachment #2 --] Storage { # definition of myself Name = laptop-sd SDPort = 9103 # Director's port WorkingDirectory = "/var/db/bacula" Pid Directory = "/var/run" Maximum Concurrent Jobs = 20 } # # List Directors who are permitted to contact Storage daemon # Director { Name = laptop-dir Password = "proba" } # # Restricted Director, used by tray-monitor to get the # status of the storage daemon # Director { Name = bacula-mon Password = "proba" Monitor = no } # # Devices supported by this Storage daemon # To connect, the Director's bacula-dir.conf must have the # same Name and MediaType. # Device { Name = FileStorage Media Type = File Archive Device = /tmp LabelMedia = yes; # lets Bacula label unlabeled media Random Access = Yes; AutomaticMount = yes; # when device opened, read it RemovableMedia = no; AlwaysOpen = no; } # Send all messages to the Director, # mount messages also are sent to the email address # Messages { Name = Standard director = laptop-dir = all } [-- Attachment #3 --] # # Default Bacula Director Configuration file # # The only thing that MUST be changed is to add one or more # file or directory names in the Include directive of the # FileSet resource. # # For Bacula release 2.4.0 (04 June 2008) -- freebsd 7.0-RELEASE # # You might also want to change the default email address # from root to your address. See the "mail" and "operator" # directives in the Messages resource. # Director { # define myself Name = laptop-dir DIRport = 9101 # where we listen for UA connections QueryFile = "/usr/local/share/bacula/query.sql" WorkingDirectory = "/var/db/bacula" PidDirectory = "/var/run" Maximum Concurrent Jobs = 1 Password = "proba" # Console password Messages = Daemon } JobDefs { Name = "DefaultJob" Type = Backup Level = Incremental Client = bacula-fd FileSet = "Full Set" Schedule = "WeeklyCycle" Storage = File Messages = Standard Pool = Default Priority = 10 } # # Define the main nightly save backup job # By default, this job will back up to disk in Job { Name = "Client1" JobDefs = "DefaultJob" Write Bootstrap = "/var/db/bacula/Client1.bsr" } #Job { # Name = "Client2" # Client = bacula2-fd # JobDefs = "DefaultJob" # Write Bootstrap = "/var/db/bacula/Client2.bsr" #} # Backup the catalog database (after the nightly save) Job { Name = "BackupCatalog" JobDefs = "DefaultJob" Level = Full FileSet="Catalog" Schedule = "WeeklyCycleAfterBackup" # This creates an ASCII copy of the catalog # WARNING!!! Passing the password via the command line is insecure. # see comments in make_catalog_backup for details. # Arguments to make_catalog_backup are: # make_catalog_backup <database-name> <user-name> <password> <host> RunBeforeJob = "/usr/local/share/bacula/make_catalog_backup bacula bacula" # This deletes the copy of the catalog RunAfterJob = "/usr/local/share/bacula/delete_catalog_backup" Write Bootstrap = "/var/db/bacula/BackupCatalog.bsr" Priority = 11 # run after main backup } # # Standard Restore template, to be changed by Console program # Only one such job is needed for all Jobs/Clients/Storage ... # Job { Name = "RestoreFiles" Type = Restore Client=bacula-fd FileSet="Full Set" Storage = File Pool = Default Messages = Standard Where = /bacula-restores } # List of files to be backed up FileSet { Name = "Full Set" Include { Options { signature = MD5 } # # Put your list of files here, preceded by 'File =', one per line # or include an external list with: # # File = <file-name # # Note: / backs up everything on the root partition. # if you have other partitons such as /usr or /home # you will probably want to add them too. # # By default this is defined to point to the Bacula build # directory to give a reasonable FileSet to backup to # disk storage during initial testing. # File = /usr/ports/sysutils/bacula-server/work/bacula-2.4.0 } # # If you backup the root directory, the following two excluded # files can be useful # Exclude { File = /proc File = /tmp File = /.journal File = /.fsck } } # # When to do the backups, full backup on first sunday of the month, # differential (i.e. incremental since full) every other sunday, # and incremental backups other days Schedule { Name = "WeeklyCycle" Run = Full 1st sun at 23:05 Run = Differential 2nd-5th sun at 23:05 Run = Incremental mon-sat at 23:05 } # This schedule does the catalog. It starts after the WeeklyCycle Schedule { Name = "WeeklyCycleAfterBackup" Run = Full sun-sat at 23:10 } # This is the backup of the catalog FileSet { Name = "Catalog" Include { Options { signature = MD5 } File = /var/db/bacula/bacula.sql } } # Client (File Services) to backup Client { Name = laptop-fd Address = bacula.ameta FDPort = 9102 Catalog = MyCatalog Password = "proba" # password for FileDaemon File Retention = 30 days # 30 days Job Retention = 6 months # six months AutoPrune = yes # Prune expired Jobs/Files } # # Second Client (File Services) to backup # You should change Name, Address, and Password before using # #Client { # Name = bacula2-fd # Address = bacula2 # FDPort = 9102 # Catalog = MyCatalog # Password = "j5aWmAynUGdJTqz5IaxrvAA6ALeOfk4LYhDWNTPciC2W2" # password for FileDaemon 2 # File Retention = 30 days # 30 days # Job Retention = 6 months # six months # AutoPrune = yes # Prune expired Jobs/Files #} # Definition of file storage device Storage { Name = File # Do not use "localhost" here Address = bacula.ameta # N.B. Use a fully qualified name here SDPort = 9103 Password = "proba" Device = FileStorage Media Type = File } # Definition of DDS tape storage device #Storage { # Name = DDS-4 # Do not use "localhost" here # Address = bacula # N.B. Use a fully qualified name here # SDPort = 9103 # Password = "5PwFr00qCFgwW9iSXeNHzRXza5QP1clbgVrGW2cQr4WL" # password for Storage daemon # Device = DDS-4 # must be same as Device in Storage daemon # Media Type = DDS-4 # must be same as MediaType in Storage daemon # Autochanger = yes # enable for autochanger device #} # Definition of 8mm tape storage device #Storage { # Name = "8mmDrive" # Do not use "localhost" here # Address = bacula # N.B. Use a fully qualified name here # SDPort = 9103 # Password = "5PwFr00qCFgwW9iSXeNHzRXza5QP1clbgVrGW2cQr4WL" # Device = "Exabyte 8mm" # MediaType = "8mm" #} # Definition of DVD storage device #Storage { # Name = "DVD" # Do not use "localhost" here # Address = bacula # N.B. Use a fully qualified name here # SDPort = 9103 # Password = "5PwFr00qCFgwW9iSXeNHzRXza5QP1clbgVrGW2cQr4WL" # Device = "DVD Writer" # MediaType = "DVD" #} # Generic catalog service Catalog { Name = MyCatalog dbname = bacula; user = bacula; password = "" } # Reasonable message delivery -- send most everything to email address # and to the console Messages { Name = Standard # # NOTE! If you send to two email or more email addresses, you will need # to replace the %r in the from field (-f part) with a single valid # email address in both the mailcommand and the operatorcommand. # What this does is, it sets the email address that emails would display # in the FROM field, which is by default the same email as they're being # sent to. However, if you send email to more than one address, then # you'll have to set the FROM address manually, to a single address. # for example, a 'no-reply@mydomain.com', is better since that tends to # tell (most) people that its coming from an automated source. # mailcommand = "/usr/local/sbin/bsmtp -h localhost -f \"\(Bacula\) \<%r\>\" -s \"Bacula: %t %e of %c %l\" %r" operatorcommand = "/usr/local/sbin/bsmtp -h localhost -f \"\(Bacula\) \<%r\>\" -s \"Bacula: Intervention needed for %j\" %r" mail = root@localhost = all, !skipped operator = root@localhost = mount console = all, !skipped, !saved # # WARNING! the following will create a file that you must cycle from # time to time as it will grow indefinitely. However, it will # also keep all your messages if they scroll off the console. # append = "/var/db/bacula/log" = all, !skipped } # # Message delivery for daemon messages (no job). Messages { Name = Daemon mailcommand = "/usr/local/sbin/bsmtp -h localhost -f \"\(Bacula\) \<%r\>\" -s \"Bacula daemon message\" %r" mail = root@localhost = all, !skipped console = all, !skipped, !saved append = "/var/db/bacula/log" = all, !skipped } # Default pool definition Pool { Name = Default Pool Type = Backup Recycle = yes # Bacula can automatically recycle Volumes AutoPrune = yes # Prune expired volumes Volume Retention = 365 days # one year } # Scratch pool definition Pool { Name = Scratch Pool Type = Backup } # # Restricted console used by tray-monitor to get the status of the director # Console { Name = bacula-mon Password = "ZTYux9C6Wf2vM0VSooFEMKlzTv9bdAx2tUf7G9rMexOE" CommandACL = status, .status } [-- Attachment #4 --] # # List Directors who are permitted to contact this File daemon # Director { Name = laptop-dir Password = "proba" } # # Restricted Director, used by tray-monitor to get the # status of the file daemon # Director { Name = bacula-mon Password = "proba" Monitor = no } # # "Global" File daemon configuration specifications # FileDaemon { # this is me Name = laptop-fd FDport = 9102 # where we listen for the director WorkingDirectory = /var/db/bacula Pid Directory = /var/run Maximum Concurrent Jobs = 20 } # Send all messages except skipped files back to Director Messages { Name = Standard director = laptop-dir = all, !skipped, !restored }help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?op.udp6sbun7237r4>
