Scroll to navigation

libnbd-golang(3) LIBNBD libnbd-golang(3)

NAME

libnbd-golang - how to use libnbd from Go

SYNOPSIS

 import "libguestfs.org/libnbd"
 h, err := libnbd.Create()
 if err != nil {
     panic(err)
 }
 defer h.Close()
 uri := "nbd://localhost"
 err = h.ConnectUri(uri)
 if err != nil {
     panic(err)
 }
 size, err := h.GetSize()
 if err != nil {
     panic(err)
 }
 fmt.Printf("size of %s = %d\n", uri, size)

DESCRIPTION

This manual page documents how to use libnbd to access Network Block Device (NBD) servers from the Go programming language. The Go bindings work very similarly to the C bindings so you should start by reading libnbd(3).

HANDLES

Create a libnbd handle of type "Libnbd" by calling Create().

You can either close the handle explicitly by a deferred call to "h.Close()" or it will be closed automatically when it is garbage collected.

ERRORS

Most calls return either a single "LibnbdError" or a pair "(ret, LibnbdError)".

EXAMPLES

This directory contains examples written in Go:

https://gitlab.com/nbdkit/libnbd/tree/master/golang/examples

SEE ALSO

libnbd(3).

AUTHORS

Richard W.M. Jones

COPYRIGHT

Copyright Red Hat

LICENSE

This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA

2025-01-10 libnbd-1.20.3