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