Brendan Ashworth aeafe668d8 posix: do not upstream errors in deleteFile (#4771)
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
2017-08-04 16:51:20 -07:00
2015-08-20 16:10:01 -07:00
2016-05-20 13:53:15 -07:00
2017-06-14 02:08:35 -07:00
2014-10-30 21:51:52 -07:00
2016-03-09 13:55:58 +01:00
2017-06-14 23:26:33 -07:00

Minio Quickstart Guide Slack Go Report Card Docker Pulls codecov

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.

Screenshot

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

Contribute to Minio Project

Please follow Minio Contributor's Guide

Languages
Go 99%
Shell 0.8%
Makefile 0.1%