Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

mcli: Unable to prepare URL for copying. Unable to guess the type of copy operation. #4893

Open
paramazo opened this issue Apr 4, 2024 · 26 comments

Comments

@paramazo
Copy link

paramazo commented Apr 4, 2024

Expected behavior

The folder in a bucket should be moved into another bucket

Actual behavior

The folder was not moved, mc results with error:

mc mv --recursive <bucket1>/<folder> <bucket2>/<folder>
mcli: <ERROR> Unable to prepare URL for copying. Unable to guess the type of copy operation.

Other folders in the same folder structure was moved this way successful.

In an earlier version of mc, the error was

mcli: <ERROR> Unable to validate source

Steps to reproduce the behavior

Unknown why some folders cant be moved

mc --version

mcli version RELEASE.2024-03-30T15-29-52Z (commit-id=9f8147bf0e037730077a1b3baef25e53181099b0)
Runtime: go1.21.8 linux/amd64

minio version RELEASE.2023-03-20T20-16-18Z (commit-id=05444a0f6af8389b9bb85280fc31337c556d4300)
Runtime: go1.19.7 linux/amd64

System information

Debian 11.5 Bullseye

@paramazo
Copy link
Author

paramazo commented Apr 8, 2024

Tested mc mirror but it does not copy anything from the affected folder and does not result with Error and ends after 2 minutes. The folder i want to copy is 101GB big with 1.8 million files.

Other smaller folders in the same bucket works with mc mv and with mc mirror.

@paramazo
Copy link
Author

Tested to copy the folder from minio server to my local system with mc cp -r, same error. This folder can not be copied, mirrored or moved in any way. Other smaller folders work, so obviously it is a bug in MinIO with very big data. This is a gamebreaker and very critical and if this behaviour is not supported, we need to change our environment and switch to another solution.

@paramazo
Copy link
Author

paramazo commented Apr 11, 2024

The data in our minio are now in a minio folder structure and as we can not access the contents via mcli/awscli/winscp, we have a huge data loss? Can anyone help here? Where do we find support?

@ds-colligence
Copy link

From what I can understand, it seems like when the bucket has hyphens in it, it is failing. At least that seems to be the case for me.

@mmedic
Copy link

mmedic commented May 7, 2024

I can confirm the same issue with a bucket with hypens in it

@jiuker
Copy link
Contributor

jiuker commented May 14, 2024

@mmedic Could you share a script to let us to reproduce that?

@hypesystem
Copy link

hypesystem commented May 14, 2024

I was wracking my brain because I got this error, too. It turns out it appears when the source file does not exist

@mratibb
Copy link

mratibb commented May 15, 2024

I had the same issue, and apparently it was a certificate issue.
Either add 'insecure' option to your command, or add the certificate to the host/container you running the command on.

@Xun66
Copy link

Xun66 commented May 24, 2024

I had the same issue with two mc commands.

Command 1:

mc alias set myminio $MINIO_ENDPOINT $MINIO_ACCESS_KEY $MINIO_SECRET_KEY
mc cp --recursive myminio/<folder> <local>/<folder>
# mc: <ERROR> Unable to prepare URL for copying. Unable to guess the type of copy operation.

Looks like the MINIO_ACCESS_KEY and MINIO_SECRET_KEY were empty. Once I filled in the correct values, everything worked smoothly.

Command 2:

mc cp --recursive <local>/<folder> myminio/<folder>
# mc: <ERROR> Unable to prepare URL for copying. Unable to guess the type of copy operation.

Turns out, the issue was that <local>/<folder> didn't exist. In earlier versions of mc, this would've triggered an error message saying: mc: <ERROR> Unable to validate source <local>/<folder>: Object does not exist.

mc version

It looks like this change was introduced in PR #4710. From version mc version RELEASE.2023-10-14T01-57-03Z (commit-id=d158b9a478a6a5a74795f01097d069be82edfff6).

my test result:

