Skip to content

djmaze/goofys-docker

 
 

Repository files navigation

license GitHub tag Docker Stars Docker Pulls

goofys-docker is a docker volume plugin wrapper for S3

Overview

The initial idea behind mounting s3 buckets as docker volumes is to provide store for configs and secrets. The volume as per goofys does not have features like random-write support, unix permissions, caching.

Getting started

Requirements

The docker host should have FUSE support with fusermount cli utility in $PATH

Building

# Might need to prefix with "sudo" because docker is used
make

See the Makefile for additional options and targets.

Installing & configuration

The most simple way to configure aws credentials is to use IAM roles to access the bucket for the machine, aws configuration file or ENV variables. The credentials will be used for all buckets mounted by goofys-docker.

The driver is installed as a Docker volume plugin. The latest release can be installed like this:

docker plugin install decentralize/goofys-volume-plugin OPTION=VALUE ...

The options given at the end of the line are optional. They can be specified at the volume level instead (see below).

The following driver-level options are available:

  • ENDPOINT - hostname of S3 endpoint (e.g. "nyc1.digitaloceanspaces.com").
  • ACCESS_KEY - S3 access key.
  • SECRET_KEY - S3 secret key.

Running

Using with docker

docker volume create --name=VOLUME_NAME --driver=decentralize/goofys-volume-plugin --opt OPTION

Options

  • bucket - Optional S3 bucket name. The default bucket is the volume name.
  • prefix - Optional S3 prefix path.
  • endpoint - Optional hostname of S3 endpoint (e.g. "nyc1.digitaloceanspaces.com") (overrides driver-level configuration).
  • region - Optional AWS region (default is "us-east-1").
  • acl - Optional ACL to use (default is "private").
  • storage-class - Optional storage class
  • debugs3 - Optional S3 debug logs (default is 0).
  • use-cache - Optional use catfs in order to cache file contents.
  • uid - Optional set user id to mount the volume as.
  • gid - Optional set group id to mount the volume as.
  • dir-mode - Optional set default permissions for new directories (default is "0755").
  • file-mode - Optional set default permissions for new files (default is "0644").
  • cheap - Optional enable cheap mode which saves on S3 requests (default off, see goofys documentation).
  • access_key - Optional S3 access key (overrides driver-level configuration).
  • secret_key - Optional S3 secret key (overrides driver-level configuration).

Create a new volume by issuing a docker volume command:

docker volume create --name=test-docker-goofys --driver=decentralize/goofys-volume-plugin region=eu-west-1

That will create a volume connected to test-docker-goofys bucket. The region of the bucket will be autodetected.

Nothing is mounted yet.

Launch the container with test-docker-goofys volume mounted in /home inside the container.

docker run -it --rm -v test-docker-goofys:/home:ro -it busybox sh
/ # cat /home/test
test file content
/ # ^D

Pass the bucket name as an option instead of the default volume name value:

docker volume create --name=vol1 --driver=decentralize/goofys-volume-plugin --opt bucket=test-docker-goofys --opt region=eu-west-1
docker run -it --rm -v vol1:/home:ro -it busybox sh
/ # cat /home/test
test file content
/ # ^D

It is also possible to mount a subfolder:

docker volume create --name=vol1 --driver=decentralize/goofys-volume-plugin --opt prefix=folder region=eu-west-1
docker run -it --rm -v vol1:/home:ro -it busybox sh
/ # cat /home/test
test file content from folder
/ # ^D

If multiple folders are mounted for the single bucket on the same machine, only 1 fuse mount will be created. The mount will be shared by docker containers. It will be unmouned when there be no containers to use it.

License

MIT

About

S3 volume driver for docker based on goofys

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 81.6%
  • Makefile 7.9%
  • Dockerfile 7.7%
  • Shell 2.8%