summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorRichard Jones <rjones@redhat.com>2010-02-08 16:44:41 +0000
committerRichard Jones <rjones@redhat.com>2010-02-08 16:44:41 +0000
commitc0baa7bdb2b404e8c808700984b3fc1a699d8dd7 (patch)
tree1b9448da5b77321c234303575a43b8c1caf0126f /src
parent6c97a65ce768b357a1481cde0533d4cf0b8b931c (diff)
downloadlibguestfs-c0baa7bdb2b404e8c808700984b3fc1a699d8dd7.tar.gz
libguestfs-c0baa7bdb2b404e8c808700984b3fc1a699d8dd7.tar.xz
libguestfs-c0baa7bdb2b404e8c808700984b3fc1a699d8dd7.zip
Documentation: Added a section on libguestfs gotchas.
Diffstat (limited to 'src')
-rw-r--r--src/guestfs.pod55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/guestfs.pod b/src/guestfs.pod
index c959d236..84eec635 100644
--- a/src/guestfs.pod
+++ b/src/guestfs.pod
@@ -524,6 +524,61 @@ For documentation see L<guestfish(1)>.
=back
+=head2 LIBGUESTFS GOTCHAS
+
+L<http://en.wikipedia.org/wiki/Gotcha_(programming)>: "A feature of a
+system [...] that works in the way it is documented but is
+counterintuitive and almost invites mistakes."
+
+Since we developed libguestfs and the associated tools, there are
+several things we would have designed differently, but are now stuck
+with for backwards compatibility or other reasons. If there is ever a
+libguestfs 2.0 release, you can expect these to change. Beware of
+them.
+
+=over 4
+
+=item Autosync / forgetting to sync.
+
+When modifying a filesystem from C or another language, you B<must>
+unmount all filesystems and call L</guestfs_sync> explicitly before
+you close the libguestfs handle. You can also call:
+
+ guestfs_set_autosync (handle, 1);
+
+to have the unmount/sync done automatically for you when the handle is
+closed. (This feature is called "autosync", L</guestfs_set_autosync>
+q.v.)
+
+If you forget to do this, then it is entirely possible that your
+changes won't be written out, or will be partially written, or (very
+rarely) that you'll get disk corruption.
+
+Note that in L<guestfish(3)> I<autosync is the default>. So quick and
+dirty guestfish scripts that forget to sync will work just fine, which
+can make this extra-puzzling if you are trying to debug a problem.
+
+=item Read-only should be the default.
+
+In L<guestfish(3)>, I<--ro> should be the default, and you should
+have to specify I<--rw> if you want to make changes to the image.
+
+This would reduce the potential to corrupt live VM images.
+
+Note that many filesystems change the disk when you just mount and
+unmount, even if you didn't perform any writes. You need to use
+C<guestfs_add_drive_ro> to guarantee that the disk is not changed.
+
+=item guestfish command line is hard to use.
+
+C<guestfish disk.img> doesn't do what people expect (open C<disk.img>
+for examination). It tries to run a guestfish command C<disk.img>
+which doesn't exist, so it fails, and it fails with a strange and
+unintuitive error message. Like the Bourne shell, we should have used
+C<guestfish -c command> to run commands.
+
+=back
+
=head1 CONNECTION MANAGEMENT
=head2 guestfs_h *