diff --git a/cmd/skopeo/copy.go b/cmd/skopeo/copy.go index 6a7e801310..2c37f45294 100644 --- a/cmd/skopeo/copy.go +++ b/cmd/skopeo/copy.go @@ -44,6 +44,7 @@ type copyOptions struct { encryptLayer []int // The list of layers to encrypt encryptionKeys []string // Keys needed to encrypt the image decryptionKeys []string // Keys needed to decrypt the image + maxParallelDownloads uint // Maximum number of parallel downloads } func copyCmd(global *globalOptions) *cobra.Command { @@ -95,6 +96,7 @@ See skopeo(1) section "IMAGE NAMES" for the expected format flags.StringSliceVar(&opts.encryptionKeys, "encryption-key", []string{}, "*Experimental* key with the encryption protocol to use needed to encrypt the image (e.g. jwe:/path/to/key.pem)") flags.IntSliceVar(&opts.encryptLayer, "encrypt-layer", []int{}, "*Experimental* the 0-indexed layer indices, with support for negative indexing (e.g. 0 is the first layer, -1 is the last layer)") flags.StringSliceVar(&opts.decryptionKeys, "decryption-key", []string{}, "*Experimental* key needed to decrypt the image") + flags.UintVar(&opts.maxParallelDownloads, "max-parallel-downloads", 6, "Maximum number of parallel downloads") return cmd } @@ -300,6 +302,7 @@ func (opts *copyOptions) run(args []string, stdout io.Writer) (retErr error) { OciDecryptConfig: decConfig, OciEncryptLayers: encLayers, OciEncryptConfig: encConfig, + MaxParallelDownloads: opts.maxParallelDownloads, }) if err != nil { return err diff --git a/docs/skopeo-copy.1.md b/docs/skopeo-copy.1.md index 43b007db67..ff50d03c3a 100644 --- a/docs/skopeo-copy.1.md +++ b/docs/skopeo-copy.1.md @@ -220,6 +220,10 @@ The username to access the destination registry. The password to access the destination registry. +**--max-parallel-downloads** _n_ + +The maximum number of parallel downloads. + ## EXAMPLES To just copy an image from one registry to another: