mc find
Syntax
The mc find command supports searching for objects on a MinIO deployment.
You can also use the command to search for files on a filesystem.
The following command searches for all objects matching the specified
pattern in the mydata bucket on the myminio MinIO deployment:
mc find myminio/mydata --name "*.jpg"
The command has the following syntax:
mc [GLOBALFLAGS] find                    \
                 [--exec "string"]       \
                 [--ignore "string"]     \
                 [--larger "string"]     \
                 [--maxdepth "string"]   \
                 [--metadata "string"]   \
                 [--name "string"]       \
                 [--newer-than "string"] \
                 [--older-than "string"] \
                 [--path "string"]       \
                 [--print "string"]      \
                 [--regex "string"]      \
                 [--smaller "string"]    \
                 [--tags "string"]`      \
                 [--versions]            \
                 [--watch]               \
                 ALIAS
- Brackets - []indicate optional parameters.
- Parameters sharing a line are mutually dependent. 
- Parameters separated using the pipe - |operator are mutually exclusive.
Copy the example to a text editor and modify as-needed before running the command in the terminal/shell.
Parameters
- ALIAS
- RequiredFor objects on MinIO or an S3-compatible host, specify the alias and the full path to search (e.g. bucket and prefixes). For example: mc find play/mydata/ For objects on a filesystem, specify the full path to search. For example: mc find ~/mydata/ Issuing mc find ALIASwith no other arguments returns a list of all objects or files at the specified path, similar tomc ls.
- --exec
- OptionalSpawns an external process for each object returned by mc find. Supports substitution formatting of the output.
- --ignore
- OptionalExclude objects whose names match the specified wildcard pattern. 
- --larger
- OptionalMatch all objects larger than the specified size in units. 
- --metadata
- OptionalNew in version mc: RELEASE.2023-04-12T02-21-51Z For use with MinIO deployments only. Return objects with metadata that matches a specified key=value. Use the format--metadata="KEY=value".You can pass a key with an empty value. In that case, mc findmatches objects that do not have the metadata key or where the metadata key’s value is empty.You can use the flag multiple times to match objects for additional metadata keys. To return, an object must have matching values for all metadata keys. 
- --name
- OptionalReturn objects whose names match the specified wildcard pattern. 
- --newer-than
- OptionalMirror object(s) newer than the specified number of days. Specify a string in #d#hh#mm#ssformat. For example:--older-than 1d2hh3mm4ss
- --older-than
- OptionalMirror object(s) older than the specified time limit. Specify a string in #d#hh#mm#ssformat. For example:--older-than 1d2hh3mm4ssDefaults to 0(all objects).
- --path
- OptionalReturn the contents of directories whose names match the specified wildcard pattern. 
- OptionalPrints results to STDOUT. Supports substitution formatting of the output.
- --regex
- OptionalReturns objects or the contents of directories whose names match the specified PCRE regex pattern. 
- --tags
- OptionalNew in version mc: RELEASE.2023-04-12T02-21-51Z For use with MinIO deployments only. Return objects with a tag that matches a specified RE2 RegEx pattern. Use the format --tag="KEY=regexValue".You can pass a key with an empty value. In that case, mc findmatches objects that do not have the metadata key or where the metadata key’s value is empty.You can use the flag multiple times to match objects for additional tags. To return, an object must have matching values for all tags. 
- --smaller
- OptionalMatch all objects smaller than the specified size in units. 
- --watch
- OptionalContinuously monitor the ALIASand return any new objects which match the specified criteria.
Global Flags
This command supports any of the global flags.
Examples
Find a Specific Object in a Bucket
mc find ALIAS/PATH --name NAME
Find Objects with File Extension in Bucket
mc find ALIAS/PATH --name *.EXTENSION
Find All Matching Files and Copy To S3 Service
Use mc find with the --exec option to find
files on a local filesystem and pass them to an mc command for
further processing. The following example uses mc cp to copy the
output of mc find to an S3-compatible host.
mc find FILEPATH --name "*.EXTENSION" --exec "mc cp {} ALIAS/PATH"
- Replace - FILEPATHwith the full file path to the directory to search.
- Replace - EXTENSIONwith the file extension of the object.
- Replace - PATHwith the path to a bucket on the S3-compatible host.
To continuously watch the specified directory and copy new objects,
include the --watch argument:
mc find --watch FILEPATH --name "*.EXTENSION" --exec "mc cp {} ALIAS/PATH"
Find Objects with a Matching Tag
Note
Tag matching is only available for use on MinIO deployments.
mc find --tags="key=v*" ALIAS/BUCKET/
- Replace - keywith the name of a tag key to match.
- Replace - v*with the RE2 Regular Expression to evaluate against.
- Replace - ALIASwith the- aliasof the MinIO deployment.
- Replace - BUCKETwith the bucket or prefix to search.
You can add additional --tags="key=RegExpression" flags to match.
Matching objects must match all included tags.
Find Objects with Matching Metadata
Note
Metadata matching is only available for use on MinIO deployments.
mc find --json --metadata="content-type=text/csv" ALIAS/BUCKET/
- Replace - content-type=text/csvwith the a key-value pair of the metadata field and value to match.
- Replace - ALIASwith the- aliasof the MinIO deployment.
- Replace - BUCKETwith the bucket or prefix to search.
You can add additional --tags="metadata=value" flags to match.
Matching objects must match all included metadata fields.
Behavior
Units of Measurement
The mc find --smaller and mc find --larger flags
accept the following case-insensitive suffixes to represent the unit of the
specified size value:
| Suffix | Unit Size | 
|---|---|
| 
 | KB (Kilobyte, 1000 Bytes) | 
| 
 | MB (Megabyte, 1000 Kilobytes) | 
| 
 | GB (Gigabyte, 1000 Megabytes) | 
| 
 | TB (Terabyte, 1000 Gigabytes) | 
| 
 | KiB (Kibibyte, 1024 Bites) | 
| 
 | MiB (Mebibyte, 1024 Kibibytes) | 
| 
 | GiB (Gibibyte, 1024 Mebibytes) | 
| 
 | TiB (Tebibyte, 1024 Gibibytes) | 
Omitting the suffix defaults to bytes.
Substitution Format
The mc find --exec and mc find --print commands
support string substitutions with special interpretations for following
keywords.
The following keywords are supported for both filesystem and S3 service targets:
- {}- Substitutes to full path.
- {base}- Substitutes to basename of path.
- {dir}- Substitutes to dirname of the path.
- {size}- Substitutes to object size of the path.
- {time}- Substitutes to object modified time of the path.
The following keyword is supported only for S3 service targets:
- {url}- Substitutes to a shareable URL of the path.
S3 Compatibility
The mc commandline tool is built for compatibility with the AWS S3 API and is tested with MinIO and AWS S3 for expected functionality and behavior.
MinIO provides no guarantees for other S3-compatible services, as their S3 API implementation is unknown and therefore unsupported. While mc commands may work as documented, any such usage is at your own risk.
