node-container
v0.2.0
Published
Puts a node app into a docker container
Downloads
9
Readme
node-container
Create a docker container from a node app and run it, because we're hipster like that.
WIP don't use for serious apps yet!
I'd love to hear your feedback. There are a lot of details to flesh out yet. Also checkout my wish list below.
Installation
npm install node-container
Usage
Give it the path of your node app...it'll do the rest (ideally). Note: The docker daemon needs to run somewhere accessible.
You can do npm test
to see it in action.
The first time you run it can take a while, since it needs to fetch the base images.
Subsequent runs should be pretty fast.
var containerize = require('node-container')
// pass it the directory of your node app, config is optional
containerize(__dirname + '/testrepo', config, function (err, container) {
if (err) throw err
console.log('DONE')
console.log(container)
})
container
is the output of docker inspect [container]
.
There you'll find the containers id, pid, network settings etc.
Configuration options
All of these are optional, but you probably want to at least set the docker config.
It can also be specified in the environment as
DOCKER_HOST=tcp://localhost:4243
{
// docker config
host: 'http://localhost',
port: 4243,
// socketPath: '',
// prefix for images and containers, eg 'prefix-appname' or 'prefix/imagename'
prefix: 'tests',
// whether to run the container or not
run: true,
// whether to monitor the node process with mon or not
monitor: true
}
What does it do exactly?
- It
npm pack
s your app, so you get all the npm goodies you expect - Copies over our Dockerfile
- Build an image from our Dockerfile with your app in it. The image provides
- a stable, updated ubuntu 12.04 base system
- the latest stable node version
- the mon process monitor (
visionmedia/mon
) to keep your app running - and runs
npm install --production
for your app
- Runs a container from the image
- which runs
npm start
for your app - and monitors it with
mon
What do I need to do?
- If your app listens to a port, it has to get it from
process.env.PORT
- If you want to listen to a specific port, you can specify it in your package.json with
port: 1234
otherwhise it defaults to3000
. If you don't want to expose it to the world you can setport: false
- Your app needs to be runnable with
npm start
Options you can set in your app's package.json
{
"port": false
}
Take a look add the test app.
Wishlist
- use node version as specified in package.json
- persistent volume support
- be more flexible wrt docker run options etc
- evaluate if it's possible to run apps as non-root user
- CLI
- find a better way to negotiate ports
Contributing
If you find a bug, have a feature request or any kind of question, please open an issue or submit a pull request. I'm open for discussing any kind of idea for node-container.