[Libguestfs] [PATCH libnbd 3/3] examples: copy-libev.c: Support extents
Nir Soffer
nsoffer at redhat.com
Mon Mar 8 11:23:05 UTC 2021
On Mon, Mar 8, 2021 at 11:50 AM Richard W.M. Jones <rjones at redhat.com>
wrote:
> On Mon, Mar 08, 2021 at 01:26:44AM +0200, Nir Soffer wrote:
> > $ strace -f -c ../copy/nbdcopy --sparse=1048576 --request-size=1048576
> > --requests=16 --connections=1 $SRC $DST
> > strace: Process 1094611 attached
> > strace: Process 1094612 attached
> > strace: Process 1094613 attached
> > strace: Process 1094614 attached
> > strace: Process 1094615 attached
> > strace: Process 1094616 attached
> > strace: Process 1094617 attached
> > strace: Process 1094618 attached
> > strace: Process 1094619 attached
> > strace: Process 1094620 attached
> > strace: Process 1094621 attached
> > strace: Process 1094622 attached
> > strace: Process 1094623 attached
> > strace: Process 1094641 attached
> >
> > (Not sure why we start so many threads with --connections=1 - bug?)
>
> I'm not sure of the exact command, so I used:
>
> $ ./run nbdcopy --sparse=1048576 --request-size=1048576 --requests=16
> --connections=1 -- [ qemu-nbd -f qcow2 -t ~/fedora-32.qcow2 ] [ nbdkit
> memory 6G ]
>
> Temporarily adding -v shows:
>
> nbdcopy: src: nbd_ops "qemu-nbd"
> nbdcopy: src: size=6442450944
> nbdcopy: dst: nbd_ops "nbdkit"
> nbdcopy: dst: size=6442450944
> nbdcopy: connections=1 requests=16 threads=1 synchronous=false
> ^^^^^^^^^
>
> Many threads were created but they all appeared to be associated with
> the ./run script, qemu-nbd and nbdkit. nbdcopy should only create one
> worker thread in this scenario.
>
Right, I was testing the run script instead of .libs/xxx. When running the
actual executable we see:
$ strace -f -c ../copy/.libs/nbdcopy --flush --sparse=1048576
--request-size=1048576 --requests=16 --connections=1 $SRC $DST
strace: Process 1142801 attached
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
59.70 0.914059 914059 1 futex
18.90 0.289297 17 16768 1 recvfrom
17.99 0.275497 32 8380 4 sendto
2.73 0.041852 4 8921 poll
0.50 0.007616 230 33 madvise
...
$ strace -c .libs/copy-libev $SRC $DST
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
50.25 0.297711 19 15446 1 recvfrom
39.81 0.235824 34 6863 sendto
7.69 0.045573 5 8911 epoll_wait
1.04 0.006132 4 1317 epoll_ctl
0.42 0.002478 24 103 mmap
...
Why do we use the run script?
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://listman.redhat.com/archives/libguestfs/attachments/20210308/a6ce2c10/attachment.htm>
More information about the Libguestfs
mailing list