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