7.7 KiB
mc find
minio
Table of Contents
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.
EXAMPLE
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"
SYNTAX
The command has the following syntax:
mc [GLOBALFLAGS] find \
[--exec "string"] \
[--ignore "string"] \
[--larger "string"] \
[--maxdepth "string"] \
[--name "string"] \
[--newer-than "string"] \
[--older-than "string"] \
[--path "string"] \
[--print "string"] \
[--regex "string"] \
[--smaller "string"] \
[--watch] \
ALIAS
Parameters
ALIAS
Required
For objects on MinIO or an S3-compatible host, specify the alias <alias>
and the
full path to search (e.g. bucket and prefixes). For example:
mc find play/mydata/
For objects on a filesyste, specify the full path to search. For example:
mc find ~/mydata/
Issuing mc find ALIAS
with no other arguments returns a
list of all objects or files at the specified path, similar to
mc ls
.
--exec
Optional Spawns an external process for each object returned
by mc find
. Supports
substitution formatting
<mc-find-substitution-format>
of the output.
--ignore
Optional Exclude objects whose names match the specified wildcard pattern.
--larger
Optional Match all objects larger than the specified size in
units <mc-find-units>
.
--maxdepth
Optional Limits directory navigation to the specified depth.
--name
Optional Return objects whose names match the specified wildcard pattern.
--newer-than
Optional Mirror object(s) newer than the specified number of
days. Specify a string in #d#hh#mm#ss
format. For example:
--older-than 1d2hh3mm4ss
--older-than
Optional Mirror object(s) older than the specified time
limit. Specify a string in #d#hh#mm#ss
format. For example:
--older-than 1d2hh3mm4ss
Defaults to 0
(all objects).
--path
Optional Return the contents of directories whose names match the specified wildcard pattern.
--print
Optional Prints results to STDOUT
. Supports
substitution formatting <mc-find-substitution-format>
of the output.
--regex
Optional Returns objects or the contents of directories whose names match the specified PCRE regex pattern.
--smaller
Optional Match all objects smaller than the specifized size
in units <mc-find-units>
.
--watch
Optional Continuously monitor the ~mc find ALIAS
and return
any new objects which match the specified criteria.
Global Flags
Examples
Find a Specific Object in a Bucket
mc find ALIAS/PATH --name NAME
- Replace
ALIAS <mc find ALIAS>
with thealias <mc alias>
of the S3-compatible host. - Replace
PATH <mc find ALIAS>
with the path to a bucket on the S3-compatible host. Omit the path to search from the root of the S3 host. - Replace
NAME <mc find --name>
with the object.
Find Objects with File Extention in Bucket
mc find ALIAS/PATH --name *.EXTENSION
- Replace
ALIAS <mc find ALIAS>
with thealias <mc alias>
of the S3-compatible host. - Replace
PATH <mc find ALIAS>
with the path to a bucket on the S3-compatible host. - Replace
EXTENSION <mc find --name>
with the file extention of the object.
Find All Matching Files and Copy To S3 Service
Use mc find
with the
~mc find --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
FILEPATH <mc find ALIAS>
with the full file path to the directory to search. - Replace
EXTENSION <mc find --name>
with the file extention of the object. - Replace
ALIAS <mc find ALIAS>
with thealias <mc alias>
of the S3-compatible host. - Replace
PATH <mc find ALIAS>
with the path to a bucket on the S3-compatible host.
To continuously watch the specified directory and copy new objects,
include the ~mc find --watch
argument:
mc find --watch FILEPATH --name "*.EXTENSION" --exec "mc cp {} ALIAS/PATH"
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 |
---|---|
k |
KB (Kilobyte, 1000 Bytes) |
m |
MB (Megabyte, 1000 Kilobytes) |
g |
GB (Gigabyte, 1000 Megabytes) |
t |
TB (Terrabyte, 1000 Gigabytes) |
ki |
KiB (Kibibyte, 1024 Bites) |
mi |
MiB (Mebibyte, 1024 Kibibytes) |
gi |
GiB (Gibibyte, 1024 Mebibytes) |
ti |
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.