+ All Categories
Home > Technology > Docker Swarm Meetup (15min lightning)

Docker Swarm Meetup (15min lightning)

Date post: 16-Apr-2017
Category:
Upload: mike-goelzer
View: 4,065 times
Download: 3 times
Share this document with a friend
15
Swarm: Docker Native Clustering Mike Goelzer [email protected] GH: @mgoelzer Freenode/Twitter: @mikegoelzer
Transcript
Page 1: Docker Swarm Meetup (15min lightning)

Swarm:DockerNativeClustering

[email protected]:@mgoelzerFreenode/Twitter:@mikegoelzer

Page 2: Docker Swarm Meetup (15min lightning)

Swarm:Simplicity,Flexibility,EaseofSetup

• WhatisSwarm?• Howdoyousetitup?• Samplemicroservice applicationonSwarm

Page 3: Docker Swarm Meetup (15min lightning)

SwarmturnsmultipleDockerhostsintoasingle,virtualDockerhost.

Page 4: Docker Swarm Meetup (15min lightning)

dockerdaemon(node-1)

Container

Container

>_Docker CLI

dockerDockerComposeKitematicJenkinsplugin

Page 5: Docker Swarm Meetup (15min lightning)

dockerdaemon(node-1)

Container

Container

>_Docker CLI

SwarmmanagerdockerDockerComposeKitematicJenkinsplugin

dockerdaemon(node-0)

Container

Container

dockerdaemon(node-2)

Container

Container

Page 6: Docker Swarm Meetup (15min lightning)

SwarmFeatures

• Scheduling• Reschedulingonfailure• HA(multiplemasters)• Labels,affinitiesandconstraintstocontrolschedulingdecisions• DNS-basedservicediscovery

Page 7: Docker Swarm Meetup (15min lightning)

Simple:2stepstocreateacluster

1. RunSwarmManager2. RestartyourDockerdaemonswith

someextraarguments

Page 8: Docker Swarm Meetup (15min lightning)

Step1:StartSwarmmanager

docker run -d -p 3375:2375 swarm manage consul://192.168.33.10:8500/

Refs:https://docs.docker.com/swarmhttps://docs.docker.com/swarm/install-manual/

Page 9: Docker Swarm Meetup (15min lightning)

Step2:Addsomeargs toyourdaemons

RestartDockerdaemonswith:

DOCKER_OPTS=-H=tcp://0.0.0.0:2375--cluster-store=consul://192.168.33.11:8500--cluster-advertise=eth1:2375

Refs:https://docs.docker.com/swarmhttps://docs.docker.com/swarm/install-manual/

Page 10: Docker Swarm Meetup (15min lightning)

Voilà,acluster

Page 11: Docker Swarm Meetup (15min lightning)

ExampleRepo:MicroserviceApponSwarm

UpcomingSwarmMeetup:http://www.meetup.com/Docker-Mountain-View/events/228284089/

https://github.com/mgoelzer/swarm-demo-voting-appDemonstratesamicroservice apponSwarmincluding:• Vagrantfile andAWSCloudFormation templatetodeploy thecluster• Loadbalancedwebfrontend• DNS-basedservicediscovery

Page 12: Docker Swarm Meetup (15min lightning)

Interlock(nginxorha_proxy)

web01

redis01

web02

redis02

web03

redis03

web04

redis04

web05

redis05

pg results-app

10.0.0.4

10.0.0.3

36.36.36.36

10.0.0.100

10.0.0.5

10.0.0.5

10.0.0.7

10.0.0.6

10.0.0.9

10.0.0.8

10.0.0.11

10.0.0.10

10.0.0.101

https://github.com/mgoelzer/swarm-demo-voting-app

Page 13: Docker Swarm Meetup (15min lightning)

ClusteredVotingApp

https://github.com/mgoelzer/swarm-demo-voting-app

Page 14: Docker Swarm Meetup (15min lightning)

Jérôme’sExample:CoinMiner

Slides:http://view.dckr.info/Repo:https://github.com/jpetazzo/orchestration-workshop

Demonstrates:• HowtodobatchworkloadsonSwarm• ELKstackforlogging andmetrics• Otherloadbalancingpatternsbeyond Interlock

Page 15: Docker Swarm Meetup (15min lightning)

MikeGoelzer|[email protected] | GH:@mgoelzer |@mikegoelzer


Recommended