]> git.sur5r.net Git - bacula/docs/blob - docs/manuals/en/main/win32.tex
Change Win32 to Windows in win32.tex
[bacula/docs] / docs / manuals / en / main / win32.tex
1 %%
2 %%
3
4 \chapter{The Windows Version of Bacula}
5 \label{Win32Chapter}
6 \index[general]{Windows Version of Bacula}
7
8 At the current time only the File daemon or Client program has
9 been thouroughly tested on Windows and is suitable for a
10 production environment. As a consequence, when we
11 speak of the Windows version of Bacula below, we are referring to
12 the File daemon (client) only. 
13
14 The Windows version of the Bacula File daemon has been tested on WinXP,
15 Win2000, Windows Server 2003, Windows Server 2008, Vista, and Windows 7
16 systems.  The Windows version of Bacula is a native Windows port, but there
17 are very few source code changes to the Unix code, which means that the
18 Windows version is for the most part running code that has long proved
19 stable on Unix systems.  When running, it is perfectly integrated with
20 Windows and displays its icon in the system icon tray, and provides a
21 system tray menu to obtain additional information on how Bacula is running
22 (status and events dialog boxes).  If so desired, it can also be stopped by
23 using the system tray menu, though this should normally never be necessary.
24
25 Once installed Bacula normally runs as a system service. This means that it is
26 immediately started by the operating system when the system is booted, and
27 runs in the background even if there is no user logged into the system. 
28
29 \section{Windows Installation}
30 \label{installation}
31 \index[general]{Installation}
32 \index[general]{Windows!Installation}
33
34 Normally, you will install the Windows version of Bacula from the binaries.
35 This install is standard Windows .exe that runs an install wizard using the
36 NSIS Free Software installer, so if you have already installed Windows
37 software, it should be very familiar to you. 
38
39 If you have a previous version of Bacula
40 installed, you should stop the service, uninstall it, and remove
41 the Bacula installation directory possibly saving your
42 bacula-fd.conf, bconsole.conf, and bat.conf files
43 for use with the new version you will install.  The Uninstall
44 program is normally found in {\bf c:\textbackslash{}bacula\textbackslash{}Uninstall.exe}.
45 We also recommend that you completely remove the directory
46 {\bf c:\textbackslash{}bacula}, because the current installer
47 uses a different directory structure (see below).
48
49 Providing you do not already have Bacula installed,
50 the installer installs the binaries and dlls in 
51 c:\textbackslash{}Program Files\textbackslash{}Bacula\textbackslash{}bin  
52 and the configuration files
53 in c:\textbackslash{}Documents and Settings\textbackslash{}All Users\textbackslash{}Application Data\textbackslash{}Bacula
54 In addition, the {\bf Start\-\gt{}All Programs\-\gt{}Bacula} menu item
55 will be created during the installation, and on that menu, you
56 will find items for editing the configuration files, displaying
57 the document, and starting bwx-console or bconsole.
58
59
60 Finally, proceed with the installation. 
61
62 \begin{itemize}
63 \item You must be logged in as Administrator to the local machine
64 to do a correct installation, if not, please do so before continuing.
65 Some users have attempted to install logged in as a domain administrator
66 account and experienced permissions problems attempting to run
67 Bacula, so we don't recommend that option.
68   
69 \item Simply double click on the {\bf bacula-win32-5.xx.0.exe}  NSIS install
70    icon. The  actual name of the icon will vary from one release version to 
71    another. 
72
73 \includegraphics{\idir win32-nsis.eps}  bacula-win32-5.xx.0.exe  
74   
75 \item Once launched, the installer wizard will ask you if you want  to install
76    Bacula.  
77
78 \addcontentsline{lof}{figure}{Windows Client Setup Wizard}
79 \includegraphics{\idir win32-welcome.eps}  
80
81 \item Next you will be asked to select the installation type. 
82
83 \addcontentsline{lof}{figure}{Windows Installation Type}
84 \includegraphics{\idir win32-installation-type.eps}
85
86
87 \item If you proceed, you will be asked to select the components to be 
88    installed. You may install the Bacula program (Bacula File Service)  and or
89    the documentation. Both will be installed in sub-directories  of the install
90    location that you choose later. The components  dialog looks like the
91    following:  
92
93 \addcontentsline{lof}{figure}{Windows Component Selection Dialog}
94 \includegraphics{\idir win32-pkg.eps}  
95 \index[general]{Upgrading}
96
97 \item If you are installing for the first time, you will  be asked to
98    enter some very basic information about your configuration. If
99    you are not sure what to enter, or have previously saved configuration
100    files, you can put anything you want into the fields, then either
101    replace the configuration files later with the ones saved, or edit
102    the file.
103
104    If you are upgrading an existing installation, the following will
105    not be displayed.
106
107
108 \addcontentsline{lof}{figure}{Windows Configure}
109 \includegraphics{\idir win32-config.eps}  
110  
111 \item While the various files are being loaded, you will see the following
112    dialog:
113
114    \addcontentsline{lof}{figure}{Windows Install Progress}
115    \includegraphics{\idir win32-installing.eps}  
116
117
118 \item Finally, the finish dialog will appear:  
119
120    \addcontentsline{lof}{figure}{Windows Client Setup Completed}
121    \includegraphics{\idir win32-finish.eps}  
122
123
124 \end{itemize}
125
126 That should complete the installation process. When the Bacula File Server is
127 ready to serve files, an icon \includegraphics{\idir idle.eps} representing a
128 cassette (or tape) will appear in the system tray
129 \includegraphics{\idir tray-icon.eps}; right click on it and a menu will appear.\\
130 \includegraphics{\idir menu.eps}\\
131 The {\bf Events} item is currently unimplemented, by selecting the {\bf
132 Status} item, you can verify whether any jobs are running or not. 
133
134 When the Bacula File Server begins saving files, the color of the holes in the
135 cassette icon will change from white to green \includegraphics{\idir running.eps},
136 and if there is an error, the holes in the cassette icon will change to red
137 \includegraphics{\idir error.eps}. 
138
139 If you are using remote desktop connections between your Windows boxes, be
140 warned that that tray icon does not always appear. It will always be visible
141 when you log into the console, but the remote desktop may not display it. 
142
143 \section{Post Windows Installation}
144 \index[general]{Post Windows Installation}
145 \index[general]{Windows!Post Installation}
146
147 After installing Bacula and before running it, you should check the contents
148 of the configuration files to ensure that they correspond to your
149 installation.  You can get to them by using:
150 the {\bf Start\-\gt{}All Programs\-\gt{}Bacula} menu item.
151
152 Finally, but pulling up the Task Manager (ctl-alt-del), verify that Bacula
153 is running as a process (not an Application) with User Name SYSTEM. If this is 
154 not the case, you probably have not installed Bacula while running as
155 Administrator, and hence it will be unlikely that Bacula can access
156 all the system files.
157
158 \section{Uninstalling Bacula on Windows}
159 \index[general]{Windows!Uninstalling Bacula}
160 \index[general]{Uninstalling Bacula on Windows}
161
162 Once Bacula has been installed, it can be uninstalled using the standard
163 Windows Add/Remove Programs dialog found on the Control panel. 
164
165 \section{Dealing with Windows Problems}
166 \label{problems}
167 \index[general]{Windows!Dealing with Problems}
168 \index[general]{Dealing with Windows Problems}
169
170 Sometimes Windows machines the File daemon may have very slow
171 backup transfer rates compared to other machines.  To you might
172 try setting the Maximum Network Buffer Size to 32,768 in both the
173 File daemon and in the Storage daemon. The default size is larger,
174 and apparently some Windows ethernet controllers do not deal with          
175 a larger network buffer size.
176
177 Many Windows ethernet drivers have a tendency to either run slowly 
178 due to old broken firmware, or because they are running in half-duplex
179 mode. Please check with the ethernet card manufacturer for the latest
180 firmware and use whatever techniques are necessary to ensure that the 
181 card is running in duplex.
182
183 If you are not using the portable option, and you have VSS
184 (Volume Shadow Copy) enabled in the Director, and you experience
185 problems with Bacula not being able to open files, it is most
186 likely that you are running an antivirus program that blocks
187 Bacula from doing certain operations. In this case, disable the
188 antivirus program and try another backup.  If it succeeds, either
189 get a different (better) antivirus program or use something like
190 RunClientJobBefore/After to turn off the antivirus program while
191 the backup is running.
192
193 If turning off anti-virus software does not resolve your VSS
194 problems, you might have to turn on VSS debugging.  The following
195 link describes how to do this:
196 \elink{http://support.microsoft.com/kb/887013/en-us}{http://support.microsoft.com/kb/887013/en-us}.
197
198 In Microsoft Windows Small Business Server 2003 the VSS Writer for Exchange
199 is turned off by default. To turn it on, please see the following link:
200 \elink{http://support.microsoft.com/default.aspx?scid=kb;EN-US;Q838183}{
201 http://support.microsoft.com/default.aspx?scid=kb;EN-US;Q838183}
202
203
204 The most likely source of problems is authentication when the Director
205 attempts to connect to the File daemon that you installed. This can occur if
206 the names and the passwords defined in the File daemon's configuration file
207 {\bf bacula-fd.conf} file on
208 the Windows machine do not match with the names and the passwords in the
209 Director's configuration file {\bf bacula-dir.conf} located on your Unix/Linux
210 server. 
211
212 More specifically, the password found in the {\bf Client} resource in the
213 Director's configuration file must be the same as the password in the {\bf
214 Director} resource of the File daemon's configuration file. In addition, the
215 name of the {\bf Director} resource in the File daemon's configuration file
216 must be the same as the name in the {\bf Director} resource of the Director's
217 configuration file. 
218
219 It is a bit hard to explain in words, but if you understand that a Director
220 normally has multiple Clients and a Client (or File daemon) may permit access
221 by multiple Directors, you can see that the names and the passwords on both
222 sides must match for proper authentication. 
223
224 One user had serious problems with the configuration file until he realized
225 that the Unix end of line conventions were used and Bacula wanted them in
226 Windows format. This has not been confirmed though, and Bacula version 2.0.0 
227 and above should now accept all end of line conventions (Windows,
228 Unix, Mac).
229
230 Running Unix like programs on Windows machines is a bit frustrating because
231 the Windows command line shell (DOS Window) is rather primitive. As a
232 consequence, it is not generally possible to see the debug information and
233 certain error messages that Bacula prints. With a bit of work, however, it is
234 possible. When everything else fails and you want to {\bf see} what is going
235 on, try the following: 
236
237 \footnotesize
238 \begin{verbatim}
239    Start a DOS shell Window.
240    c:\Program Files\bacula\bacula-fd -t >out
241    type out
242 \end{verbatim}
243 \normalsize
244
245 The precise path to bacula-fd depends on where it is installed.
246 The {\bf -t} option will cause Bacula to read the configuration file, print
247 any error messages and then exit. the {\bf \gt{}} redirects the output to the
248 file named {\bf out}, which you can list with the {\bf type} command. 
249
250 If something is going wrong later, or you want to run {\bf Bacula} with a
251 debug option, you might try starting it as: 
252
253 \footnotesize
254 \begin{verbatim}
255    c:\Program Files\bacula\bin\bacula-fd -d 100 >out
256 \end{verbatim}
257 \normalsize
258
259 In this case, Bacula will run until you explicitly stop it, which will give
260 you a chance to connect to it from your Unix/Linux server. In later versions
261 of Bacula (1.34 on, I think), when you start the File daemon in debug mode it
262 can write the output to a trace file {\bf bacula.trace} in the current
263 directory. To enable this, before running a job, use the console, and enter: 
264
265 \footnotesize
266 \begin{verbatim}
267    trace on
268 \end{verbatim}
269 \normalsize
270
271 then run the job, and once you have terminated the File daemon, you will find
272 the debug output in the {\bf bacula.trace} file, which will probably be 
273 located in the same directory as bacula-fd.exe.
274
275 In addition, you should look in the System Applications log on the Control
276 Panel to find any Windows errors that Bacula got during the startup process. 
277
278 Finally, due to the above problems, when you turn on debugging, and specify
279 trace=1 on a setdebug command in the Console, Bacula will write the debug
280 information to the file {\bf bacula.trace} in the directory from which Bacula
281 is executing. 
282
283 If you are having problems with ClientRunBeforeJob scripts randomly dying, 
284 it is possible that you have run into an Oracle bug.  See bug number 622 in
285 the bugs.bacula.org database.  The following information has been
286 provided by a user on this issue:
287
288 \footnotesize
289 \begin{verbatim}
290 The information in this document applies to:
291  Oracle HTTP Server - Version: 9.0.4
292  Microsoft Windows Server 2003
293  Symptoms
294  When starting an OC4J instance, the System Clock runs faster, about 7
295 seconds per minute.
296  
297  Cause
298  
299  + This is caused by the Sun JVM bug 4500388, which states that "Calling
300 Thread.sleep() with a small argument affects the system clock". Although
301 this is reported as fixed in JDK 1.4.0_02, several reports contradict this
302 (see the bug in
303 http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4500388).
304  
305  + Also reported by Microsoft as "The system clock may run fast when you
306 use the ACPI power management timer as a high-resolution counter on Windows
307 2000-based computers" (See http://support.microsoft.com/?id=821893)
308 \end{verbatim}
309 \normalsize
310
311 You may wish to start the daemon with debug mode on rather than doing it
312 using bconsole. To do so, edit the following registry key:
313
314 \footnotesize
315 \begin{verbatim}
316 HKEY_LOCAL_MACHINE\HARDWARE\SYSTEM\CurrentControlSet\Services\Bacula-dir
317 \end{verbatim}
318 \normalsize
319
320 using regedit, then add -dnn after the /service option, where nn represents
321 the debug level you want.
322
323 \label{Compatibility}
324 \section{Windows Compatibility Considerations}
325 \index[general]{Windows Compatibility Considerations}
326 \index[general]{Considerations!Windows Compatibility}
327
328 If you are not using the VSS (Volume Shadow Copy) option described in the
329 next section of this chapter, and if any applications are running during
330 the backup and they have files opened exclusively, Bacula will not be able
331 to backup those files, so be sure you close your applications (or tell your
332 users to close their applications) before the backup.  Fortunately, most
333 Microsoft applications do not open files exclusively so that they can be
334 backed up.  However, you will need to experiment.  In any case, if Bacula
335 cannot open the file, it will print an error message, so you will always
336 know which files were not backed up.  For version 1.37.25 and greater, see
337 the section below on Volume Shadow Copy Service that permits backing up any
338 file.
339
340 During backup, Bacula doesn't know about the system registry, so you will
341 either need to write it out to an ASCII file using {\bf regedit~~/e} or use a
342 program specifically designed to make a copy or backup the registry. 
343
344 In Bacula version 1.31 and later, we use Windows backup API calls by
345 default.  Typical of Windows, programming these special BackupRead and
346 BackupWrite calls is a real nightmare of complications.  The end result
347 gives some distinct advantages and some disadvantages.
348
349 First, the advantages are that Windows systems, the security and
350 ownership information is now backed up.  In addition, with the exception of
351 files in exclusive use by another program, Bacula can now access all system
352 files.  This means that when you restore files, the security and ownership
353 information will be restored on Windows along with the data.
354
355 The disadvantage of the Windows backup API calls is that it produces
356 non-portable backups.  That is files and their data that are backed up on
357 Windows using the native API calls (BackupRead/BackupWrite) cannot be
358 directly restored on Linux or Unix systems.  Bacula should be able to read
359 non-portable backups on any system and restore the data appropriately.
360 However, on a system that does not have the BackupRead/BackupWrite calls
361 (older Windows versions and all Unix/Linux machines), though the file data
362 can be restored, the Windows security and access control data will not be
363 restored.  This means that a standard set of access permissions will be set
364 for such restored files.
365         
366
367 As a default, Bacula backs up Windows systems using the Windows API calls.
368 If you want to backup data on a Windows system and restore it on a
369 Unix or Linux system, we have provided a special {\bf portable} option
370 that backs up the data in a portable fashion by using portable API calls.
371 See the \ilink{portable option}{portable} on the Include statement in a
372 FileSet resource in the Director's configuration chapter for the details on
373 setting this option.  However, using the portable option means you may have
374 permissions problems accessing files, and none of the security and
375 ownership information will be backed up or restored.  The file data can,
376 however, be restored on any system.
377
378 You should always be able to restore any file backed up on Unix or Win95/98/Me
379 to any other system. On some older Windows systems, you may have to
380 reset the ownership of such restored files. 
381
382 Finally, if you specify the {\bf portable=yes} option on the files you back
383 up. Bacula will be able to restore them on any other system. However, any
384 Windows specific security and ownership information will be lost. 
385
386 The following matrix will give you an idea of what you can expect. Thanks to
387 Marc Brueckner for doing the tests: 
388
389 \addcontentsline{lot}{table}{WinNT/2K/XP Restore Portability Status}
390 \begin{longtable}{|l|l|p{2.8in}|}
391  \hline 
392 \multicolumn{1}{|c|}{\bf Backup OS} & \multicolumn{1}{c|}{\bf Restore OS}
393 & \multicolumn{1}{c|}{\bf Results } \\
394  \hline {WinMe} & {WinMe} & {Works } \\
395  \hline {WinMe} & {WinNT} & {Works (SYSTEM permissions) } \\
396  \hline {WinMe} & {WinXP} & {Works (SYSTEM permissions) } \\
397  \hline {WinMe} & {Linux} & {Works (SYSTEM permissions) } \\
398  \hline {\ } & {\ } & {\ } \\
399  \hline {WinXP} & {WinXP} & {Works } \\
400  \hline {WinXP} & {WinNT} & {Works (all files OK, but got "The data is invalid"
401 message) } \\
402  \hline {WinXP} & {WinMe} & {Error: Windows data stream not supported. } \\
403  \hline {WinXP} & {WinMe} & {Works if {\bf Portable=yes} specified during backup.} \\
404  \hline {WinXP} & {Linux} & {Error: Windows data stream not supported. } \\
405  \hline {WinXP} & {Linux} & {Works if {\bf Portable=yes} specified during backup.}\\
406  \hline {\ } & {\ } & {\ } \\
407  \hline {WinNT} & {WinNT} & {Works } \\
408  \hline {WinNT} & {WinXP} & {Works } \\
409  \hline {WinNT} & {WinMe} & {Error: Windows data stream not supported. } \\
410  \hline {WinNT} & {WinMe} & {Works if {\bf Portable=yes} specified during backup.}\\
411  \hline {WinNT} & {Linux} & {Error: Windows data stream not supported. } \\
412  \hline {WinNT} & {Linux} & {Works if {\bf Portable=yes} specified during backup. }\\
413  \hline {\ } & {\ } & {\ } \\
414  \hline {Linux} & {Linux} & {Works } \\
415  \hline {Linux} & {WinNT} & {Works (SYSTEM permissions) } \\
416  \hline {Linux} & {WinMe} & {Works } \\
417  \hline {Linux} & {WinXP} & {Works (SYSTEM permissions)}
418 \\ \hline 
419 \end{longtable}
420
421 Note: with Bacula versions 1.39.x and later, non-portable Windows data can
422 be restore to any machine.
423
424
425 \label{VSS}
426 \section{Volume Shadow Copy Service}
427 \index[general]{Volume Shadow Copy Service}
428 \index[general]{VSS}
429 Microsoft added VSS to Windows XP and Windows 2003. From the perspective of
430 a backup-solution for Windows, this is an extremely important step. VSS
431 allows Bacula to backup open files and even to interact with applications like
432 RDBMS to produce consistent file copies. VSS aware applications are called
433 VSS Writers, they register with the OS so that when Bacula wants to do a
434 Snapshot, the OS will notify the register Writer programs, which may then
435 create a consistent state in their application, which will be backed up.
436 Examples for these writers are "MSDE" (Microsoft database
437 engine), "Event Log Writer", "Registry Writer" plus 3rd
438 party-writers.  If you have a non-vss aware application (e.g.
439 SQL Anywhere or probably MySQL), a shadow copy is still generated
440 and the open files can be backed up, but there is no guarantee
441 that the file is consistent.
442
443 Bacula produces a message from each of the registered writer programs
444 when it is doing a VSS backup so you know which ones are correctly backed
445 up.
446
447 Technically Bacula creates a shadow copy as soon as the backup process
448 starts. It does then backup all files from the shadow copy and destroys the
449 shadow copy after the backup process. Please have in mind, that VSS
450 creates a snapshot and thus backs up the system at the state it had
451 when starting the backup. It will disregard file changes which occur during
452 the backup process.
453
454 VSS can be turned on by placing an
455
456 \index[dir]{Enable VSS}
457 \index[general]{Enable VSS}
458 \begin{verbatim}
459 Enable VSS = yes
460 \end{verbatim}
461
462 in your FileSet resource. 
463
464 The VSS aware File daemon has the letters VSS on the signon line that
465 it produces when contacted by the console. For example:
466 \begin{verbatim}
467 Tibs-fd Version: 1.37.32 (22 July 2005) VSS Windows XP MVS NT 5.1.2600
468 \end{verbatim}
469 the VSS is shown in the line above. This only means that the File daemon
470 is capable of doing VSS not that VSS is turned on for a particular backup.
471 There are two ways of telling if VSS is actually turned on during a backup.
472 The first is to look at the status output for a job, e.g.:
473 \footnotesize
474 \begin{verbatim}
475 Running Jobs:
476 JobId 1 Job NightlySave.2005-07-23_13.25.45 is running.
477     VSS Backup Job started: 23-Jul-05 13:25
478     Files=70,113 Bytes=3,987,180,650 Bytes/sec=3,244,247
479     Files Examined=75,021
480     Processing file: c:/Documents and Settings/kern/My Documents/My Pictures/Misc1/Sans titre - 39.pdd
481     SDReadSeqNo=5 fd=352
482 \end{verbatim}
483 \normalsize
484 Here, you see under Running Jobs that JobId 1 is "VSS Backup Job started ..." 
485 This means that VSS is enabled for that job.  If VSS is not enabled, it will
486 simply show "Backup Job started ..." without the letters VSS.
487
488 The second way to know that the job was backed up with VSS is to look at the 
489 Job Report, which will look something like the following:
490 \footnotesize
491 \begin{verbatim}
492 23-Jul 13:25 rufus-dir: Start Backup JobId 1, Job=NightlySave.2005-07-23_13.25.45
493 23-Jul 13:26 rufus-sd: Wrote label to prelabeled Volume "TestVolume001" on device "DDS-4" (/dev/nst0)
494 23-Jul 13:26 rufus-sd: Spooling data ...
495 23-Jul 13:26 Tibs: Generate VSS snapshots. Driver="VSS WinXP", Drive(s)="C"
496 23-Jul 13:26 Tibs: VSS Writer: "MSDEWriter", State: 1 (VSS_WS_STABLE)
497 23-Jul 13:26 Tibs: VSS Writer: "Microsoft Writer (Bootable State)", State: 1 (VSS_WS_STABLE)
498 23-Jul 13:26 Tibs: VSS Writer: "WMI Writer", State: 1 (VSS_WS_STABLE)
499 23-Jul 13:26 Tibs: VSS Writer: "Microsoft Writer (Service State)", State: 1 (VSS_WS_STABLE)
500 \end{verbatim}
501 \normalsize
502 In the above Job Report listing, you see that the VSS snapshot was generated for drive C (if
503 other drives are backed up, they will be listed on the {\bf Drive(s)="C"}  You also see the
504 reports from each of the writer program.  Here they all report VSS\_WS\_STABLE, which means
505 that you will get a consistent snapshot of the data handled by that writer.
506
507 \section{VSS Problems}
508 \index[general]{Problems!VSS}
509 \index[fd] {Problems!VSS}
510 \index[general]{VSS Problems}
511 \index[fd]{VSS Problems}
512
513 If you are experiencing problems such as VSS hanging on MSDE, first try
514 running {\bf vssadmin} to check for problems, then try running {\bf
515 ntbackup} which also uses VSS to see if it has similar problems. If so, you
516 know that the problem is in your Windows machine and not with Bacula.
517
518 The FD hang problems were reported with {\bf MSDEwriter} when:
519 \begin{itemize}
520 \item a local firewall locked local access to the MSDE TCP port (MSDEwriter
521 seems to use TCP/IP and not Named Pipes).  
522 \item msdtcs was installed to run under "localsystem": try running msdtcs
523 under  networking account (instead of local system) (com+ seems to work
524 better with this configuration).
525 \end{itemize}
526
527
528 \section{Windows Firewalls}
529 \index[general]{Firewalls!Windows}
530 \index[general]{Windows Firewalls}
531
532 If you turn on the firewalling feature on Windows (default in WinXP SP2), you
533 are likely to find that the Bacula ports are blocked and you cannot
534 communicate to the other daemons. This can be deactivated through the {\bf
535 Security Notification} dialog, which is apparently somewhere in the {\bf
536 Security Center}. I don't have this on my computer, so I cannot give the exact
537 details. 
538
539 The command: 
540
541 \footnotesize
542 \begin{verbatim}
543 netsh firewall set opmode disable
544 \end{verbatim}
545 \normalsize
546
547 is purported to disable the firewall, but this command is not accepted on my
548 WinXP Home machine. 
549
550 \section{Windows Port Usage}
551 \index[general]{Windows Port Usage}
552 \index[general]{Usage!Windows Port}
553
554 If you want to see if the File daemon has properly opened the port and is
555 listening, you can enter the following command in a shell window: 
556
557 \footnotesize
558 \begin{verbatim}
559    netstat -an | findstr 910[123]
560 \end{verbatim}
561 \normalsize
562
563 TopView is another program that has been recommend, but it is not a
564 standard Windows program, so you must find and download it from the Internet.
565
566 \section{Windows Disaster Recovery}
567 \index[general]{Recovery!Windows Disaster}
568 \index[general]{Windows Disaster Recovery}
569
570 We don't currently have a good solution for disaster recovery on Windows as we
571 do on Linux. The main piece lacking is a Windows boot floppy or a Windows boot
572 CD. Microsoft releases a Windows Pre-installation Environment ({\bf WinPE})
573 that could possibly work, but we have not investigated it. This means that
574 until someone figures out the correct procedure, you must restore the OS from
575 the installation disks, then you can load a Bacula client and restore files.
576 Please don't count on using {\bf bextract} to extract files from your backup
577 tapes during a disaster recovery unless you have backed up those files using
578 the {\bf portable} option. {\bf bextract} does not run on Windows, and the
579 normal way Bacula saves files using the Windows API prevents the files from
580 being restored on a Unix machine. Once you have an operational Windows OS
581 loaded, you can run the File daemon and restore your user files. 
582
583 Please see 
584 \ilink{ Disaster Recovery of Windows Systems}{Windows33} for the latest
585 suggestion, which looks very promising. 
586
587 It looks like Bart PE Builder, which creates a Windows PE (Pre-installation
588 Environment) Boot-CD, may be just what is needed to build a complete disaster
589 recovery system for Windows. This distribution can be found at 
590 \elink{http://www.nu2.nu/pebuilder/}{http://www.nu2.nu/pebuilder/}.
591
592 \section{Windows Restore Problems}
593 \index[general]{Problems!Windows Restore}
594 \index[general]{Windows Restore Problems}
595 Please see the  
596 \ilink{Restore Chapter}{Windows} of this manual for problems
597 that you might encounter doing a restore.
598
599 section{Windows Backup Problems}
600 \index[general]{Problems!Windows Backup}
601 \index[general]{Windows Backup Problems}
602 If during a Backup, you get the message: 
603 {\bf ERR=Access is denied} and you are using the portable option,
604 you should try both adding both the non-portable (backup API) and
605 the Volume Shadow Copy options to your Director's conf file.
606
607 In the Options resource:
608 \footnotesize
609 \begin{verbatim}
610 portable = no
611 \end{verbatim}
612 \normalsize
613
614 In the FileSet resource:
615 \footnotesize
616 \begin{verbatim}
617 enablevss = yes
618 \end{verbatim}
619 \normalsize
620
621 In general, specifying these two options should allow you to backup
622 any file on a Windows system.  However, in some cases, if users
623 have allowed to have full control of their folders, even system programs
624 such a Bacula can be locked out.  In this case, you must identify
625 which folders or files are creating the problem and do the following:
626
627 \begin{enumerate}
628 \item Grant ownership of the file/folder to the Administrators group,
629 with the option to replace the owner on all child objects.
630 \item Grant full control permissions to the Administrators group,
631 and change the user's group to only have Modify permission to
632 the file/folder and all child objects.
633 \end{enumerate}
634
635 Thanks to Georger Araujo for the above information.
636
637 \section{Windows Ownership and Permissions Problems}
638 \index[general]{Problems!Windows Ownership and Permissions}
639 \index[general]{Windows Ownership and Permissions Problems}
640
641 If you restore files backed up from Windows to an alternate directory,
642 Bacula may need to create some higher level directories that were not saved
643 (or restored). In this case, the File daemon will create them under the SYSTEM
644 account because that is the account that Bacula runs under as a service. As of
645 version 1.32f-3, Bacula creates these files with full access permission.
646 However, there may be cases where you have problems accessing those files even
647 if you run as administrator. In principle, Microsoft supplies you with the way
648 to cease the ownership of those files and thus change the permissions.
649 However, a much better solution to working with and changing Windows permissions
650 is the program {\bf SetACL}, which can be found at 
651 \elink{http://setacl.sourceforge.net/}{http://setacl.sourceforge.net/}. 
652
653 If you have not installed Bacula while running as Administrator
654 and if Bacula is not running as a Process with the userid (User Name) SYSTEM, 
655 then it is very unlikely that it will have sufficient permission to
656 access all your files. 
657
658 Some users have experienced problems restoring files that participate in
659 the Active Directory. They also report that changing the userid under which
660 Bacula (bacula-fd.exe) runs, from SYSTEM to a Domain Admin userid, resolves
661 the problem.
662
663
664 \section{Manually resetting the Permissions}
665 \index[general]{Manually resetting the Permissions}
666 \index[general]{Permissions!Manually resetting the}
667
668 The following solution was provided by Dan Langille \lt{}dan at langille in
669 the dot org domain\gt{}. The steps are performed using Windows 2000 Server but
670 they should apply to most Windows platforms. The procedure outlines how to deal
671 with a problem which arises when a restore creates a top-level new directory.
672 In this example, "top-level" means something like {\bf
673 c:\textbackslash{}src}, not {\bf c:\textbackslash{}tmp\textbackslash{}src}
674 where {\bf c:\textbackslash{}tmp} already exists. If a restore job specifies /
675 as the {\bf Where:} value, this problem will arise. 
676
677 The problem appears as a directory which cannot be browsed with Windows
678 Explorer. The symptoms include the following message when you try to click on
679 that directory: 
680
681 \includegraphics{\idir access-is-denied.eps} 
682
683 If you encounter this message, the following steps will change the permissions
684 to allow full access. 
685
686 \begin{enumerate}
687 \item right click on the top level directory (in this example, {\bf c:/src})
688    and  select {\bf Properties}. 
689 \item click on the Security tab. 
690 \item If the following message appears, you can ignore it, and click on {\bf
691    OK}. 
692
693 \includegraphics{\idir view-only.eps} 
694
695 You should see something like this: 
696
697 \includegraphics{\idir properties-security.eps} 
698 \item click on Advanced 
699 \item click on the Owner tab 
700 \item Change the owner to something other than the current owner (which is
701    {\bf SYSTEM} in this example as shown below). 
702
703 \includegraphics{\idir properties-security-advanced-owner.eps} 
704 \item ensure the "Replace owner on subcontainers and objects" box is 
705    checked 
706 \item click on OK 
707 \item When the message "You do not have permission to read the contents of
708    directory c:\textbackslash{}src\textbackslash{}basis. Do you wish to replace
709    the directory permissions with permissions granting you Full Control?", click
710 on Yes. 
711
712 \includegraphics{\idir confirm.eps} 
713 \item Click on OK to close the Properties tab 
714    \end{enumerate}
715
716 With the above procedure, you should now have full control over your restored
717 directory. 
718
719 In addition to the above methods of changing permissions, there is a Microsoft
720 program named {\bf cacls} that can perform similar functions.
721
722 \section{Backing Up the WinNT/XP/2K System State}
723 \index[general]{State!Backing Up the WinNT/XP/2K System}
724 \index[general]{Backing Up the WinNT/XP/2K System State}
725
726 Note, most of this section applies to the older Windows OSes that
727 do not have VSS. On newer Windows OSes that have VSS, all files
728 including the System State will by default be properly backed
729 up by Bacula.
730
731 A suggestion by Damian Coutts using Microsoft's NTBackup utility in
732 conjunction with Bacula should permit a full restore of any damaged system
733 files on Win2K/XP. His suggestion is to do an NTBackup of the critical system
734 state prior to running a Bacula backup with the following command: 
735
736 \footnotesize
737 \begin{verbatim}
738 ntbackup backup systemstate /F c:\systemstate.bkf
739 \end{verbatim}
740 \normalsize
741
742 The {\bf backup} is the command, the {\bf systemstate} says to backup only the
743 system state and not all the user files, and the {\bf /F
744 c:\textbackslash{}systemstate.bkf} specifies where to write the state file.
745 this file must then be saved and restored by Bacula. 
746
747 To restore the system state, you first reload a base operating system if the
748 OS is damaged, otherwise, this is not necessary, then you would use Bacula to
749 restore all the damaged or lost user's files and to recover the {\bf
750 c:\textbackslash{}systemstate.bkf} file. Finally if there are any damaged or
751 missing system files or registry problems, you run {\bf NTBackup} and {\bf
752 catalogue} the system statefile, and then select it for restore. The
753 documentation says you can't run a command line restore of the systemstate. 
754
755 To the best of my knowledge, this has not yet been tested. If you test it,
756 please report your results to the Bacula email list. 
757
758 Note, Bacula uses VSS to backup and restore open files and
759 system files, but on older Windows machines such as WinNT and
760 Win2000, VSS is not implemented by Microsoft so that you must
761 use some special techniques to back them up as described
762 above.  On new Windows machines, Bacula will backup and restore
763 all files including the system state providing you have
764 VSS enabled in your Bacula FileSet (default).
765
766 \section{Fixing the Windows Boot Record}
767 \index[general]{Fixing the Windows Boot Record}
768 \index[general]{Windows!Fixing the Boot Record}
769 A tip from a user:
770 An effective way to restore a Windows backup for
771 those who do not purchase the bare metal restore
772 capability is to install Windows on a different
773 hard drive and restore the backup.  Then run the
774 recovery CD and run
775
776 \begin{verbatim}
777 diskpart
778    select disk 0
779    select part 1
780    active
781    exit
782
783 bootrec /rebuldbcd
784 bootrec /fixboot
785 bootrec /fixmbr
786 \end{verbatim}
787
788
789 \section{Considerations for Filename Specifications}
790 \index[general]{Windows!Considerations for Filename Specifications}
791
792 Please see the 
793 \ilink{Director's Configuration chapter}{win32} of this manual
794 for important considerations on how to specify Windows paths in Bacula FileSet
795 Include and Exclude directives. 
796
797 \index[general]{Unicode}
798 Bacula versions prior to 1.37.28 do not support Windows Unicode filenames.
799 As of that version, both {\bf bconsole} and {\bf bwx-console} support Windows
800 Unicode filenames. There may still be some problems with multiple byte
801 characters (e.g. Chinese, ...) where it is a two byte character but the
802 displayed character is not two characters wide.
803
804 \index[general]{Windows Path Length Restriction}
805 Path/filenames longer than 260 characters (up to 32,000) are supported
806 beginning with Bacula version 1.39.20. Older Bacula versions support
807 only 260 character path/filenames.
808
809 \section{Windows Specific File daemon Command Line}
810 \index[general]{Client!Windows Specific File daemon Command Line Options}
811 \index[general]{Windows Specific File daemon Command Line Options}
812
813 These options are not normally seen or used by the user, and are documented
814 here only for information purposes. At the current time, to change the default
815 options, you must either manually run {\bf Bacula} or you must manually edit
816 the system registry and modify the appropriate entries. 
817
818 In order to avoid option clashes between the options necessary for {\bf
819 Bacula} to run on Windows and the standard Bacula options, all Windows
820 specific options are signaled with a forward slash character (/), while as
821 usual, the standard Bacula options are signaled with a minus (-), or a minus
822 minus (\verb:--:). All the standard Bacula options can be used on the Windows
823 version. In addition, the following Windows only options are implemented: 
824
825 \begin{description}
826
827 \item [/service ]
828    \index[fd]{/service}
829    Start Bacula as a service 
830
831 \item [/run ]
832    \index[fd]{/run}
833    Run the Bacula application  
834
835 \item [/install ]
836    \index[fd]{/install}
837    Install Bacula as a service in the system registry  
838
839 \item [/remove ]
840    \index[fd]{/remove}
841    Uninstall Bacula from the system registry  
842
843 \item [/about ]
844    \index[fd]{/about}
845    Show the Bacula about dialogue box  
846
847 \item [/status ]
848    \index[fd]{/status}
849    Show the Bacula status dialogue box  
850
851 \item [/events ]
852    \index[fd]{/events}
853    Show the Bacula events dialogue box (not  yet implemented)  
854
855 \item [/kill ]
856    \index[fd]{/kill}
857    Stop any running {\bf Bacula}  
858
859 \item [/help ]
860    \index[fd]{/help}
861    Show the Bacula help dialogue box 
862 \end{description}
863
864 It is important to note that under normal circumstances the user should never
865 need to use these options as they are normally handled by the system
866 automatically once Bacula is installed. However, you may note these options in
867 some of the .bat files that have been created for your use. 
868
869 \section{Shutting down Windows Systems}
870 \index[general]{Shutting down Windows Systems}
871 \index[general]{Systems!Shutting down Windows}
872
873 Some users like to shutdown their Windows machines after a backup using a
874 Client Run After Job directive. If you want to do something similar, you might
875 take the shutdown program from the 
876 \elink{apcupsd project}{http://www.apcupsd.com} or one from the 
877 \elink{Sysinternals project}
878 {http://technet.microsoft.com/en-us/sysinternals/bb897541.aspx}.