$ docker run -it --rm minio/mc:RELEASE.2023-10-14T01-57-03Z cp -r /foo/ myio/bar 
mc: Configuration written to `/root/.mc/config.json`. Please update your access credentials.
mc: Successfully created `/root/.mc/share`.
mc: Initialized share uploads `/root/.mc/share/uploads.json` file.
mc: Initialized share downloads `/root/.mc/share/downloads.json` file.
mc: <ERROR> Unable to prepare URL for copying. Unable to guess the type of copy operation. 
$ docker run -it --rm minio/mc:RELEASE.2023-10-04T06-52-56Z cp -r /foo/ myio/bar   
mc: Configuration written to `/root/.mc/config.json`. Please update your access credentials.
mc: Successfully created `/root/.mc/share`.
mc: Initialized share uploads `/root/.mc/share/uploads.json` file.
mc: Initialized share downloads `/root/.mc/share/downloads.json` file.
mc: <ERROR> Unable to validate source `/foo/`: Object does not exist

@obarisk
Copy link

obarisk commented Jun 23, 2024

I have the same issue. With a very small file (28 Bytes).

I can replicate the issue by

  • use golang PutObject to create a small file like xxx-1/7f9d85cf-7f48-408c-9649-f4c1ba472886/small.json

  • use mc cli (windows) to copy the object to local right after the object created.

    mc: Unable to prepare URL for copying. Unable to guess the type of copy operation.

  • mc ls can find the object (small.json)

  • mc cat the object with redirect to local/small.json (works)

  • mc cp works after a couple hours.

cli version

mc version RELEASE.2024-05-03T11-21-07Z (commit-id=b471de8d1882cae21ca84e98d56c2a5e2c321164)
Runtime: go1.22.2 windows/amd64
Copyright (c) 2015-2024 MinIO, Inc.
License GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>

server version

minio version RELEASE.2024-06-13T22-53-53Z (commit-id=20960b6a2ddb9594ee418035b3c7c7fe92ae6a12)
Runtime: go1.22.4 linux/amd64
License: GNU AGPLv3 - https://www.gnu.org/licenses/agpl-3.0.html
Copyright: 2015-2024 MinIO, Inc.

@XoseRamon
Copy link

XoseRamon commented Aug 26, 2024

I had this very same issue when the source folder (uploading files to a minIO instance) contains hyphens. Removing the hyphens in the source folder fixed the issue. The error message is not very helpful.

@jiuker
Copy link
Contributor

jiuker commented Aug 26, 2024

@XoseRamon Like what name?

@XoseRamon
Copy link

XoseRamon commented Aug 26, 2024

