2 Release Notes for Bacula 2.2.5
4 Bacula code: Total files = 520 Total lines = 195,550 (*.h *.c *.in)
5 82 new files, 41,221 new lines of code, 208,380 lines of change from 2.0.3
7 This Director and Storage daemon must be upgraded at the same time,
8 but they should be compatible with all 2.0.x File daemons, unless you
9 use some of the new features that affect the FD. In other words, you should
10 not have to upgrade all your File daemons when you upgrade. There is
11 no database upgrade needed from version 2.0.x to 2.2.0.
13 Version 2.2.5 is a major bug fix release to version 2.2.4
14 - It fixes the following bugs: #961, 962, 963, 969, 968, 960,
15 964, (possibly 935 and 903), 953, 953, 967, 966, 965, 954,
16 957, 908, 958, and 955.
17 - It also improves listing performance problems in bat pointed
20 Version 2.2.4 is a minor bug fix release to version 2.2.3
21 - Possible fix for authorization problems bug #953.
22 - Possible fix for bug #908.
23 - Add waits to multiple exit detection code to try to force pid
24 file to always be deleted.
25 - Restore good dev.tar.gz to rescue set appropriate binary property.
27 - Fix seg fault in error exit of acquire_for_read after unsuccessfully
28 trying to switch drives by checking for blocking before unblocking.
30 - Cancel storage daemon in all cases where FD reports error. This
31 should fix virtually all cases of bug #920 and will ensure that Devices
32 are released as soon as possible.
33 - Fix error message that was clobbered when Dir tells SD it does not
34 have write permission on Volume. This should fix a minor point
35 in bug #942, but not the main problem.
36 - Fix migration code to get correct Volume name with multiple volumes
37 by skipping |. Fixes bug #936.
38 - Implement patch supplied by Landon to fix bug #944 where using
39 TLS with bconsole uses 99+% of the CPU.
40 - Fix bug #946 about "bacula-dir -t" which doesn't works
42 - Using "m" in bconsole will show messages as in prior versions
45 - Note, you need GTK >= 2.10 to be able to link the Tray Monitor
48 Version 2.2.3 is a critical bug fix release to version 2.2.2
49 - Fix bug #935, and possibly also bug #903 where files were not
50 restored. MediaId was not properly set in JobMedia record after
51 a Volume change. This bug is known to affect all versions from
52 2.0.0 on, and probably versions prior to that. A detailed analysis
53 of the bug can be found at:
55 http://www.bacula.org/downloads/bug-395.txt
57 - Add ./configure search in qwt-qt4 for qwt package
58 - Apply Martin Simmons patch that should turn off the new API usage
59 when batch insert is turned off allowing building on older
61 - Note, you need GTK >= 2.10 to be able to link the Tray Monitor
64 Version 2.2.2 is a minor bug fix release to 2.2.1
65 - Detect if new PosgreSQL batch insert API is present.
66 - Correct incorrect mempool call causing Director crash on older
67 systems that do not have va_copy().
68 - Update spec files for 2.2.1 release
70 Version 2.2.1 is mainly a minor bug fix release to version 2.2.0,
71 the main changes since 2.2.0 are:
72 - Fixed bugs #921, 930, and 923.
73 - More portable timezone offset in bsmtp thaks to Attila Fülöp.
74 - Fix several bat issues.
75 - Use GTK+ calls instead of egg files in tray-monitor.
76 - Win32 service routines rewritten
77 - Updated projects file
78 Please see the ChangeLog for details.
80 Notes on 2.2.0 release follow:
82 Areas requiring caution or testing:
83 - You must have the thread safe version of MySQL client libraries loaded
84 to build with MySQL enabled.
85 - Volumes are pruned only when absolutely necessary -- this may cause
86 your database to grow compared to prior Bacula versions.
87 - Solaris door and even port files are no longer restored (equivalent
88 to what we do with sockets).
89 - SQLite is no longer supported for Solaris -- it fails too often with
90 bus errors. SQLite3 should work on Solaris.
91 - The default setting for SQLite3 is now 'PRAGMA synchronous=OFF'.
92 This makes it run 30 times faster, but increases the possiblity
93 of a corrupted database if your server shuts down unexpectedly.
94 The default behavior can be changed in src/version.h
95 - Restore on Win32, and in particular on Vista is untested. Please
96 test before relying on it. It should backup and restore reparse
98 - Win32 servers are untested, and very likely not to work.
100 The major new features are:
101 - Much faster insertion of attributes (somewhere around 10 times),
102 many thanks to Eric Bollengier and Marc Cousin.
103 - First release of bat (Bacula Administration Tool). Note to build
104 bat you must explicitly enable it on the ./configure line, you
105 must have the Qt4 version 4.2 or later libraries loaded, the qwt
106 (Qt Graphics) package loaded, and qmake and the other Qt4 tools
107 must be available. Most of the implementation was done by Dirk Bartley.
108 - Red/Black restore in memory tree (500 times faster loading).
109 - The Regex Where code to allow easier relocation of restored files
111 - Socket level heartbeat for all connections (untested).
112 - posix_fadvise() use in the FD to improve performance reduces
113 swapping due to opening/reading lots of files. Win32 equivalent
115 - Much improved Volume reservation code that should eliminate most
116 conflicts experienced in multiple drive autochangers.
117 - Simpler locking in the SD in the reservation system.
118 - Detection of file size/date change during backup if enabled.
119 - New Recycle Pool feature -- thanks to Eric.
120 - Efficient implementation of very large include/exclude lists.
121 - Volumes are no longer pruned during 'status dir'
122 - Pruning is now more efficient, and if a Volume is purged,
123 during pruning, it is immediately discovered.
124 - License is now GPL v2 without modifications, fix a few copyright
125 mistakes made when adding FSFE copyright notice.
127 New ./configure options:
128 - --enable-bwx-console
133 - --enable-batch-insert
135 New bconsole commands:
141 - .pwd (in restore tree)
142 - restoreclient (keyword)
143 - backupclient (keyword)
144 - regexwhere (keyword)
145 - update jobid (new command)
146 - recyclepool (keyword)
149 - Heartbeat Interval (bconsole.conf)
150 - Heartbeat Interval (bacula-dir.conf in Director, Client, Storage)
151 - TLS Allowed CN (bacula-dir.conf in Client)
152 - Regex Where (bacula-dir.conf in Job)
153 - Strip Prefix (bacula-dir.conf in Job)
154 - Add Prefix (bacula-dir.conf in Job)
155 - Add Suffex (bacula-dir.conf in Job)
156 - Recycle Pool (bacula-dir.conf in Pool)
157 - FailJobOnError (bacula-dir.conf in RunScript)
158 - CheckFileChanges (bacula-dir.conf in FileSet)
159 - StripPath (bacula-dir.conf in FileSet)
161 Other features or bug fixes:
162 - Fixed bugs: 916, 910, 917, 914, 906, 907,
163 842, 830, 893, 861, 888, 886, 807, 877, 872
164 885, 887, 864, 874, 882, 881, 863, 859,
165 856, 854, 845, 847, 846, 809, 772,
166 822, 825, 824, 808, 802, 797, 798, 795, 789, 791,
167 788, 780, 763, 782, 612, 767, 775, 621, 772, 764,
168 766, 621, 761, 755, 750, 741, 747, 742, 744, and 743.
169 - Configure bat with --enable-bat. Define qwt libraries with
170 --with-qwt=<dir>. See Installation chapter of manual for details.
171 - Create a depkgs-qt package that has both Qt4 and qwt, which are
172 needed to build bat. Most modern Linux systems will have both
173 these packages in the distro.
174 - Storage overrides delete all previous storage definitions instead
176 - One should be able to mount and unmount removable devices if the
177 Device resource has Removeable Media set and the mount and unmount
178 directives are defined.
179 - ./configure will do a better job of searching for qwt libraries.
180 - The Win32 version can no longer be shutdown from the tray monitor.
181 Use the command line or the Services panne.
182 - Keep prune_volumes() from pruning the whole Scratch pool.
183 - More debug output in status storage.
184 - Correct moving a Scratch volume from pool to pool (some
185 critical columns were lost).
186 - Different locking in reservations and despooling systems,
187 which means more micro-locking and less macro-locking, which
188 should give a lot more concurrency at the expense of slightly
189 (<0.1%) more overhead due to more locking/unlocking, but
190 concurrent jobs should run much faster.
191 - Additional drive reservation algorithm that should solve a lot of
192 the problems experienced with multiple drive autochangers.
193 - Storage daemon status command enhanced to more clearly show Volume,
194 pool and media type when a job is waiting.
195 - Made bsmtp work with more strict SMTP servers.
196 - Detect doubly freed buffers in smartall.c
197 - wx-console renamed to bwx-console (Fedora request)
198 - gnome-console renamed to bgnome-console (Fedora request)
199 - Migration preserves original job's FileSetId
200 - Spooling implemented for migration jobs.
201 - Config files can be read through a pipe, by specifying a leading |
202 in front of the configuration path/filename.
203 - New memory command (bconsole) that will print the current Director's
204 memory usage, and an in use buffer dump.
205 - Console name changed from *Console* to -Console- to accomodate Win32
206 filename restrictions.
207 - Corrected the Win32 ftruncate bug.
208 - Additional version information added to Job reports.
209 - New -8 option for bsmtp to specify UTF-8 encoding type.
210 - bsmtp will no longer add < > to target (from, to, cc) if there
211 is already a < in the target.
212 - Prefer Mounted Volumes extended to mean a volume that is being
213 mounted by another job.
214 - Runscript timing set to same as version 1.38.11
215 - New TLS Allowed CN directive(s) permitted.
216 - New bconsole 'exec' command to run external script/command.
217 - Turn on FreeBSD/OpenBSD code to set EOT model on tape.
218 - Drop from root done before database is opened.
219 - Database user and name can be configured with:
220 --with-db-name=name --with-db-user=user
221 - Turn on wait_for_drive in mtx-changer script.
222 - Rework how bar codes are handled in mtx-changer script.
223 This appears to have been an unreported bug.
224 - Updated nagios plugin supplied by Christian Masopust
225 - Better restricted console ACL checking.
226 - New Client Connect Wait directive in Storage daemon so that
227 users can configure how long SD waits for FD connection.
228 - Bacula will no longer permit pruning of the currently running
229 job (note, if other jobs are running, they may be pruned).
230 - Sockets are no longer restored.
231 - dbcheck works in 300K chunks so will typically run faster.
232 - Include/Exclude lists can now be efficiently handled for quite
233 large sizes -- tens of thousands of entries.
234 - Several memory leaks in migration and database usage were fixed.
235 - New console keyword restoreclient, which specifies the client to
236 which the restore will be sent. The client keyword specifies
237 the backup client. The restoreclient keyword is optional if it is
238 not specified, the backup client will also be the restore client.
239 - The disk file size is now checked to ensure that it agrees with the
240 catalog value before Bacula will append to the disk (same as tape