Skip to content

A storage container (plus helper methods) to be used to a data volume for 1:M containers

Notifications You must be signed in to change notification settings

lifegadget/docker-locker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 

Repository files navigation

#Docker Locker

lifegadget/docker-locker [container]

Introduction

Hey wouldn't it be nice if you had a place your "stuff" in Dockerland? Well good news trooper, now you do ... put it in the "Docker Locker". This is a simple container which will serve as a Data Volume Container and has a few nifty helper methods too to make the locker be a great place to be. Enjoy. Fork, steal, contribute back. Do what you like. Make it your locker.

Usage

The primary use case for the locker is to put something into the locker and then have it be used by other Docker containers. This is achieved with the load option of docker-locker:

sudo run lifegadget/docker-locker load [thingy]

Sounds easy right? Well it is. All we need to understand is what "thingy" is ... thingy is one of the following:

  1. Git Repo - just point to a git repo on GitHub or BitBucket and it will clone your repo into the container and make it available at /locker
  2. Tarball - give a URL to a tarball and the locker will download, uncompress the tarball, and make it available at /locker

How great is that? Well it's ok but it gets better.

Load: Environment Switches

In many cases you make just be happy to use things out-of-the-box but the locker provides you some flexibility for your flexible lifestyle needs:

  • BRANCH - allows you specify which branch/tag you want to pull from your git repo. By default it will assume master but choose what you like.

  • ENTRY_ALIAS - often your storage root will contain both your source and distribution (or public) files, in cases where your webserver might expose your content at a particular name -- let's use "api" as an example -- you'll often want to have the generic name of "public" or "dist" be replaced with a name that mimics the functional name. This is helpful when you're using reverse-proxy solutions like NGINX to expose the locker's distribution. To use this simply state the name of the alias and the locker will automagically create a symbolic link to the appopriate folder:

      sudo git run lifegadget/docker-locker  \
      	load git@github.com/badass/some-killer-app \ 
      	-e ENTRY_ALIAS_='api' 
    

    creates a symbolic link to the /dist or /public folder (depending on which exists):

      lrwxrwxrwx  1 root root    14 Oct 10 08:02 api -> /storage/dist
    

    Handy, right? Let's you more easily have a single root directive in your NGINX config.

  • PREP - so maybe you're one of those "I'm never happy types", always asking for something more, maybe what you want is to do something bespoke to your repo? Sound familiar? Well then, you'll pleased to know that here in the locker this sort of selfish behaviour is not only expected but rewarded. Here's how it works, you just specify an array of commands you'd like run over your thingy and once it's been put into the container we'll do your evil bidding.

Load Examples

While talking in the abstract with terms like thingy is great fun and highly entertaining (for us not you), it sometimes leaves one wondering if there's any substance behind the abstract posing. Well thanks for raining on the party but you're right and here you go:

Assume that ...

  • NodeJS Service:

    You love JavaScript so much you want to see it on the server as well as the client. It's your right. We reserve no judgement. So anyway, you've got this killer REST API built using Node and it lives on GitHub at http://github/some-killer-app/nodejs. You believe that living on the edge is the only place to live so obviously the master branch is far too passé so instead you want the locker to hold the this-shits-bleeding branch. So here's how you get that shit out the door and into the locker:

      sudo git run lifegadget/docker-locker run \
      	load git@github.com/badass/some-killer-nodejs-app \
      	-e BRANCH='this-shits-bleeding' \
      	-e ENTRY_ALIAS='bleeder' \
      	-e PREP='["npm install", "bower update"]' \
      	--name nodeApp
      sudo git run -d lifegadget/docker-nginx run \
      	--volumes-from nodeApp
    
  • Couchbase Database:

    SQL is so yesterday, and you're here bring NOSQL to the masses. Couchbase may not have the immediate street cred as Redis or Mongo but you're a sucker of crazy scalable performance and you're buying the Couchbase sponsored research that shows just how smart a techno hipster you are by using this NO-SQL genius. Pat yourself on the back ... it's so good to be you. Here's what you need to do load up your data partition:

      sudo git run lifegadget/docker-locker run \
      	load http://some-killer-app.s3-website-eu-1west-1.amazonaws/i-am-a-nosql-god.tar.gz 
      	--name CDB
      sudo git run -d lifegadget/couchbase start \
      	--volumes-from CDB
    

    this is probably not a very good example, we promise to improve the example in the future when we care more ... in the mean time don't hesitate sending us a PR with a better one.

Private Repos

We can't always be public so for those private moments in repo-land we need a way to authorize our locker to do our bidding. The most convenient way to do this when not travelling with the Docker crowd is to generate a SSH keypair and then add your public key to your repository manager (e.g., github or bitbucket). The problem is that your docker-locker does not have visibility into your host machine's private keys and therefore something else must be done. Fear not young Jedi fighter, the locker has two ways of navigating this:

  • Borrow Host's Key:

    You can simply pass your host's private key in as a parameter to the load command. For instance:

      sudo git run lifegadget/docker-locker run \
      	load http://github/some-killer-app/nodejs \
      	-e PRIVATE_KEY=$(< ~/.ssh/id_rsa)
    
  • Register Container:

    Far less convenient but each Locker auto-generates a public/private keypairing and you can get your public keypair -- which is unique to a given build of the locker -- by running:

      sudo git run lifegadget/docker-locker public-key
    

    With key in hand you can head to your favourite repository and add this public key to the authorisation chain for a repo. With this approach you don't need to worry about passing the PRIVATE_KEY environment variable, all is taken care of for you.

Other Commands

The nice thing about Docker containers is that they are perpetual, meaning they don't need to always be running to keep their state on shared volumes. In almost all cases you'll start using docker-locker by loading something into it using the already covered load command. Equally as likely you'll use the data volume in the locker to feed other containers with the --volume-from switch. Beyond these two core use-cases there are other commands that are supported too:

  • about - just a simple about message which includes the version of the Locker being used (as well as the public key of the container)
  • public-key - the public key for a given container build (note: this will be shared across all lockers for a given build of the locker)
  • pull - if your locker is repo-based then this will refresh it with a git pull
  • refresh - refreshes the content from source (pull for repo, redownload for tarball) and runs the "PREP" if environment variable is set

About

A storage container (plus helper methods) to be used to a data volume for 1:M containers

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages