]> git.sur5r.net Git - bacula/docs/blob - docs/manuals/en/problems/faq.tex
Apply improvement to FAQ on authorization errors bug #2185
[bacula/docs] / docs / manuals / en / problems / faq.tex
1 %%
2 %%
3 % TODO: maybe merge all this FAQ in with the appropriate section?
4 % TODO: and use detailed indexing to help reader
5
6 \chapter{Bacula Frequently Asked Questions}
7 \label{FaqChapter}
8 \index[general]{Questions!Bacula Frequently Asked }
9 \index[general]{Bacula Frequently Asked Questions }
10
11 These are questions that have been submitted over time by the
12 Bacula users. The following
13 FAQ is very useful, but it is not always up to date 
14 with newer information, so after reading it, if you don't find what you 
15 want, you might try the Bacula wiki maintained by Frank Sweetser, which
16 contains more than just a FAQ:
17 \elink{http://wiki.bacula.org}{http://wiki.bacula.org}
18 or go directly to the FAQ at: 
19 \elink{http://wiki.bacula.org/doku.php?id=faq}{http://wiki.bacula.org/doku.php?id=faq}.
20
21 Please also see
22 \borgxrlink{the bugs}{BugsChapter}{main}{section} of the \mainman{} for a list of known bugs and solutions.
23
24 \begin{description}
25 \label{what}
26 \section{What is Bacula?}
27 \item [What is {\bf Bacula}? ]
28    \index[general]{What is Bacula? }
29    {\bf Bacula} is a network backup and restore program. 
30
31 \section{Does Bacula support Windows?}
32 \item [Does Bacula support Windows?]
33 \index[general]{Does Bacula support Windows? }
34    Yes, Bacula compiles and runs on Windows machines (Win98, WinMe, WinXP,
35    WinNT, Win2003, and Win2000).  We provide a binary version of the Client
36    (bacula-fd), but have not tested the Director nor the Storage daemon.
37    Note, Win95 is no longer supported because it doesn't have the
38    GetFileAttributesExA API call.
39  
40
41 \label{lang}
42 \section{What language is Bacula written in?}
43 \item [What language is Bacula written in?]
44 \index[general]{What language is Bacula written in? }
45    It is written in C++, but it is mostly C  code using only a limited set of
46    the C++ extensions  over C.  Thus Bacula is completely  compiled using the
47    C++ compiler. There are several modules, including the Win32 interface, that
48    are written using the  object oriented C++ features. Over time, we are slowly
49    adding a larger  subset of C++.  
50
51 \label{run}
52 \section{On what machines does Bacula run?}
53 \item [On what machines does Bacula run? ]
54    \index[general]{On what machines does Bacula run? }
55    {\bf Bacula} builds and executes on Red Hat Linux (versions RH7.1-RHEL
56    4.0, Fedora, SuSE, Gentoo, Debian, Mandriva, ...), FreeBSD, Solaris,
57    Alpha, SGI (client), NetBSD, OpenBSD, Mac OS X (client), and Win32.
58
59    Bacula has been my only backup tool for over seven years backing up 8
60    machines nightly (6 Linux boxes running SuSE, previously
61    Red Hat and Fedora, a WinXP machine, and a WinNT machine).
62  
63
64 \label{stable}
65 \section{Is Bacula Stable?}
66 \item [Is Bacula Stable? ]
67 \index[general]{Is Bacula Stable? }
68    Yes, it is remarkably stable, but remember, there are still a lot of
69    unimplemented or partially implemented features.  With a program of this
70    size (150,000+ lines of C++ code not including the SQL programs) there
71    are bound to be bugs.  The current test environment (a twisted pair
72    local network and a HP DLT backup tape) is not exactly ideal, so
73    additional testing on other sites is necessary.  The File daemon has
74    never crashed -- running months at a time with no intervention.  The
75    Storage daemon is remarkably stable with most of the problems arising
76    during labeling or switching tapes.  Storage daemon crashes are rare
77    but running multiple drives and simultaneous jobs sometimes (rarely)
78    problems.
79    The Director, given the multitude of functions it fulfills is also
80    relatively stable.  In a production environment, it rarely if ever
81    crashes.  Of the three daemons, the Director is the most prone to having
82    problems.  Still, it frequently runs several months with no problems.
83
84    There are a number of reasons for this stability.  
85
86    \begin{enumerate}
87    \item  The program is constantly checking the chain of allocated
88       memory buffers to ensure that no overruns have occurred.  \\
89    \item All  memory leaks (orphaned buffers) are reported each time the
90       program  terminates.\\
91    \item Any signal (segmentation fault, ...) generates a 
92       traceback that is emailed to the developer.  This permits quick
93       resolution of bugs even if they only show up rarely in a production
94       system.\\
95    \item There is a reasonably comprehensive set of regression tests
96       that avoids re-creating the most common errors in new versions of
97       Bacula.
98    \end{enumerate}
99
100 \label{AuthorizationErrors}
101 \section{I'm Getting Authorization Errors. What is Going On? }
102 \item [I'm Getting Authorization Errors. What is Going On? ]
103 \index[general]{Authorization Errors}
104 \index[general]{Concurrent Jobs}
105    For security reasons, Bacula requires that both  the File daemon and the
106    Storage daemon know the name  of the Director as well as its password. As a
107    consequence,  if you change the Director's name or password, you must  make
108    the corresponding change in the Storage daemon's and  in the File daemon's
109    configuration files.  
110
111    During the authorization process, the Storage daemon and File daemon
112    also require that the Director authenticates itself, so both ends
113    require the other to have the correct name and password.
114
115    If you have edited the conf files and modified any name or any password,
116    and you are getting authentication errors, then your best bet is to go
117    back to the original conf files generated by the Bacula installation
118    process.  Make only the absolutely necessary modifications to these
119    files -- e.g.  add the correct email address.  Then follow the
120    instructions in the \borgxrlink{Running Bacula}{TutorialChapter}{main}{chapter} of
121    the \mainman{}.  You will run a backup to disk and a restore.  Only when
122    that works, should you begin customization of the conf files.
123
124    Another reason that you can get authentication errors is if you are
125    running Multiple Concurrent Jobs in the Director, but you have not set
126    them in the File daemon or the Storage daemon.  Once you reach their
127    limit, they will reject the connection producing authentication (or
128    connection) errors.
129
130    If you are having problems connecting to a Windows machine that
131    previously worked, you might try restarting the Bacula service since
132    Windows frequently encounters networking connection problems.
133
134    Some users report that authentication fails if there is not a proper
135    reverse DNS lookup entry for the machine.  This seems to be a
136    requirement of gethostbyname(), which is what Bacula uses to translate
137    names into IP addresses.  If you cannot add a reverse DNS entry, or you
138    don't know how to do so, you can avoid the problem by specifying an IP
139    address rather than a machine name in the appropriate Bacula conf file.
140
141    Here is a picture that indicates what names/passwords in which
142    files/Resources must match up:
143
144    \includegraphics{Conf-Diagram}  
145
146    In the left column, you will find the Director, Storage, and  Client
147    resources, with their names and passwords -- these  are all in {\bf
148    bacula-dir.conf}. The right column is where the corresponding values
149    should be found in the  Console, Storage daemon (SD), and File daemon (FD)
150    configuration  files.  
151
152    Another thing to check is to ensure that the Bacula component you are
153    trying to access has {\bf Maximum Concurrent Jobs} set large enough to
154    handle each of the Jobs and the Console that want to connect
155    simultaneously.  Once the maximum connections has been reached, each
156    Bacula component will reject all new connections.
157
158    Please also remember that File daemons with later versions than the
159    Director and Storage daemons are not supported and can result in
160    authorization errors.
161
162    Finally, make sure you have no {\bf hosts.allow} or {\bf hosts.deny}
163    file that is not permitting access to the site trying to connect.
164
165 \label{AccessProblems}
166 \section{Bacula Runs Fine but Cannot Access a Client on a Different Machine.
167    Why? }
168 \item [Bacula Runs Fine but Cannot Access a Client on a Different Machine.
169    Why? ]
170 \index[general]{Cannot Access a Client}
171    There are several reasons why Bacula could not contact a client  on a
172    different machine. They are:  
173
174 \begin{itemize}
175 \item It is a Windows Client, and the client died because of an  improper
176    configuration file. Check that the Bacula icon is in  the system tray and the
177    the menu items work. If the client has  died, the icon will disappear only
178    when you move the mouse over  the icon.  
179 \item The Client address or port is incorrect or not resolved by  DNS. See if
180    you can ping the client machine using the same  address as in the Client
181    record.  
182 \item You have a firewall, and it is blocking traffic on port  9102 between
183    the Director's machine and the Client's  machine (or on port 9103 between the
184    Client and the Storage daemon  machines).  
185 \item Your password or names are not correct in both the Director and  the
186    Client machine. Try configuring everything identical to  how you run the
187    client on the same machine as the Director, but  just change the Address. If
188    that works, make the other changes  one step at a time until it works.  
189 \item You may also be having problems between your File daemon and your
190    Storage daemon. The name you use in the Storage resource of your
191    Director's conf file must be known (resolvable) by the File daemon, 
192    because it is passed symbolically to the File daemon, which then
193    resolves it to get an IP address used to contact the Storage daemon.
194 \item You may have a {\bf hosts.allow} or {\bf hosts.deny} file that is
195    not permitting access.
196 \end{itemize}
197
198 \label{startover}
199 \section{My Catalog is Full of Test Runs, How Can I Start Over?}
200 \item [My Catalog is Full of Test Runs, How Can I Start Over? ]
201   \index[general]{My Catalog is Full of Test Runs, How Can I Start Over? }
202   If you are using MySQL do the following:
203
204 \footnotesize
205 \begin{verbatim}
206    cd <bacula-source>/src/cats
207    ./drop_mysql_tables
208    ./make_mysql_tables
209  
210 \end{verbatim}
211 \normalsize
212
213 If you are using SQLite, do the following:
214
215 \footnotesize
216 \begin{verbatim}
217    Delete bacula.db from your working directory.
218    cd <bacula-source>/src/cats
219    ./drop_sqlite_tables
220    ./make_sqlite_tables
221  
222 \end{verbatim}
223 \normalsize
224
225 Then write an EOF on each tape you used with {\bf Bacula} using: 
226
227 \footnotesize
228 \begin{verbatim}
229 mt -f /dev/st0 rewind
230 mt -f /dev/st0 weof
231 \end{verbatim}
232 \normalsize
233
234 where you need to adjust the device name for your system.  
235
236 \label{restorehang}
237 \section{I Run a Restore Job and Bacula Hangs. What do I do?}
238 \item [I Run a Restore Job and Bacula Hangs. What do I do?]
239 \index[general]{I Run a Restore Job and Bacula Hangs. What do I do? }
240    On Bacula version 1.25 and prior, it expects you to have the correct
241    tape mounted prior to a restore.  On Bacula version 1.26 and higher, it
242    will ask you for the tape, and if the wrong one is mounted, it will
243    inform you.
244
245    If you have previously done an {\bf unmount} command, all Storage daemon
246    sessions (jobs) will be completely blocked from using the drive
247    unmounted, so be sure to do a {\bf mount} after your unmount.  If in
248    doubt, do a second {\bf mount}, it won't cause any harm.
249
250 \label{windowstart}
251 \section{I Cannot Get My Windows Client to Start Automatically? }
252 \item [I Cannot Get My Windows Client to Start Automatically? ]
253 \index[general]{Windows Auto Start}
254    You are probably having one of two problems: either the Client is dying
255    due to an incorrect configuration file, or you didn't do the
256    Installation commands necessary to install it as a Windows Service.
257
258    For the first problem, see the next FAQ question.  For the second
259    problem, please review the \borgxrlink{Windows Installation Instructions}{Win32Chapter}{main}{chapter} in the\mainman{}.
260
261 \label{windowsdie}
262 \section{My Windows Client Immediately Dies When I Start It}
263 \item [My Windows Client Immediately Dies When I Start It]
264 \index[general]{Windows Client Dies}
265 The most common problem is either that the configuration file is not where
266 it expects it to be, or that there is an error in the configuration file.
267 You must have the configuration file in {\bf
268 c:\textbackslash{}bacula\textbackslash{}bin\textbackslash{}bacula-fd.conf}.
269
270 To {\bf see} what is going on when the File daemon starts  on Windows, do the
271 following:  
272
273 \footnotesize
274 \begin{verbatim}
275     Start a DOS shell Window.
276     cd c:\bacula\bin
277     bacula-fd -d100 -c c:\bacula\bin\bacula-fd.conf
278     
279 \end{verbatim}
280 \normalsize
281
282 This will cause the FD to write a file {\bf bacula.trace}  in the current
283 directory, which you can examine and thereby determine  the problem.  
284
285 \label{scroll}
286 \item [When I Start the Console, the Error Messages Fly By. How can I see
287    them? ]
288 \index[general]{Error Messages}
289    Either use a shell window with a scroll bar, or use the gnome-console.
290    In any case, you probably should be logging all output to a file, and
291    then you can simply view the file using an editor or the {\bf less}
292    program.  To log all output, I have the following in my Director's
293    Message resource definition:
294
295 \footnotesize
296 \begin{verbatim}
297     append = "/home/kern/bacula/bin/log" = all, !skipped
298     
299 \end{verbatim}
300 \normalsize
301
302 Obviously you will want to change the filename to be appropriate  for your
303 system.  
304
305 \label{nobackup}
306 \section{My backups are not working on my Windows 
307    Client. What should I do?}
308 \item [I didn't realize that the backups were not working on my Windows 
309    Client. What should I do? ]
310 \index[general]{Backups Failing}
311 You should be sending yourself an email message for each job. This will  avoid
312 the possibility of not knowing about a failed backup. To do so  put something
313 like:  
314
315 \footnotesize
316 \begin{verbatim}
317   Mail = yourname@yourdomain = all, !skipped
318   
319 \end{verbatim}
320 \normalsize
321
322 in your Director's message resource.  You should then receive one email for
323 each Job that ran.  When you are comfortable with what is going on (it took
324 me 9 months), you might change that to:
325
326 \footnotesize
327 \begin{verbatim}
328    MailOnError = yourname@yourdomain = all, !skipped
329    
330 \end{verbatim}
331 \normalsize
332
333 then you only get email messages when a Job errors as is the case  for your
334 Windows machine.  
335
336 You should also be logging the Director's messages, please see the  previous
337 FAQ for how to do so.  
338
339 \label{sched}
340 \section{All my Jobs are scheduled for the same time. Will this cause
341    problems?}
342 \item [All my Jobs are scheduled for the same time. Will this cause
343    problems? ]
344 \index[general]{Schedule problems}
345    No, not at all.  Bacula will schedule all the Jobs at the same time, but
346    will run them one after another unless you have increased the number of
347    simultaneous jobs in the configuration files for the Director, the File
348    daemon, and the Storage daemon.  The appropriate configuration record is
349    {\bf Maximum Concurrent Jobs = nn}.  At the current time, we recommend
350    that you leave this set to {\bf 1} for the Director.
351
352 \label{disk}
353 \section{Can Bacula Backup My System To Files instead of Tape?}
354 \item [Can Bacula Backup My System To Files instead of Tape? ]
355 \index[general]{Backup to Disk}
356    Yes, in principle, Bacula can backup to any storage medium as long as
357    you have correctly defined that medium in the Storage daemon's Device
358    resource.  For an example of how to backup to files, please see the
359    \borgxrlink{Pruning Example}{PruningExample}{main}{chapter} of the \mainman{}.
360    Also, there is a whole chapter devoted to \borgxrlink{Basic Volume
361    Management}{DiskChapter}{main}{chapter} in the \mainman{}.  This chapter was originally written to
362    explain how to write to disk, but was expanded to include volume
363    management.  It is, however, still quite a good chapter to read.
364
365 \label{testbackup}
366 \section{Can I use a dummy device to test the backup?}
367    Yes, to have a {\sl Virtual} device which just consumes data, you can use a 
368    FIFO device (see \borgxrlink{Stored configuration}{SetupFifo}{main}{chapter}
369    in the \mainman{}).  It's useful to test a backup.
370 \footnotesize
371 \begin{verbatim}
372 Device {
373   Name = NULL
374   Media Type = NULL
375   Device Type = Fifo
376   Archive Device = /dev/null
377   LabelMedia = yes
378   Random Access = no
379   AutomaticMount = no
380   RemovableMedia = no
381   MaximumOpenWait = 60
382   AlwaysOpen = no
383 }
384 \end{verbatim}
385 \normalsize
386
387 \label{bigfiles}
388 \section{Can Bacula Backup and Restore Files Bigger than 2 Gigabytes?}
389 \item [Can Bacula Backup and Restore Files Bigger than 2 Gigabytes?]
390 \index[general]{Large file support}
391 If your operating system permits it, and you are running Bacula version
392 1.26 or later, the answer is yes.  To the best of our knowledge all client
393 system supported by Bacula can handle files bigger 2 Gigabytes.
394
395 \label{cancel}
396 \section{I want to stop a job.}
397 %% Is there  a better way than "./bacula stop" to stop it?}
398 \item [I Started A Job then Decided I Really Did Not Want to Run It. Is
399    there  a better way than {\bf ./bacula stop} to stop it?]
400 \index[general]{Cancelling jobs} 
401    Yes, you normally should use the Console command {\bf cancel} to cancel
402    a Job that is either scheduled or running.  If the Job is scheduled, it
403    will be marked for cancellation and will be canceled when it is
404    scheduled to start.  If it is running, it will normally terminate after
405    a few minutes.  If the Job is waiting on a tape mount, you may need to
406    do a {\bf mount} command before it will be canceled.
407
408 \label{trademark}
409 \section{Why have You Trademarked the Name Bacula?}
410 \item [Why have You Trademarked the Name
411    Bacula\raisebox{.6ex}{{\footnotesize \textsuperscript{\textregistered}}}?]
412 \index[general]{Bacula Trademark}
413 We have trademarked the name Bacula to ensure that all media  written by any
414 program named Bacula will always be compatible. Anyone  may use the name
415 Bacula, even in a derivative product as long as it  remains totally compatible
416 in all respects with the program defined  here.
417
418 \label{docversion}
419 \section{Why is the Online Document for Version 1.39 but the Released Version is 1.38?}
420 \item [Why is the Online Document for Version 1.39 of Bacula when the
421    Current Version is 1.38?]
422 \index[general]{Multiple manuals}
423 As Bacula is being developed, the document is also being enhanced, more
424 often than not it has clarifications of existing features that can be very
425 useful to our users, so we publish the very latest document.  Fortunately
426 it is rare that there are confusions with new features.
427
428 If you want to read a document that pertains only to a specific  version,
429 please use the one distributed in the source code.  The web site also has 
430 online versions of both the released manual and the current development
431 manual.
432
433 \label{sure}
434 \section{Does Bacula really save and restore all files?}
435 \item [How Can I Be Sure that Bacula Really Saves and Restores All Files? ]
436 \index[general]{Checking Restores}
437    It is really quite simple, but took me a while to figure
438    out how to "prove" it.  First make a Bacula Rescue disk, see the
439    \borgxrlink{Disaster Recovery Using Bacula}{RescueChapter}{main}{chapter} of the \mainman{}.
440    Second, you run a full backup of all your files on all partitions.
441    Third, you run an Verify InitCatalog Job on the same FileSet, which
442    effectively makes a record of all the files on your system.  Fourth, you
443    run a Verify Catalog job and assure yourself that nothing has changed
444    (well, between an InitCatalog and Catalog one doesn't expect anything).
445    Then do the unthinkable, write zeros on your MBR (master boot record)
446    wiping out your hard disk.  Now, restore your whole system using your
447    Bacula Rescue disk and the Full backup you made, and finally re-run the
448    Verify Catalog job.  You will see that with the exception of the
449    directory modification and access dates and the files changed during the
450    boot, your system is identical to what it was before you wiped your hard
451    disk.
452    Alternatively you could do the wiping and restoring to another computer
453    of the same type.
454
455 \label{upgrade}
456 \section{I want an Incremental but Bacula runs it as a Full backup. Why?}
457 \item [I did a Full backup last week, but now in running an Incremental,
458    Bacula  says it did not find a FULL backup, so it did a FULL backup. Why?]
459 \index[general]{FULL backup not found}
460    Before doing an Incremental or a Differential
461    backup, Bacula checks to see if there was a prior Full backup of the
462    same Job that terminated successfully.  If so, it uses the date that
463    full backup started as the time for comparing if files have changed.  If
464    Bacula does not find a successful full backup, it proceeds to do one.
465    Perhaps you canceled the full backup, or it terminated in error.  In
466    such cases, the full backup will not be successful.  You can check by
467    entering {\bf list jobs} and look to see if there is a prior Job with
468    the same Name that has Level F and JobStatus T (normal termination).
469
470    Another reason why Bacula may not find a suitable Full backup is that
471    every time you change the FileSet, Bacula will require a new Full
472    backup.  This is necessary to ensure that all files are properly backed
473    up in the case where you have added more files to the FileSet.
474    Beginning with version 1.31, the FileSets are also dated when they are
475    created, and this date is displayed with the name when you are listing
476    or selecting a FileSet.  For more on backup levels see below.
477
478    See also {\bf Ignore FileSet Changes} in the
479    \borgxrlink{FileSet Resource definition}{FileSetResource}{main}{chapter} in the \mainman{}.
480
481 \label{filenamelengths}
482 \section{Do you really handle unlimited path lengths?}
483 \item [How Can You Claim to Handle Unlimited Path and Filename Lengths
484    when  All Other Programs Have Fixed Limits?]
485 \index[general]{Path and Filename Lengths} 
486    Most of those other programs have been around for a long time, in fact
487    since the beginning of Unix, which means that they were designed for
488    rather small fixed length path and filename lengths.  Over the years,
489    these restrictions have been relaxed allowing longer names.  Bacula on
490    the other hand was designed in 2000, and so from the start, Path and
491    Filenames have been kept in buffers that start at 256 bytes in length,
492    but can grow as needed to handle any length.  Most of the work is
493    carried out by lower level routines making the coding rather easy.
494
495    Note that due to limitations Win32 path and filenames cannot exceed
496    260 characters. By using Win32 Unicode functions, we will remove this
497    restriction in later versions of Bacula.
498
499 \label{unique}
500 \section{What Is the Really Unique Feature of Bacula?}
501 \item [What Is the Really Unique Feature of Bacula?]
502 \index[general]{Unique Feature of Bacula} 
503    Well, it is hard to come up with unique features when backup programs
504    for Unix machines have been around since the 1960s.  That said, I
505    believe that Bacula is the first and only program to use a standard SQL
506    interface to catalog its database.  Although this adds a bit of
507    complexity and possibly overhead, it provides an amazingly rich set of
508    features that are easy to program and enhance.  The current code has
509    barely scratched the surface in this regard (version 1.38).
510
511    The second feature, which gives a lot of power and flexibility to Bacula
512    is the Bootstrap record definition.
513
514    The third unique feature, which is currently (1.30) unimplemented, and
515    thus can be called vaporware :-), is Base level saves.  When
516    implemented, this will enormously reduce tape usage.
517
518 \label{sequence}
519 \section{How can I force one job to run after another?}
520 \item [If I Run Multiple Simultaneous Jobs, How Can I Force One
521    Particular  Job to Run After Another Job? ]
522 \index[general]{Multiple Simultaneous Jobs}
523 Yes, you can set Priorities on your jobs so that they  run in the order you
524 specify. Please see:  
525 \borgxrlink{the Priority record}{Priority}{main}{chapter} of the \mainman{} in
526 the  Job resource.
527
528 \label{nomail}
529 \section{I Am Not Getting Email Notification, What Can I Do? }
530 \item [I Am Not Getting Email Notification, What Can I Do? ]
531 \index[general]{No Email Notification}
532    The most common problem is that you have not specified a fully qualified
533    email address and your bsmtp server is rejecting the mail.  The next
534    most common problem is that your bsmtp server doesn't like the syntax on
535    the From part of the message.  For more details on this and other
536    problems, please see the \ilink{ Getting Email Notification to Work}{email} section of the Tips chapter of this manual.  The section
537    \ilink{Getting Notified of Job Completion}{notification} of the Tips
538    chapter may also be useful.  For more information on the {\bf bsmtp}
539    mail program, please see \borgxrlink{bsmtp}{bsmtp}{utility}{command} in the
540    \utilityman{}.
541
542 \label{periods}
543 \section{My retention periods don't work}
544 \item [I Change Recycling, Retention Periods, or File Sizes in my Pool
545    Resource  and they Still Don't Work.]
546 \index[general]{Recycling}
547 \index[general]{Retention Periods}
548 \index[general]{Pool changes}
549   The different variables associated with a Pool are defined in the  Pool
550   Resource, but are actually read by Bacula from the Catalog database.  On
551   Bacula versions prior to 1.30, after changing your Pool Resource,  you must
552   manually update the corresponding values in the Catalog by  using the {\bf
553   update pool} command in the Console program. In Bacula  version 1.30, Bacula
554   does this for you automatically every time it  starts.  
555   
556   When Bacula creates a Media record (Volume), it uses many default  values from
557   the Pool record. If you subsequently change the Pool  record, the new values
558   will be used as a default for the next Volume  that is created, but if you
559   want the new values to apply to existing  Volumes, you must manually update
560   the Volume Catalog entry using  the {\bf update volume} command in the Console
561   program. 
562
563 \label{CompressionNotWorking}
564 \section{Why aren't my files compressed?}
565 \item [I Have Configured Compression On, But None of My Files Are
566    Compressed.  Why?]
567 \index[general]{Compression}
568    There are two kinds of compression. One is tape compression. This  is done by
569    the tape drive hardware, and you either enable or disable  it with system
570    tools such as {\bf mt}. This compression works  independently of Bacula,  
571    and when it is enabled, you should not use the Bacula software 
572    compression.
573    
574    Bacula also has software compression code in the File daemons, which you
575    normally need to enable only when backing up to file Volumes.  There are
576    two conditions necessary to enable the Bacula software compression.
577
578 \begin{enumerate}
579 \item You must have the zip development libraries loaded on your system
580    when building Bacula and Bacula must find this library, normally {\bf
581    /usr/lib/libz.a}.  On Red Hat systems, this library is provided by the
582    {\bf zlib-devel} rpm.
583
584    If the library is found by Bacula during the {\bf ./configure} it will
585    be mentioned in the {\bf config.out} line by:
586
587 \footnotesize
588 \begin{verbatim}
589     ZLIB support:  yes
590           
591 \end{verbatim}
592 \normalsize
593
594 \item You must add the {\bf compression=gzip} option on your  Include
595    statement in the Director's configuration file.  
596 \end{enumerate}
597
598 \label{NewTape}
599 \item [Bacula is Asking for a New Tape After 2 GB of Data but My Tape
600    holds 33 GB. Why?]
601 \index[general]{Tape capacity}
602 There are several reasons why Bacula will request a new tape.  
603
604 \begin{itemize}
605 \item There is an I/O error on the tape. Bacula prints an error message  and
606    requests a new tape. Bacula does not attempt to continue writing  after an
607    I/O error.  
608 \item Bacula encounters and end of medium on the tape. This is not always 
609    distinguishable from an I/O error.  
610 \item You have specifically set some size limitation on the tape. For  example
611    the {\bf Maximum Volume Bytes} or {\bf Maximum Volume Files}  in the
612    Director's Pool resource, or {\bf Maximum Volume Size} in  the Storage
613    daemon's Device resource.  
614 \end{itemize}
615
616 \label{LevelChanging}
617 \section{Incremental backups are not working}
618 \item [Bacula is Not Doing the Right Thing When I Request an Incremental
619    Backup. Why?]
620 \index[general]{Incremental backups}
621    As explained in one of the previous questions, Bacula will automatically
622    upgrade an Incremental or Differential job to a Full backup if it cannot
623    find a prior Full backup or a suitable Full backup.  For the gory
624    details on how/when Bacula decides to upgrade levels please see the
625    \borgxrlink{Level record}{Level}{main}{chapter} in the \mainman{}.
626    
627    If after reading the above mentioned section, you believe that Bacula  is not
628    correctly handling the level (Differential/Incremental),  please send us the
629    following information for analysis:  
630
631 \begin{itemize}
632 \item Your Director's configuration file.  
633 \item The output from {\bf list jobs} covering the period where you  are
634    having the problem.  
635 \item The Job report output from the prior Full save (not critical).  
636 \item An {\bf llist jobid=nnn} where nnn is the JobId of the prior  Full save.
637  
638 \item The Job report output from the save that is doing the  wrong thing (not
639    critical).  
640 \item An {\bf llist jobid=nnn} where nnn is the JobId of the job  that was not
641    correct.  
642 \item An explanation of what job went wrong and why you think it did.  
643    \end{itemize}
644
645 The above information can allow us to analyze what happened, without it, 
646 there is not much we can do.  
647
648 \label{WaitForever}
649 \section{I am waiting forever for a backup of an offsite machine}
650 \item [I am Backing Up an Offsite Machine with an Unreliable Connection.
651    The  Director Waits Forever for the Client to Contact the SD. What Can  I
652    Do?]
653 \index[general]{Backing Up Offsite Machines}
654    Bacula was written on the assumption that it will have a good TCP/IP
655    connection between all the daemons.  As a consequence, the current
656    Bacula doesn't deal with faulty connections very well.  This situation
657    is slowly being corrected over time.
658    
659    There are several things you can do to improve the situation.  
660
661 \begin{itemize}
662 \item Upgrade to version 1.32 and use the new SDConnectTimeout record.  For
663    example, set:  
664
665 \footnotesize
666 \begin{verbatim}
667           SD Connect Timeout = 5 min
668           
669 \end{verbatim}
670 \normalsize
671
672 in the FileDaemon resource.  
673 \item Run these kinds of jobs after all other jobs.  
674    \end{itemize}
675
676 \label{sshHanging}
677 \section{SSH hangs forever after starting Bacula}
678 \item [When I ssh into a machine and start Bacula then attempt to exit, 
679    ssh hangs forever.]
680 \index[general]{ssh hangs}
681    This happens because Bacula leaves stdin, stdout, and stderr open for
682    debug purposes.  To avoid it, the simplest thing to do is to redirect
683    the output of those files to {\bf /dev/null} or another file in your
684    startup script (the Red Hat autostart scripts do this automatically).
685    For example, you start the Director with:
686    
687 \footnotesize
688 \begin{verbatim}
689     bacula-dir -c bacula-dir.conf ... >/dev/null 0>\&1 2>\&1
690     
691 \end{verbatim}
692 \normalsize
693
694 and likewise for the other daemons.  
695
696 \label{RetentionPeriods}
697 \section{I'm confused by retention periods}
698 \item [I'm confused by the different Retention periods: File Retention, 
699    Job Retention, Volume Retention. Why are there so many?]
700 \index[general]{Retention Periods}
701    Yes, this certainly can be confusing.  The basic reason for so many is
702    to allow flexibility.  The File records take quite a lot of space in the
703    catalog, so they are typically records you want to remove rather
704    quickly.  The Job records, take very little space, and they can be
705    useful even without the File records to see what Jobs actually ran and
706    when.  One must understand that if the File records are removed from the
707    catalog, you cannot use the {\bf restore} command to restore an
708    individual file since Bacula no longer knows where it is.  However, as
709    long as the Volume Retention period has not expired, the data will still
710    be on the tape, and can be recovered from the tape.
711    
712    For example, I keep a 30 day retention period for my Files to keep my
713    catalog from getting too big, but I keep my tapes for a minimum of one
714    year, just in case.
715
716 \label{MaxVolumeSize}
717 \section{MaxVolumeSize is ignored}
718 \item [Why Does Bacula Ignore the MaxVolumeSize Set in my Pool?]
719 \index[general]{MaxVolumeSize}
720    The MaxVolumeSize that Bacula uses comes from the Media record, so most
721    likely you changed your Pool, which is used as the default for creating
722    Media records, {\bf after} you created your Volume.  Check what is in
723    the Media record by doing:
724
725 \footnotesize
726 \begin{verbatim}
727 llist Volume=xxx
728 \end{verbatim}
729 \normalsize
730
731 If it doesn't have the right value, you can use: 
732
733 \footnotesize
734 \begin{verbatim}
735 update Volume=xxx
736 \end{verbatim}
737 \normalsize
738
739 to change it.  
740
741 \label{ConnectionRefused}
742 \section{I get a Connection refused when connecting to my Client}
743 \item [In connecting to my Client, I get "ERR:Connection Refused.  Packet
744    Size too big from File daemon:192.168.1.4:9102" Why?]
745 \index[general]{ERR:Connection Refused}
746    This is typically a communications error resulting  from one of the
747    following:
748  
749
750 \begin{itemize}
751 \item Old versions of Bacula, usually a Win32 client, where two  threads were
752    using the same I/O packet. Fixed in more recent  versions. Please upgrade.  
753 \item Some other program such as an HP Printer using the same  port (9102 in
754    this case).  
755 \end{itemize}
756
757 If it is neither of the above, please submit a bug report at  
758 \elink{bugs.bacula.org}{http://bugs.bacula.org}.  
759
760 Another solution might be to run the daemon with the debug  option by:  
761
762 \footnotesize
763 \begin{verbatim}
764     Start a DOS shell Window.
765     cd c:\bacula\bin
766     bacula-fd -d100 -c c:\bacula\bin\bacula-fd.conf
767     
768 \end{verbatim}
769 \normalsize
770
771 This will cause the FD to write a file {\bf bacula.trace}  in the current
772 directory, which you can examine to determine  the problem.  
773
774 \section{Long running jobs die with Pipe Error}
775 \item [During long running jobs my File daemon dies with Pipe Error, or
776        some other communications error. Why?]
777 \index[general]{Communications Errors}
778 \index[general]{Pipe Errors}
779 \index[general]{slow}
780 \index[general]{Backups!slow}
781    There are a number of reasons why a connection might break.
782    Most often, it is a router between your two computers that times out
783    inactive lines (not respecting the keepalive feature that Bacula uses).
784    In that case, you can use the {\bf Heartbeat Interval} directive in
785    both the Storage daemon and the File daemon. 
786
787    In at least one case, the problem has been a bad driver for a Win32
788    NVidia NForce 3 ethernet card with driver (4.4.2 17/05/2004). 
789    In this case, a good driver is (4.8.2.0 06/04/2005).  Moral of
790    the story, make sure you have the latest ethernet drivers
791    loaded, or use the following workaround as suggested by Thomas
792    Simmons for Win32 machines:
793      
794    Browse to:
795    Start \gt{} Control Panel \gt{} Network Connections
796
797    Right click the connection for the nvidia adapter and select properties. 
798    Under the General tab, click "Configure...". Under the Advanced tab set 
799    "Checksum Offload" to disabled and click OK to save the change.  
800
801    Lack of communications, or communications that get interrupted can
802    also be caused by Linux firewalls where you have a rule that throttles
803    connections or traffic.  For example, if you have:
804
805 \footnotesize
806 \begin{verbatim}
807 iptables -t filter -A INPUT -m limit --limit 3/second --limit-burst 3 -j DROP
808 \end{verbatim}
809 \normalsize
810
811    you will want to add the following rules {\bf before} the above rule:
812 \footnotesize
813 \begin{verbatim}
814 iptables -t filter -A INPUT --dport 9101 -j ACCEPT
815 iptables -t filter -A INPUT --dport 9102 -j ACCEPT
816 iptables -t filter -A INPUT --dport 9103 -j ACCEPT
817 \end{verbatim}
818 \normalsize
819    This will ensure that any Bacula traffic will not get terminated because
820    of high usage rates.
821    
822 \section{How do I tell the Job which Volume to use?}
823 \item[I can't figure out how to tell the job which volume to use]
824    \index[general]{What tape to mount}
825   This is an interesting statement. I now see that a number of people new to
826   Bacula have the same problem as you, probably from using programs like tar.
827
828   In fact, you do not tell Bacula what tapes to use.  It is the inverse.  Bacula
829   tells you want tapes it wants.  You put tapes at its disposition and it
830   chooses.  
831
832   Now, if you *really* want to be tricky and try to tell Bacula what to do, it
833   will be reasonable if for example you mount a valid tape that it can use on a
834   drive, it will most likely go ahead and use it.  It also has a documented
835   algorithm for choosing tapes -- but you are asking for problems ...
836
837   So, the trick is to invert your concept of things and put Bacula in charge of
838   handling the tapes.  Once you do that, you will be fine.  If you want to
839   anticipate what it is going to do, you can generally figure it out correctly
840   and  get what you want.  
841
842   If you start with the idea that you are going to force or tell Bacula to use
843   particular tapes or you insist on trying to run in that kind of mode, you will
844   probably not be too happy.
845
846   I don't want to worry about what tape has what data. That is what Bacula is
847   designed for.
848
849   If you have an application where you *really* need to remove a tape each day
850   and  insert a new one, it can be done the directives exist to accomplish that.
851   In such a case, one little "trick" to knowing what tape Bacula will want at
852   2am  while you are asleep is to run a tiny job at 4pm while you are still at
853   work  that backs up say one directory, or even one file. You will quickly find
854   out  what tape it wants, and you can mount it before you go home ... 
855
856 \label{Password generation}
857 \section{Password generation}
858 \item [How do I generate a password?]
859 \index[general]{MaxVolumeSize}
860
861    Each daemon needs a password.  This password occurs in the configuration
862    file for that daemon and in the bacula-dir.conf file. These passwords are
863    plain text.  There is no special generation procedure.  Most people just
864    use random text.
865
866    Passwords are never sent over the wire in plain text.  They are always
867    encrypted.
868
869    Security surrounding these passwords is best left security to your
870    operating system.  Passwords are not encrypted within Bacula
871    configuration files.
872
873 \end{description}
874