This commit changes posix's deleteFile() to not upstream errors from removing parent directories. This fixes a race condition. The race condition occurs when multiple deleteFile()s are called on the same parent directory, but different child files. Because deleteFile() recursively removes parent directories if they are empty, but deleteFile() errors if the selected deletePath does not exist, there was an opportunity for a race condition. The two processes would remove the child directories successfully, then depend on the parent directory still existing. In some cases this is an invalid assumption, because other processes can remove the parent directory beforehand. This commit changes deleteFile() to not upstream an error if one occurs, because the only required error should be from the immediate deletePath, not from a parent path. In the specific bug report, multiple CompleteMultipartUpload requests would launch multiple deleteFile() requests. Because they chain up on parent directories, ultimately at the end, there would be multiple remove files for the ultimate parent directory, .minio.sys/multipart/{bucket}. Because only one will succeed and one will fail, an error would be upstreamed saying that the file does not exist, and the CompleteMultipartUpload code interpreted this as NoSuchKey, or that the object/part id doesn't exist. This was faulty behavior and is now fixed. The added test fails before this change and passes after this change. Fixes: https://github.com/minio/minio/issues/4727
Minio Quickstart Guide
Minio is an object storage server released under Apache License v2.0. It is compatible with Amazon S3 cloud storage service. It is best suited for storing unstructured data such as photos, videos, log files, backups and container / VM images. Size of an object can range from a few KBs to a maximum of 5TB.
Minio server is light enough to be bundled with the application stack, similar to NodeJS, Redis and MySQL.
Docker Container
Stable
docker pull minio/minio
docker run -p 9000:9000 minio/minio server /export
Edge
docker pull minio/minio:edge
docker run -p 9000:9000 minio/minio:edge server /export
Please visit Minio Docker quickstart guide for more here
macOS
Homebrew
Install minio packages using Homebrew
brew install minio/stable/minio
minio server ~/Photos
Note
If you previously installed minio using brew install minio
then reinstall minio from minio/stable/minio
official repo. Homebrew builds are unstable due to golang 1.8 bugs.
brew uninstall minio
brew install minio/stable/minio
Binary Download
Platform | Architecture | URL |
---|---|---|
Apple macOS | 64-bit Intel | https://dl.minio.io/server/minio/release/darwin-amd64/minio |
chmod 755 minio
./minio server ~/Photos
GNU/Linux
Binary Download
Platform | Architecture | URL |
---|---|---|
GNU/Linux | 64-bit Intel | https://dl.minio.io/server/minio/release/linux-amd64/minio |
32-bit Intel | https://dl.minio.io/server/minio/release/linux-386/minio | |
32-bit ARM | https://dl.minio.io/server/minio/release/linux-arm/minio | |
64-bit ARM | https://dl.minio.io/server/minio/release/linux-arm64/minio | |
32-bit ARMv6 | https://dl.minio.io/server/minio/release/linux-arm6vl/minio |
chmod +x minio
./minio server ~/Photos
Microsoft Windows
Binary Download
Platform | Architecture | URL |
---|---|---|
Microsoft Windows | 64-bit | https://dl.minio.io/server/minio/release/windows-amd64/minio.exe |
32-bit | https://dl.minio.io/server/minio/release/windows-386/minio.exe |
minio.exe server D:\Photos
FreeBSD
Port
Install minio packages using pkg
pkg install minio
sysrc minio_enable=yes
sysrc minio_disks=/home/user/Photos
service minio start
Binary Download
Platform | Architecture | URL |
---|---|---|
FreeBSD | 64-bit | https://dl.minio.io/server/minio/release/freebsd-amd64/minio |
chmod 755 minio
./minio server ~/Photos
Install from Source
Source installation is only intended for developers and advanced users. If you do not have a working Golang environment, please follow How to install Golang.
go get -u github.com/minio/minio
Test using Minio Browser
Minio Server comes with an embedded web based object browser. Point your web browser to http://127.0.0.1:9000 ensure your server has started successfully.
Test using Minio Client mc
mc
provides a modern alternative to UNIX commands like ls, cat, cp, mirror, diff etc. It supports filesystems and Amazon S3 compatible cloud storage services. Follow the Minio Client Quickstart Guide for further instructions.
Explore Further
- Minio Erasure Code QuickStart Guide
- Use
mc
with Minio Server - Use
aws-cli
with Minio Server - Use
s3cmd
with Minio Server - Use
minio-go
SDK with Minio Server - The Minio documentation website
Contribute to Minio Project
Please follow Minio Contributor's Guide