@jiuker I had something like mc cp test-data/*.gzip minio/test-bucket which threw an error and changing it to mc cp testdata/*.gzip minio/test-bucket worked. I am using:

mc version RELEASE.2024-08-17T11-33-50Z (commit-id=2c94b8d03979ed96a6379ecabc3435b271398efc)
Runtime: go1.22.6 linux/amd64
Copyright (c) 2015-2024 MinIO, Inc.
License GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>

@jiuker
Copy link
Contributor

jiuker commented Aug 28, 2024

@jiuker I had something like mc cp test-data/*.gzip minio/test-bucket which threw an error and changing it to mc cp testdata/*.gzip minio/test-bucket worked. I am using:

mc version RELEASE.2024-08-17T11-33-50Z (commit-id=2c94b8d03979ed96a6379ecabc3435b271398efc)
Runtime: go1.22.6 linux/amd64
Copyright (c) 2015-2024 MinIO, Inc.
License GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>

What's the cp? remote to local?

@XoseRamon
Copy link

@jiuker I had something like mc cp test-data/*.gzip minio/test-bucket which threw an error and changing it to mc cp testdata/*.gzip minio/test-bucket worked. I am using:

mc version RELEASE.2024-08-17T11-33-50Z (commit-id=2c94b8d03979ed96a6379ecabc3435b271398efc)
Runtime: go1.22.6 linux/amd64
Copyright (c) 2015-2024 MinIO, Inc.
License GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>

What's the cp? remote to local?

local to remote

@jiuker
Copy link
Contributor

jiuker commented Aug 29, 2024

@jiuker I had something like mc cp test-data/*.gzip minio/test-bucket which threw an error and changing it to mc cp testdata/*.gzip minio/test-bucket worked. I am using:

mc version RELEASE.2024-08-17T11-33-50Z (commit-id=2c94b8d03979ed96a6379ecabc3435b271398efc)
Runtime: go1.22.6 linux/amd64
Copyright (c) 2015-2024 MinIO, Inc.
License GNU AGPLv3 <https://www.gnu.org/licenses/agpl-3.0.html>

What's the cp? remote to local?

local to remote

Ok, I can't replicate this. Please share the quick bashScript to generate the dir test-data. And then I will follow this.

@keplersj
Copy link

keplersj commented Oct 9, 2024

I'm seeing this issue locally and in our Continuous Integration environment when using the mc cp --recursive command to copy local files to a bucket whose name contains a hyphen.

We did not see this failure before the October 2nd release of mc: https://github.com/minio/mc/releases/tag/RELEASE.2024-10-02T08-27-28Z.

@vbmithr
Copy link

vbmithr commented Oct 27, 2024

Same issue here just trying to copy a remote file to local.

@mmedic
Copy link

mmedic commented Oct 28, 2024

I think the issue here is a dash - in a bucket name. Can anyone else confirm?

@vbmithr
Copy link

vbmithr commented Oct 28, 2024

Confirmed ;)

@aelbarkani
Copy link

I think the issue here is a dash - in a bucket name. Can anyone else confirm?

Confirmed :(

@CuongVoThanh
Copy link

Confirmed :((

@CuongVoThanh
Copy link

Use mc mirror instead.

@udf2457
Copy link

udf2457 commented Jan 17, 2025

I stumbled accross this one today with mc cp. Sadly it stinks of somebody re-using an error message in the wrong place.

In my case, the source file did not exist and that's what caused the nonsensical "Unable to guess the type of copy operation." message. Once the source file existed it worked fine.

Someone needs to take a fine tooth comb through the code and find anywhere that bubbles up this silly message.

Sorry if I sound harsh... I spent far too much time bashing my head against why this error was coming up in my CI/CD process before finding the solution was easy and would have been quick to resolve if mc gave me the correct error.

@jiuker
Copy link
Contributor

jiuker commented Jan 22, 2025

I stumbled accross this one today with mc cp. Sadly it stinks of somebody re-using an error message in the wrong place.

In my case, the source file did not exist and that's what caused the nonsensical "Unable to guess the type of copy operation." message. Once the source file existed it worked fine.

Someone needs to take a fine tooth comb through the code and find anywhere that bubbles up this silly message.

Sorry if I sound harsh... I spent far too much time bashing my head against why this error was coming up in my CI/CD process before finding the solution was easy and would have been quick to resolve if mc gave me the correct error.

Could you give an quick reprduce steps? I will check @udf2457

@udf2457
Copy link

udf2457 commented Jan 23, 2025

@jiuker In my case it's as simple as it sounds...

  • I had a GH-runner doing CI builds
  • It was generating a file
  • I was pointing mc cp at the wrong place (right file, wrong directory)
  • That was the error message I was seeing
  • Fixed the source to "right file, right directory" and it all worked

That was literally the only change I made to my CI yaml (iirc it was something like changing '/tmp' to GH's '${{runner.temp}}')

N.B. The mc version used was not from package manager but from your Github release (I have a little script that downloads the latest version with a little help from jq)

N.B.N.B. I can confirm the issue has nothing to do with bucket names as mentioned by some others above. At the time I renamed my bucket to strictly alnum and it still did the same thing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests