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