Tutum

The Story So Far

Image

Your application and all it's dependencies packaged together.

gazelle/wit:latest

OS: Debian

Language: Ruby

App: WIT

Gems + Packages

Describing the Environment

Service

tst-wit-web:
  image: 'tutum.co/gazelle/wit:latest'
  deployment_strategy: high_availability
  environment:
    - FORCE_SSL=1
    - RACK_ENV=staging
    - 'VIRTUAL_HOST=https://wit-tst.cns.gazelle.com,http://wit-tst.cns.gazelle.com'
  expose:
    - '8080'
  tags:
    - open
    - tst

Stack

tst-wit-lb:
  image: 'tutum/haproxy:latest'
  deployment_strategy: high_availability
  environment:
    - BACKEND_PORT=8080
    - 'DEFAULT_SSL_CERT=-----BEGIN PRIVATE KEY----------END CERTIFICATE-----'
    - 'OPTION=http-server-close, redispatch, httplog, dontlognull, forwardfor'
    - 'SSL_BIND_CIPHERS=ECDHE-RSA-AES128-GCM-SHA256'
    - 'STATS_AUTH=admin:password'
  links:
    - tst-wit-web
  ports:
    - '80:80'
    - '443:443'
    - '1936:1936'
  restart: always
  roles:
    - global
  tags:
    - open
    - tst
tst-wit-web:
  image: 'tutum.co/gazelle/wit:latest'
  deployment_strategy: high_availability
  environment:
    - FORCE_SSL=1
    - RACK_ENV=staging
    - 'VIRTUAL_HOST=https://wit-tst.cns.gazelle.com,http://wit-tst.cns.gazelle.com'
  expose:
    - '8080'
  tags:
    - open
    - tst

Running the Environment

Node

172.31.255.255

An AWS instance that hosts containers

Docker

Daemon

tst-wit-lb

tst-wit-web

Node Cluster

A collection of nodes with the same attributes:

  • Tags
  • VPC
  • Subnet
  • Security

VPC: tutum-open-vpc

Tags: tst, open, t2large

Subnet: tutum-open-subnet

Security group: tst-tutum-vpc

172.31.255.255

172.31.255.255

172.31.255.255

172.31.255.255

172.31.255.255

172.31.255.255

Networking

Ports

172.31.255.255

tst-wit-web

serves

8080

app

container

expose

8080

as

8080

publishes

8080

Publishing Ports

172.31.255.255

A node can only publish port 8080 for one app

tst-sort-web

tst-wit-web

8080

8080

Overlay Network

172.31.255.255

A software network that treats containers like nodes

tst-wit-web

tst-multi-lb

link

8080

expose

8080

publish

8080

link

8080

tst-sort-web

Demo

CLI

> brew install tutum

> tutum login
user: gazelle
password: **********

# Tails combined log of all instances of this service
> tutum service logs -f tst-wit-web

# Connects to the running instance
> tutum container exec tst-wit-web-1 bash

# After an instance is terminated, it sticks around for a little bit, so names can clash.
# Use this to find the ID of the container.
> tutum container ps | grep tst-wit-web

> tutum container exec af2342 bash



问题?

Tutum

By blatyo

Tutum

  • 842