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