Annotation of embedaddon/curl/docs/PARALLEL-TRANSFERS.md, revision 1.1

1.1     ! misho       1: # Parallel transfers
        !             2: 
        !             3: curl 7.66.0 introduces support for doing multiple transfers simultaneously; in
        !             4: parallel.
        !             5: 
        !             6: ## -Z, --parallel
        !             7: 
        !             8: When this command line option is used, curl will perform the transfers given
        !             9: to it at the same time. It will do up to `--parallel-max` concurrent
        !            10: transfers, with a default value of 50.
        !            11: 
        !            12: ## Progress meter
        !            13: 
        !            14: The progress meter that is displayed when doing parallel transfers is
        !            15: completely different than the regular one used for each single transfer.
        !            16: 
        !            17:   It shows:
        !            18: 
        !            19:  o percent download (if known, which means *all* transfers need to have a
        !            20:    known size)
        !            21:  o percent upload (if known, with the same caveat as for download)
        !            22:  o total amount of downloaded data
        !            23:  o total amount of uploaded data
        !            24:  o number of transfers to perform
        !            25:  o number of concurrent transfers being transferred right now
        !            26:  o number of transfers queued up waiting to start
        !            27:  o total time all transfers are expected to take (if sizes are known)
        !            28:  o current time the transfers have spent so far
        !            29:  o estimated time left (if sizes are known)
        !            30:  o current transfer speed (the faster of UL/DL speeds measured over the last
        !            31:    few seconds)
        !            32: 
        !            33: Example:
        !            34: 
        !            35:     DL% UL%  Dled  Uled  Xfers  Live   Qd Total     Current  Left    Speed
        !            36:     72  --  37.9G     0   101    30    23  0:00:55  0:00:34  0:00:22 2752M
        !            37: 
        !            38: ## Behavior differences
        !            39: 
        !            40: Connections are shared fine between different easy handles, but the
        !            41: "authentication contexts" are not. So for example doing HTTP Digest auth with
        !            42: one handle for a particular transfer and then continue on with another handle
        !            43: that reuses the same connection, the second handle can't send the necessary
        !            44: Authorization header at once since the context is only kept in the original
        !            45: easy handle.
        !            46: 
        !            47: To fix this, the authorization state could be made possible to share with the
        !            48: share API as well, as a context per origin + path (realm?) basically.
        !            49: 
        !            50: Visible in test 153, 1412 and more.
        !            51: 
        !            52: ## Feedback!
        !            53: 
        !            54: This is early days for parallel transfer support. Keep your eyes open for
        !            55: unintended side effects or downright bugs.
        !            56: 
        !            57: Tell us what you think and how you think we could improve this feature!
        !            58: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>