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