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