|
|
cd6068 |
From 64c53898702fa6ae8bfbd1f0f2ec9fc09d96c66b Mon Sep 17 00:00:00 2001
|
|
|
022f11 |
From: "Richard W.M. Jones" <rjones@redhat.com>
|
|
|
022f11 |
Date: Mon, 29 Jul 2013 14:47:56 +0100
|
|
|
022f11 |
Subject: [PATCH] RHEL 7: Disable unsupported remote drive protocols
|
|
|
022f11 |
(RHBZ#962113).
|
|
|
022f11 |
|
|
|
022f11 |
This disables support for unsupported remote drive protocols:
|
|
|
022f11 |
|
|
|
022f11 |
* ftp
|
|
|
022f11 |
* ftps
|
|
|
022f11 |
* http
|
|
|
022f11 |
* https
|
|
|
022f11 |
* tftp
|
|
|
022f11 |
* gluster
|
|
|
022f11 |
* iscsi
|
|
|
022f11 |
* rbd
|
|
|
022f11 |
* sheepdog
|
|
|
022f11 |
* ssh
|
|
|
022f11 |
|
|
|
022f11 |
Note 'nbd' is not disabled, and of course 'file' works.
|
|
|
022f11 |
|
|
|
022f11 |
We hope to gradually add some of these back over the lifetime of RHEL 7.
|
|
|
022f11 |
---
|
|
|
022f11 |
fish/guestfish.pod | 67 ----------------------------
|
|
|
022f11 |
fish/test-add-uri.sh | 29 ------------
|
|
|
022f11 |
generator/actions.ml | 72 ------------------------------
|
|
|
022f11 |
src/drives.c | 8 ++++
|
|
|
022f11 |
src/guestfs.pod | 121 ---------------------------------------------------
|
|
|
022f11 |
5 files changed, 8 insertions(+), 289 deletions(-)
|
|
|
022f11 |
|
|
|
022f11 |
diff --git a/fish/guestfish.pod b/fish/guestfish.pod
|
|
|
022f11 |
index c19fe6c..a240280 100644
|
|
|
022f11 |
--- a/fish/guestfish.pod
|
|
|
022f11 |
+++ b/fish/guestfish.pod
|
|
|
022f11 |
@@ -1138,40 +1138,6 @@ The possible I<-a URI> formats are described below.
|
|
|
022f11 |
|
|
|
022f11 |
Add the local disk image (or device) called C<disk.img>.
|
|
|
022f11 |
|
|
|
022f11 |
-=head2 B<-a ftp://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a ftps://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a http://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a https://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a tftp://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk located on a remote FTP, HTTP or TFTP server.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /disk.img protocol:(ftp|...) server:tcp:example.com
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a gluster://example.com[:port]/disk>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk image located on GlusterFS storage.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The server is the one running C<glusterd>, and may be C<localhost>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /disk protocol:gluster server:tcp:example.com
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a iscsi://example.com[:port]/target-iqn-name[/lun]>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk located on an iSCSI server.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /target-iqn-name/lun protocol:iscsi server:tcp:example.com
|
|
|
022f11 |
-
|
|
|
022f11 |
=head2 B<-a nbd://example.com[:port]>
|
|
|
022f11 |
|
|
|
022f11 |
=head2 B<-a nbd://example.com[:port]/exportname>
|
|
|
022f11 |
@@ -1193,39 +1159,6 @@ The equivalent API command would be (no export name):
|
|
|
022f11 |
|
|
|
022f11 |
><fs> add "" protocol:nbd server:[tcp:example.com|unix:/socket]
|
|
|
022f11 |
|
|
|
022f11 |
-=head2 B<-a rbd://example.com[:port]/disk>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk image located on a Ceph (RBD/librbd) storage volume.
|
|
|
022f11 |
-
|
|
|
022f11 |
-Although libguestfs and Ceph supports multiple servers, only a single
|
|
|
022f11 |
-server can be specified when using this URI syntax.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /disk protocol:rbd server:tcp:example.com
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a sheepdog://[example.com[:port]]/volume/image>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk image located on a Sheepdog volume.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The server name is optional. Although libguestfs and Sheepdog
|
|
|
022f11 |
-supports multiple servers, only at most one server can be specified
|
|
|
022f11 |
-when using this URI syntax.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /disk protocol:sheepdog [server:tcp:example.com]
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head2 B<-a ssh://[user@]example.com[:port]/disk.img>
|
|
|
022f11 |
-
|
|
|
022f11 |
-Add a disk image located on a remote server, accessed using the Secure
|
|
|
022f11 |
-Shell (ssh) SFTP protocol. SFTP is supported out of the box by all
|
|
|
022f11 |
-major SSH servers.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The equivalent API command would be:
|
|
|
022f11 |
-
|
|
|
022f11 |
- ><fs> add /disk protocol:ssh server:tcp:example.com [username:user]
|
|
|
022f11 |
-
|
|
|
022f11 |
=head1 PROGRESS BARS
|
|
|
022f11 |
|
|
|
022f11 |
Some (not all) long-running commands send progress notification
|
|
|
022f11 |
diff --git a/fish/test-add-uri.sh b/fish/test-add-uri.sh
|
|
|
022f11 |
index dfeccf7..c481e88 100755
|
|
|
022f11 |
--- a/fish/test-add-uri.sh
|
|
|
022f11 |
+++ b/fish/test-add-uri.sh
|
|
|
022f11 |
@@ -37,14 +37,6 @@ function fail ()
|
|
|
022f11 |
$VG ./guestfish -x -a file://$(pwd)/test-add-uri.img </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
grep -sq 'add_drive ".*/test-add-uri.img"' test-add-uri.out || fail
|
|
|
022f11 |
|
|
|
022f11 |
-# curl
|
|
|
022f11 |
-$VG ./guestfish -x -a ftp://user@example.com/disk.img </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk.img" "protocol:ftp" "server:tcp:example.com" "username:user"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-# gluster
|
|
|
022f11 |
-$VG ./guestfish -x -a gluster://example.com/disk </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk" "protocol:gluster" "server:tcp:example.com"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
# NBD
|
|
|
022f11 |
$VG ./guestfish -x -a nbd://example.com </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
grep -sq 'add_drive "" "protocol:nbd" "server:tcp:example.com"' test-add-uri.out || fail
|
|
|
022f11 |
@@ -58,26 +50,5 @@ grep -sq 'add_drive "" "protocol:nbd" "server:unix:/sk"' test-add-uri.out || fai
|
|
|
022f11 |
$VG ./guestfish -x -a 'nbd:///export?socket=/sk' </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
grep -sq 'add_drive "/export" "protocol:nbd" "server:unix:/sk"' test-add-uri.out || fail
|
|
|
022f11 |
|
|
|
022f11 |
-# rbd
|
|
|
022f11 |
-$VG ./guestfish -x -a rbd://example.com:3000/disk </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk" "protocol:rbd" "server:tcp:example.com:3000"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-# sheepdog
|
|
|
022f11 |
-$VG ./guestfish -x -a sheepdog:///volume/image </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/volume/image" "protocol:sheepdog"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-$VG ./guestfish -x -a sheepdog://example.com:3000/volume/image </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/volume/image" "protocol:sheepdog" "server:tcp:example.com:3000"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-# ssh
|
|
|
022f11 |
-$VG ./guestfish -x -a ssh://example.com/disk.img </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk.img" "protocol:ssh" "server:tcp:example.com"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-$VG ./guestfish -x -a ssh://user@example.com/disk.img </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk.img" "protocol:ssh" "server:tcp:example.com" "username:user"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
-$VG ./guestfish -x -a ssh://user@example.com:2000/disk.img </dev/null >test-add-uri.out 2>&1
|
|
|
022f11 |
-grep -sq 'add_drive "/disk.img" "protocol:ssh" "server:tcp:example.com:2000" "username:user"' test-add-uri.out || fail
|
|
|
022f11 |
-
|
|
|
022f11 |
rm test-add-uri.out
|
|
|
022f11 |
rm test-add-uri.img
|
|
|
022f11 |
diff --git a/generator/actions.ml b/generator/actions.ml
|
|
|
cd6068 |
index e3b57ff..879080f 100644
|
|
|
022f11 |
--- a/generator/actions.ml
|
|
|
022f11 |
+++ b/generator/actions.ml
|
|
|
022f11 |
@@ -1333,27 +1333,6 @@ C<filename> is interpreted as a local file or device.
|
|
|
022f11 |
This is the default if the optional protocol parameter
|
|
|
022f11 |
is omitted.
|
|
|
022f11 |
|
|
|
022f11 |
-=item C<protocol = \"ftp\"|\"ftps\"|\"http\"|\"https\"|\"tftp\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to a remote FTP, HTTP or TFTP server.
|
|
|
022f11 |
-The C<server> parameter must also be supplied - see below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/FTP, HTTP AND TFTP>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=item C<protocol = \"gluster\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to the GlusterFS server.
|
|
|
022f11 |
-The C<server> parameter must also be supplied - see below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/GLUSTER>
|
|
|
022f11 |
-
|
|
|
022f11 |
-=item C<protocol = \"iscsi\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to the iSCSI server.
|
|
|
022f11 |
-The C<server> parameter must also be supplied - see below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/ISCSI>.
|
|
|
022f11 |
-
|
|
|
022f11 |
=item C<protocol = \"nbd\">
|
|
|
022f11 |
|
|
|
022f11 |
Connect to the Network Block Device server.
|
|
|
022f11 |
@@ -1361,31 +1340,6 @@ The C<server> parameter must also be supplied - see below.
|
|
|
022f11 |
|
|
|
022f11 |
See also: L<guestfs(3)/NETWORK BLOCK DEVICE>.
|
|
|
022f11 |
|
|
|
022f11 |
-=item C<protocol = \"rbd\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to the Ceph (librbd/RBD) server.
|
|
|
022f11 |
-The C<server> parameter must also be supplied - see below.
|
|
|
022f11 |
-The C<username> parameter may be supplied. See below.
|
|
|
022f11 |
-The C<secret> parameter may be supplied. See below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/CEPH>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=item C<protocol = \"sheepdog\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to the Sheepdog server.
|
|
|
022f11 |
-The C<server> parameter may also be supplied - see below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/SHEEPDOG>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=item C<protocol = \"ssh\">
|
|
|
022f11 |
-
|
|
|
022f11 |
-Connect to the Secure Shell (ssh) server.
|
|
|
022f11 |
-
|
|
|
022f11 |
-The C<server> parameter must be supplied.
|
|
|
022f11 |
-The C<username> parameter may be supplied. See below.
|
|
|
022f11 |
-
|
|
|
022f11 |
-See also: L<guestfs(3)/SSH>.
|
|
|
022f11 |
-
|
|
|
022f11 |
=back
|
|
|
022f11 |
|
|
|
022f11 |
=item C<server>
|
|
|
022f11 |
@@ -1396,13 +1350,7 @@ is a list of server(s).
|
|
|
022f11 |
Protocol Number of servers required
|
|
|
022f11 |
-------- --------------------------
|
|
|
022f11 |
file List must be empty or param not used at all
|
|
|
022f11 |
- ftp|ftps|http|https|tftp Exactly one
|
|
|
022f11 |
- gluster Exactly one
|
|
|
022f11 |
- iscsi Exactly one
|
|
|
022f11 |
nbd Exactly one
|
|
|
022f11 |
- rbd One or more
|
|
|
022f11 |
- sheepdog Zero or more
|
|
|
022f11 |
- ssh Exactly one
|
|
|
022f11 |
|
|
|
022f11 |
Each list element is a string specifying a server. The string must be
|
|
|
022f11 |
in one of the following formats:
|
|
|
022f11 |
@@ -1416,26 +1364,6 @@ in one of the following formats:
|
|
|
022f11 |
If the port number is omitted, then the standard port number
|
|
|
022f11 |
for the protocol is used (see C</etc/services>).
|
|
|
022f11 |
|
|
|
022f11 |
-=item C<username>
|
|
|
022f11 |
-
|
|
|
022f11 |
-For the C<ftp>, C<ftps>, C<http>, C<https>, C<iscsi>, C<rbd>, C<ssh>
|
|
|
022f11 |
-and C<tftp> protocols, this specifies the remote username.
|
|
|
022f11 |
-
|
|
|
022f11 |
-If not given, then the local username is used for C<ssh>, and no authentication
|
|
|
022f11 |
-is attempted for ceph. But note this sometimes may give unexpected results, for
|
|
|
022f11 |
-example if using the libvirt backend and if the libvirt backend is configured to
|
|
|
022f11 |
-start the qemu appliance as a special user such as C<qemu.qemu>. If in doubt,
|
|
|
022f11 |
-specify the remote username you want.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=item C<secret>
|
|
|
022f11 |
-
|
|
|
022f11 |
-For the C<rbd> protocol only, this specifies the 'secret' to use when
|
|
|
022f11 |
-connecting to the remote device.
|
|
|
022f11 |
-
|
|
|
022f11 |
-If not given, then a secret matching the given username will be looked up in the
|
|
|
022f11 |
-default keychain locations, or if no username is given, then no authentication
|
|
|
022f11 |
-will be used.
|
|
|
022f11 |
-
|
|
|
022f11 |
=item C<cachemode>
|
|
|
022f11 |
|
|
|
022f11 |
Choose whether or not libguestfs will obey sync operations (safe but slow)
|
|
|
022f11 |
diff --git a/src/drives.c b/src/drives.c
|
|
|
022f11 |
index f310b06..7abd952 100644
|
|
|
022f11 |
--- a/src/drives.c
|
|
|
022f11 |
+++ b/src/drives.c
|
|
|
022f11 |
@@ -136,6 +136,7 @@ create_drive_non_file (guestfs_h *g,
|
|
|
022f11 |
return drv;
|
|
|
022f11 |
}
|
|
|
022f11 |
|
|
|
022f11 |
+#if 0 /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
static struct drive *
|
|
|
022f11 |
create_drive_curl (guestfs_h *g,
|
|
|
022f11 |
enum drive_protocol protocol,
|
|
|
022f11 |
@@ -218,6 +219,7 @@ create_drive_gluster (guestfs_h *g,
|
|
|
022f11 |
readonly, format, iface, name, disk_label,
|
|
|
022f11 |
cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
+#endif /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
|
|
|
022f11 |
static int
|
|
|
022f11 |
nbd_port (void)
|
|
|
022f11 |
@@ -264,6 +266,7 @@ create_drive_nbd (guestfs_h *g,
|
|
|
022f11 |
cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
|
|
|
022f11 |
+#if 0 /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
static struct drive *
|
|
|
022f11 |
create_drive_rbd (guestfs_h *g,
|
|
|
022f11 |
struct drive_server *servers, size_t nr_servers,
|
|
|
022f11 |
@@ -451,6 +454,7 @@ create_drive_iscsi (guestfs_h *g,
|
|
|
022f11 |
readonly, format, iface, name, disk_label,
|
|
|
022f11 |
cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
+#endif /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
|
|
|
022f11 |
/* Traditionally you have been able to use /dev/null as a filename, as
|
|
|
022f11 |
* many times as you like. Ancient KVM (RHEL 5) cannot handle adding
|
|
|
022f11 |
@@ -865,6 +869,7 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
|
|
|
022f11 |
disk_label, cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
}
|
|
|
022f11 |
+#if 0 /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
else if (STREQ (protocol, "ftp")) {
|
|
|
022f11 |
drv = create_drive_curl (g, drive_protocol_ftp,
|
|
|
022f11 |
servers, nr_servers, filename,
|
|
|
022f11 |
@@ -905,12 +910,14 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
|
|
|
022f11 |
readonly, format, iface, name,
|
|
|
022f11 |
disk_label, cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
+#endif /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
else if (STREQ (protocol, "nbd")) {
|
|
|
022f11 |
drv = create_drive_nbd (g, servers, nr_servers, filename,
|
|
|
022f11 |
username, secret,
|
|
|
022f11 |
readonly, format, iface, name,
|
|
|
022f11 |
disk_label, cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
+#if 0 /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
else if (STREQ (protocol, "rbd")) {
|
|
|
022f11 |
drv = create_drive_rbd (g, servers, nr_servers, filename,
|
|
|
022f11 |
username, secret,
|
|
|
022f11 |
@@ -936,6 +943,7 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
|
|
|
022f11 |
readonly, format, iface, name,
|
|
|
022f11 |
disk_label, cachemode);
|
|
|
022f11 |
}
|
|
|
022f11 |
+#endif /* DISABLED IN RHEL 7 */
|
|
|
022f11 |
else {
|
|
|
022f11 |
error (g, _("unknown protocol '%s'"), protocol);
|
|
|
022f11 |
drv = NULL; /*FALLTHROUGH*/
|
|
|
022f11 |
diff --git a/src/guestfs.pod b/src/guestfs.pod
|
|
|
022f11 |
index eedea94..87e8882 100644
|
|
|
022f11 |
--- a/src/guestfs.pod
|
|
|
022f11 |
+++ b/src/guestfs.pod
|
|
|
022f11 |
@@ -668,91 +668,6 @@ you don't need to add any disks.
|
|
|
022f11 |
|
|
|
022f11 |
=head2 REMOTE STORAGE
|
|
|
022f11 |
|
|
|
022f11 |
-=head3 CEPH
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access Ceph (librbd/RBD) disks.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the optional C<protocol> and C<server> parameters of
|
|
|
022f11 |
-L</guestfs_add_drive_opts> like this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **servers = { "ceph1.example.org:3000", /* ... */, NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/pool/image",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "rbd",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, servers,
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_USERNAME, "rbduser",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SECRET, "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==",
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-C<servers> (the C<server> parameter) is a list of one or more Ceph
|
|
|
022f11 |
-servers. The server string is documented in
|
|
|
022f11 |
-L</guestfs_add_drive_opts>. The C<username> and C<secret> parameters are
|
|
|
022f11 |
-also optional, and if not given, then no authentication will be used.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head3 FTP, HTTP AND TFTP
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access remote disks over FTP, FTPS, HTTP, HTTPS
|
|
|
022f11 |
-or TFTP protocols.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the optional C<protocol> and C<server> parameters of
|
|
|
022f11 |
-L</guestfs_add_drive_opts> like this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **servers = { "www.example.org", NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/disk.img",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "http",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, servers,
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-The C<protocol> can be one of C<"ftp">, C<"ftps">, C<"http">,
|
|
|
022f11 |
-C<"https"> or C<"tftp">.
|
|
|
022f11 |
-
|
|
|
022f11 |
-C<servers> (the C<server> parameter) is a list which must have a
|
|
|
022f11 |
-single element. The single element is a string defining the web,
|
|
|
022f11 |
-FTP or TFTP server. The format of this string is documented in
|
|
|
022f11 |
-L</guestfs_add_drive_opts>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head3 GLUSTER
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access Gluster disks.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the optional C<protocol> and C<server> parameters of
|
|
|
022f11 |
-L</guestfs_add_drive_opts> like this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **servers = { "gluster.example.org:24007", NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/volname/image",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "gluster",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, servers,
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-C<servers> (the C<server> parameter) is a list which must have a
|
|
|
022f11 |
-single element. The single element is a string defining the Gluster
|
|
|
022f11 |
-server. The format of this string is documented in
|
|
|
022f11 |
-L</guestfs_add_drive_opts>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-Note that gluster usually requires the client process (ie. libguestfs)
|
|
|
022f11 |
-to run as B<root> and will give unfathomable errors if it is not
|
|
|
022f11 |
-(eg. "No data available").
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head3 ISCSI
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access iSCSI disks remotely.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the optional C<protocol> and C<server> parameters like
|
|
|
022f11 |
-this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **server = { "iscsi.example.org:3000", NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/target-iqn-name/lun",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "iscsi",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, server,
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-The C<server> parameter is a list which must have a single element.
|
|
|
022f11 |
-The single element is a string defining the iSCSI server. The format
|
|
|
022f11 |
-of this string is documented in L</guestfs_add_drive_opts>.
|
|
|
022f11 |
-
|
|
|
022f11 |
=head3 NETWORK BLOCK DEVICE
|
|
|
022f11 |
|
|
|
022f11 |
Libguestfs can access Network Block Device (NBD) disks remotely.
|
|
|
022f11 |
@@ -815,42 +730,6 @@ L<https://bugs.launchpad.net/qemu/+bug/1155677>
|
|
|
022f11 |
|
|
|
022f11 |
=back
|
|
|
022f11 |
|
|
|
022f11 |
-=head3 SHEEPDOG
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access Sheepdog disks.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the optional C<protocol> and C<server> parameters of
|
|
|
022f11 |
-L</guestfs_add_drive_opts> like this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **servers = { /* optional servers ... */ NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/volume",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "sheepdog",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, servers,
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-The optional list of C<servers> may be zero or more server addresses
|
|
|
022f11 |
-(C<"hostname:port">). The format of the server strings is documented
|
|
|
022f11 |
-in L</guestfs_add_drive_opts>.
|
|
|
022f11 |
-
|
|
|
022f11 |
-=head3 SSH
|
|
|
022f11 |
-
|
|
|
022f11 |
-Libguestfs can access disks over a Secure Shell (SSH) connection.
|
|
|
022f11 |
-
|
|
|
022f11 |
-To do this, set the C<protocol> and C<server> and (optionally)
|
|
|
022f11 |
-C<username> parameters of L</guestfs_add_drive_opts> like this:
|
|
|
022f11 |
-
|
|
|
022f11 |
- char **server = { "remote.example.com", NULL };
|
|
|
022f11 |
- guestfs_add_drive_opts (g, "/path/to/disk.img",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_FORMAT, "raw",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_PROTOCOL, "ssh",
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_SERVER, server,
|
|
|
022f11 |
- GUESTFS_ADD_DRIVE_OPTS_USERNAME, "remoteuser",
|
|
|
022f11 |
- -1);
|
|
|
022f11 |
-
|
|
|
022f11 |
-The format of the server string is documented in
|
|
|
022f11 |
-L</guestfs_add_drive_opts>.
|
|
|
022f11 |
-
|
|
|
022f11 |
=head2 INSPECTION
|
|
|
022f11 |
|
|
|
022f11 |
Libguestfs has APIs for inspecting an unknown disk image to find out
|
|
|
022f11 |
--
|
|
|
022f11 |
1.8.3.1
|
|
|
022f11 |
|