SlideShare a Scribd company logo
1 of 70
inBloom, Inc.
server to cloud
converting a legacy platform to an open source paas
todd fritz
April 3. 2014
inBloom, Inc.
agenda
• whoami
• goals
• change
• genesis
• decompose
• refactor
• architecture
• ajug
• questions
• references
• appendix
APRIL 2014 1
inBloom, Inc.
whoami
bio: http://www.linkedin/com/in/tfritz
• architect at inbloom
 opinions contained within this presentation may not represent my employer, but I
think they should
• evangelist of layered, distributed, message-oriented-middleware
• current focus is middleware through caching, nosql data store
• exposed to different companies, projects, people and technologies
• novice bass player
• recent father of a five month old
• scuba diver. next adventure:
 https://www.bikiniatoll.com/divetour.html
APRIL 2014 2
No sleep for you!
inBloom, Inc.
thanks
credit for those who helped (or listened)
• altisource
 todd nist
• inbloom
 verlin henderson
 paul lawler
 vincent mayers
 ben morgan
 bill siggelkow
• red hat
 ray ploski
APRIL 2014 3
inBloom, Inc.
inBloom, Inc.
email: oss@inbloom.org
twitter: @inBloomDev
dev.inbloom.org
APRIL 2014 4
inBloom, Inc.
goals
APRIL 2014 5
inBloom, Inc.
objectives for next 45 minutes
• to delay you from happy hour and inspire curiosity
• discuss the benefits of change
• shine a light on a path forward
• cover the if, why and how to modernize
• define basic cloud migration criteria
• explain techniques to decompose legacy apps
• virtualization and containerization
• evangelize containers as an architecture enabler
• discuss migration strategy and architectures
• this talk does not (yet) include code examples (coming soon
to atlanta java users group)
APRIL 2014 6
inBloom, Inc.
change
APRIL 2014 7
inBloom, Inc.
what? change? why?
APRIL 2014 8
an unknown manager in the
wild, ready to spray a can of
dilbert.
http://d1r5i20o8cadcu.cloudfront.net/designs/images/76856/original/programmer_creattica_full.jpg
inBloom, Inc.
may we live in interesting times
innovation is impossible without change
• ―Software is eating the world.‖ – Marc Andreesson, 2011, Wall Street
Journal
 ―We are in the middle of a dramatic and broad technological and
economic shift in which software companies are poised to take over
large swathes of the economy. More and more major businesses and
industries are being run on software and delivered as online services—
from movies to agriculture to national defense.‖
• ―Every company is a software company -- or at least aspiring to be
one. That reality will shake up industries, lead to huge successes
and failures and potentially make or break brands.‖ – Larry Dignan
• ―…this software revolution in every company will be similar to how
enterprise resource planning changed the game for businesses and
their processes.‖ – Forrester analyst John McCarthy
APRIL 2014 9
http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats-the-key-to-business-model-success-.html
inBloom, Inc.
innovation economics
• a growing economic doctrine that adapts conventional economics
theory so that knowledge, technology, entrepreneurship, and
innovation are at the center of the model
 rather than independent forces that are largely unaffected by policy
 good fit for companies that manage software
• two fundamental tenets:
1. economic policy should drive productivity through innovation
2. market reliance on resources and price signals alone may not
be as effective to create both productivity and economic growth
• differs from conventional economic doctrines
• companies benefit from innovation in obvious ways
APRIL 2014 10
inBloom, Inc.
a path forward
how does a company that has not traditionally been in the software
space become a successful software company? also applies to a
software company that is reinventing itself, and startups.
1. protect intellectual property
2. re-think software monetization models
 based on how customers want to pay
 subscription models
3. automate the entire software, device and entitlement lifecycle
 software installation, provisioning, activation
 subscription management, software updates and upgrades
 software entitlements (features)
4. purpose-built software licensing and entitlement management
APRIL 2014 11
http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats-the-key-to-business-model-success-.html
inBloom, Inc.
status quo gets left behind
• today will not be tomorrow
• cloud provides competitive advantage for some use cases
 amazon is market leader
 ongoing competition between cloud providers; amazon and google
 encourages use standards and adoption of new tech and patterns
• technology advances disrupt computing infrastructure and software
to expose opportunity
• quantum computing, e.g. d-wave qubit
 ok, some controversy, but it is fast
 significant advance in compute power
 will disrupt software design and how we scale, e.g. compute grids
 it is real, maturing, and is not going away
 outpaces moore’s law as it scales
 http://www.gizmag.com/d-wave-quantum-computer-supercomputer-ranking/27476/
APRIL 2014 12
inBloom, Inc.
cloud adoption – 36% increase – benefits
APRIL 2014 13
http://www.secure-24.com/the-advantages-of-infrastructure-outsourcing/
inBloom, Inc.
good candidates for cloud
1. strong business sponsorship at tip of spear
2. well understood with few dependencies
3. uses common standards and implementations
4. can be decomposed or decoupled
5. already modularized or service oriented
6. already virtualized
7. favorable cost-benefit analysis
8. security model translates to cloud
9. opportunities to improve by modernization
APRIL 2014 14
http://www.websitepulse.com/blog/the-great-cloud-migration-are-your-apps-ready
inBloom, Inc.
unfavorable candidates – who has one?
1. lacks strong business sponsorship
2. security equation difficult to understand
3. complex architecture and external dependencies
4. technology or deployment lock in
5. latency sensitive (real time apps)
6. not standards based or uses home-grown libraries
7. etl heavy (not parallelized) or long running jobs
8. government regulations, contractual requirements, or
certifications (pci)
9. unfavorable economics (cost-benefit/risk analysis)
10. transaction lifecycles not well understood
APRIL 2014 15
http://www.websitepulse.com/blog/the-great-cloud-migration-are-your-apps-ready
inBloom, Inc.
the go forward decision
APRIL 2014 16
inBloom, Inc.
genesis
APRIL 2014 17
inBloom, Inc.
hello world! i am a legacy system
APRIL 2014 18
inBloom, Inc.
what to do with it?
break it apart; analyze
employ an iterative methodology
 leverage existing knowledge and literature
 some analysis before
 decompose and modularize (scale cube)
 separation of concerns
 proof of concepts are your friend
deployment environments
 private servers
 cloud (private, public)
 hybrid
platform architectures
 legacy
 paas
 xpaas
APRIL 2014 19
inBloom, Inc.
terms
• paas
 “Platform as a service (PaaS)…provides a computing
platform and a solution stack as a service. Along with
software as a service (SaaS) and infrastructure as a service
(IaaS), it is a service model of cloud computing… the
consumer creates the software using tools…from the
provider. The consumer also controls software deployment
and configuration... The provider provides the
networks, servers, storage, and other services that are
required to host the consumer's application” -wikipedia
• xpaas
 standardization of enterprise paas
 create platforms from a catalogue of paas/saas/iaas
APRIL 2014 20
inBloom, Inc.
paas by segment
gartner’s 2012 paas market share chart (from red hat’s xpaas whitepaper).
APRIL 2014 21
inBloom, Inc.
xpaas topology
APRIL 2014 22
https://img.en25.com/Web/RedHat/JB_xPaaS_Tech_Overview_11454037_v3_0913cd_web.pdf
• enables specialization, layering, separated concerns, decoupling
inBloom, Inc.
decompose
APRIL 2014 23
inBloom, Inc.
i am the fragments of a legacy system
APRIL 2014 24
hear me roar…
inBloom, Inc.
what have I gotten myself into?
APRIL 2014 25
http://www.secure-24.com/the-advantages-of-infrastructure-outsourcing/
“legacy spaghetti”
the code sucks…
i can’t even build it…
inBloom, Inc.
getting started
• involve devops from the beginning
• if your company does not have devops then call pressureManager()
• make decisions from quantitative assessments
• agile systems analysis and integration modeling
• agile modeling best practices
• use the afk scale cube
 http://akfpartners.com/techblog/2008/05/08/splitting-applications-or-
services-for-scale/
• read ―The Art of Scalability‖ by abbott and fisher
 http://theartofscalability.com/
• perform functional decomposition and service identification
• the cloud is not ―all or nothing‖
 phased migrations can realize immediate value
 new technologies can coexist with legacy
• iterative design ahead
• use containers to enable decoupling, architectural flexibility, confine legacy
APRIL 2014 26
inBloom, Inc.
legacy analysis and design
• decompose into layers; functions and separate concerns
• design decoupled components and services
• isolate technologies within components (insulate lock-in)
• conceptualize legacy components and services as
―legos‖
• future state runs alongside current state to provide value
• take heed of transaction lifecycle, batch jobs, data
retention and use cases
• be mindful of customer impact, cost and schedule
constraints
• consider security at each layer and service
APRIL 2014 27
inBloom, Inc.
success – value add criteria
APRIL 2014 28
“For every complex question there is a simple and wrong solution.”
- Albert Einstein
avoid “Khan’s paradigm”:
a top-down plan led by an overlord
of super-humans will fail.
my Java kung fu can
crush any project.
tactical
• time, cost, quality
strategic
• sustainability, relevance, effect
inBloom, Inc.
agile modeling best practices
APRIL 2014 29
http://www.agilemodeling.com/essays/bestPractices.htm
inBloom, Inc.
refactor
APRIL 2014 30
inBloom, Inc.
assembling the new system
APRIL 2014 31
inBloom, Inc.
we can rebuild it
• cynical optics
 rather than one bowl of spaghetti; several small, independent plates
 investment in analysis, design ahead, separating concerns has tangible
benefits
 use containers!
APRIL 2014 32
before after
inBloom, Inc.
putting it together
• favor continuous deployment
• prefer reusable, modularized components
• decoupled services; soa done right (microservice)
• message oriented and event driven
• parallelize development across business function
• select the right tool for each component; polyglot
• include automated unit and integration tests
• leverage containerization instead of virtualization
when possible (see next slide)
APRIL 2014 33
inBloom, Inc.
why containers?
APRIL 2014 34
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
revisting paas requirements
• ―Virtualization vs. Containers to support PaaS‖
 by Dua, Raja, Kakadia
 http://www.slideshare.net/rajdeep/conference-presentationv3
 Basis of next three slides
• paas focuses on developer productivity and abstracts out
underlying infrastructure
• 3 key paas requirements for the infrastructure
1. network, compute and storage programmatically
managed and provisioned
2. h/a infrastructure (e.g. nodes) efficiently utilized
3. ability to bind applications/services to external
network (dns, routers)
APRIL 2014 35
inBloom, Inc.
paas requirements (cont.)
1. network, compute and storage programmatically managed and
provisioned
2. h/a infrastructure (e.g. nodes) efficiently utilized
3. ability to bind applications/services to external network
(dns, routers)
 vms good for #1 & #2
 apps can reside within:
• vms
• containers
• vms with containers
 containers better for #3 as resources better utilized
and light weight
APRIL 2014 36
inBloom, Inc.
paas requirements (cont.)
• containers have weaknesses (for now)
 standardization
 strong security
 os independence
 robust monitoring
• ―Containers have inherent advantage over VMs for
PaaS use case‖.
- Dua, Raja, Kakadia
APRIL 2014 37
inBloom, Inc.
container platform contenders
• warden (cloud foundry)
 https://github.com/cloudfoundry/warden
• docker
 https://www.docker.io/
• google lmctfy (let me contain that for you)
 https://github.com/google/lmctfy
 december, 2013
• openvz
APRIL 2014 38
inBloom, Inc.APRIL 2014 39
container of the day
inBloom, Inc.
about docker
docker is a micro container framework for paas
• https://www.docker.io/learn_more/
• open-source
• easier scalability
• lightweight, portable, insulated containers
• reusable from dev (―local cloud‖) through production
• can run at scale on vms, bare metal, cloud; virtually
anywhere
• encapsulate any payload (application)
• run consistently on and between virtually any server
APRIL 2014 40
inBloom, Inc.
more about docker
APRIL 2014 41
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
brief overview about how it works
• docker builds on lxc which offers system-level virtualization and has existed since
linux 2.6.32 (December, 2009) – but use 3.8+
• docker has three parts
 docker daemon runs as root to manage containers
 docker containers spawn from images, which are tiny and can be versioned
 docker repository allows images to be exchanged and versioned like code
(public or private)
• each container has its own ip address
• link exposed ports and variables across containers through configuration using
abassador containers to avoid hard coding (svendowideit):
 consumer  redis-ambassador  redis
• port and pipework to expose containers outside host
• can share volumes, multi home, integrate containers into host network, and much
more (ajug)
• continuous integration can generate versioned docker images, web hooks, repo
notifications
• supervisor management tool to manage processes within container
(http://supervisord.org/introduction.html)
APRIL 2014 42
inBloom, Inc.
even more about docker
• common use cases:
 automate application packaging and deployment
 lightweight paas environments
 automate testing, continuous integration, and deployment
 deploy and scale web apps, databases, backend services
• growing adoption since dec 2013
• red hat fast-tracks docker apps for enterprise linux
 http://www.infoworld.com/t/application-virtualization/red-
hat-fast-tracks-docker-apps-enterprise-linux-238122
• production ready deployment planned for december, 2014.
 Support services planned for early 2015
APRIL 2014 43
inBloom, Inc.
containers available for reuse
APRIL 2014 44
http://www.slideshare.net/dotCloud/docker-intro-november
a docker container image may already exist
inBloom, Inc.
docker image registry – versioning!
APRIL 2014 45
http://www.slideshare.net/dotCloud/docker-intro-november
artifactory for virtualization images?
inBloom, Inc.
New in Docker 0.9
• execution driver api
 customize execution environment around container; enables use
of other isolation tools
• built in execution container - libcontainer
 alongside lxc, boosts stability, insulates docker from different
versions of lxc
APRIL 2014 46
inBloom, Inc.
architecture
APRIL 2014 47
inBloom, Inc.
containers enable architecture
• containers enable architecture and design
• design, build, or migrate, each layer or module into a container
• containers encapsulate technology, isolate lock-in, and are easy to scale
• enables use of best tool; go polyglot
• easy to upgrade what’s in a container
 replace node.js with vert.x
 technology portability
• understand workload and transaction use cases (data stores, social)
• service oriented (done right, not soap)
• learn message oriented middleware (mom)
 enterprise integration patterns (eip)
 apache camel
 queues (amqp)
• prefer data streams to batch jobs
• leverage power of compute grids and distributed caching
• pay the piper and dedicate effort to data/domain architecture
APRIL 2014 48
inBloom, Inc.
ajug
APRIL 2014 49
inBloom, Inc.
coming soon
• v2 of this presentation
 with code examples
 in-depth architecture ideas
 development concepts
• to be presented to atlanta java users group (ajug)
APRIL 2014 50
inBloom, Inc.
questions
APRIL 2014 51
inBloom, Inc.
references
APRIL 2014 52
inBloom, Inc.
reference material
• https://www.docker.io/
• http://deis.io/overview/
• http://www.ambysoft.com/essays/brokenTriangle.html
• http://martinfowler.com/articles/microservices.html#MicroservicesAndSoa
• http://www.susannemadsen.co.uk/1/post/2013/12/the-iron-triangle-and-the-tripleconstraintsare-outdated.html
• http://www.slideshare.net/pet-computacao/software-evolution-from-legacy-systems-service-oriented-architecture-
to-cloud-computing
• http://www.cloudcomputingpatterns.org/Message-oriented_Middleware
• https://img.en25.com/Web/RedHat/JB_xPaaS_Tech_Overview_11454037_v3_0913cd_web.pdf
• http://www.infoq.com/articles/sustainable-architectural-design-decisions
• http://www.sciencedirect.com/science/article/pii/S0268401201000135
• http://martinfowler.com/bliki/TolerantReader.html
• http://www.cakesolutions.net/teamblogs/2014/01/28/deploying-scala-akka-based-applications-to-amazon-cloud/
• http://highscalability.com/blog/2013/5/8/typesafe-interview-scala-akka-is-an-iaas-for-your-process-ar.html
• http://www.informationweek.com/software/moving-legacy-apps-to-the-cloud/d/d-id/1108964
• http://www.forbes.com/sites/louiscolumbus/2012/11/08/cloud-computing-and-enterprise-software-forecast-update-
2012/
• http://blogs-images.forbes.com/louiscolumbus/files/2013/01/Bain-Go-To-Market-System.jpg
• http://www.infoq.com/articles/SaaSificationOfLegacyApps
• http://www.agilemodeling.com/essays/bestPractices.htm
• http://osintegrators.com/node/145
• http://appsembler.com/blog/paas-bakeoff-comparing-stackato-openshift-dotcloud-and-heroku-for-django-hosting-
and-deployment/
APRIL 2014 53
inBloom, Inc.
More Reference Material
• Redmonk on DB technology: http://www.youtube.com/watch?v=HClEcT8n5Lc&app=desktop
• http://gigaom.com/2014/03/25/heres-the-google-vs-amazon-pricing-break-down/
• Decomposing applications for scalability and deployability
 http://vimeo.com/49392435
• http://venturebeat.com/2008/10/13/the-cloud-isnt-for-everyone/
• http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats-
the-key-to-business-model-success-.html
• https://blog.codecentric.de/en/2014/01/lightweight-virtual-machines-made-simple-docker-run-100-
virtual-maschines/
• https://blog.codecentric.de/en/2014/01/docker-networking-made-simple-3-ways-connect-lxc-
containers/
• http://blog.docker.io/2014/03/docker-0-9-introducing-execution-drivers-and-libcontainer/
APRIL 2014 54
inBloom, Inc.
appendix
(slides that did not fit within time constraint)
APRIL 2014 55
inBloom, Inc.
paas -> xpaas
an xpaas is composed of multiple, specialized paas
systems
―…xPaaS services augment core container functionality with
integration, business process management (BPM) and mobile
capabilities.‖
 integration paas (ipaas) -- simplifies
connections, messages, route definitions, and data
transformations
 bpm paas (bpmpaas) -- process modeling, process
engine, simplify definition and evolution of business processes
 mobile paas (mpaas) -- push notifications, data synchronizations
and back-end integration
 …
APRIL 2014 56
inBloom, Inc.
agile legacy systems analysis and
integration modeling
APRIL 2014 57
Methodology: http://www.agilemodeling.com/essays/agileLegacyIntegrationModeling.htm
inBloom, Inc.
the scale cube
APRIL 2014 58
inBloom, Inc.
Analysis Considerations
• Refine understanding of current and future state solutions
 Client-Server (beware of stateful thick clients)
 N-Tier
 SaaS ready components?
• Features, use cases, request lifecycle
• Messaging models, usage patterns, volume and velocity – capacity planning
• Messaging? Network configuration?
• All aspects of security
• Identify components and concerns, layers
• Impact of latency
• Caching, and Master Data Management (MDM)
• Identify problems and do not ignore technical debt…
• Product Management != Project Management (or scrum master)
The unknown may lead to failure, delays or increased cost.
APRIL 2014 59
inBloom, Inc.
Security First
FEBRUARY 2014 60
• Foundational
• Assess all concerns and services
• Network, OS, Disk (data at rest)
• Applications
• Encryption
• Data
• Protecting Personally Identifiable Information (PII)
• Securing logged information
• Securing in-memory objects and caches
• User Authentication and Authorization
• Manage users, groups, roles and permissions, SSO
• Separate abstractions for Authentication from Authorization (CAS, etc)
• OAUTH, SAML2
• Learn about SENDS
• Science-Enhanced Networked Domains and Secure Social Spaces
• Security needs to be more than a technology solution
• http://www.theatlantic.com/technology/archive/2011/03/cyber-security-cant-ignore-human-
behavior/72826/
• Be aware of industry bias toward technical solutions with security.
• Can’t control stupid human behaviors such as taping a password to keyboard.
• APRIL
inBloom, Inc.
What?
Perhaps you are wondering…
• Why Docker?
The next several slides provide background
• (Borrowed from Docker’s site.)
Keep in mind:
• Docker containers encapsulate concerns
• Avoids Holy Wars about specific architectures to implement
• Great for the dozens of Spring projects..
 Run each within its own Container
APRIL 2014 61
inBloom, Inc.
how a docker works
• uses linux kernel for containment (jailing)
 chroot: changes root directory of process w/ child
 cgroups: control groups
• groups processes (to unit of thread)
• pseudo filesystem
• numerous subsystems functions implemented
– CPU sets, etc
• linux containers: lxc
 file system isolation
 network and process isolation
 resource allocation
APRIL 2014 62
inBloom, Inc.
Converting the Legacy App into Docker
• Containers enable extreme choice – use what you want.
• Container model facilitates separates concerns
 Applications (various technologies)
 Back End systems including ―Big Data‖
 Messaging
 Caching (e.g. Hazelcast!)
 Microservices. Use Data as glue.
APRIL 2014 63
inBloom, Inc.APRIL 2014 64
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
Docker Ecosystem
APRIL 2014 65
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
Why Developers should Care about Docker
APRIL 2014 66
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
DevOps & Docker
APRIL 2014 67
http://www.slideshare.net/dotCloud/docker-intro-november
inBloom, Inc.
More about Docker
• Deis is a framework that caps Docker and Heroku
 http://deis.io/deis-0-5-1-docker-containers-all-the-way-down/
 ―Deis…is an open source PaaS that makes it easy to deploy and scale Docker containers
and Chef nodes used to host applications, databases, middleware and other services. Deis
leverages Chef, Docker, Heroku Buildpacks to provide a private PaaS that is lightweight and
flexible.‖
 Supported Languages
• Java, Scala, PHP, Ruby, Python, Node.js, Clojure, Play, Perl, Dart, Go.
• Deis can deploy anything using Heroku Buildpacks or Dockerfiles.
 Supported Providers
• Any system including every public cloud, private cloud or bare metal.
• Automatic provisioning for EC2, Rackspace, Digital Ocean
• Integration testing with Maven and Docker
 http://giallone.blogspot.co.uk/2014/03/integration-testing-with-maven-and.html
• Industry timeline from 1995 to Docker
 http://5pi.de/docker-intro/#/step-1
• Decker
APRIL 2014 68
inBloom, Inc.
Message Oriented Middleware
APRIL 2014 69

More Related Content

What's hot

Crash Course in Open Source Cloud Computing
Crash Course in Open Source Cloud Computing Crash Course in Open Source Cloud Computing
Crash Course in Open Source Cloud Computing Mark Hinkle
 
Open Source Tool Chains for Cloud Computing
Open Source Tool Chains for Cloud ComputingOpen Source Tool Chains for Cloud Computing
Open Source Tool Chains for Cloud ComputingMark Hinkle
 
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud Computing
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud ComputingInteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud Computing
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud ComputingMark Hinkle
 
Talk at the Boston Cloud Foundry Meetup June 2015
Talk at the Boston Cloud Foundry Meetup June 2015Talk at the Boston Cloud Foundry Meetup June 2015
Talk at the Boston Cloud Foundry Meetup June 2015Chip Childers
 
Cloud Computing Expo West - Crash Course in Open Source Cloud Computing
Cloud Computing Expo West - Crash Course in Open Source Cloud ComputingCloud Computing Expo West - Crash Course in Open Source Cloud Computing
Cloud Computing Expo West - Crash Course in Open Source Cloud ComputingMark Hinkle
 
Future of Open Source in a Cloudy World
Future of Open Source in a Cloudy WorldFuture of Open Source in a Cloudy World
Future of Open Source in a Cloudy WorldBret Piatt
 
Why kubernetes for Serverless (FaaS)
Why kubernetes for Serverless (FaaS)Why kubernetes for Serverless (FaaS)
Why kubernetes for Serverless (FaaS)Krishna-Kumar
 
Containers, microservices and serverless for realists
Containers, microservices and serverless for realistsContainers, microservices and serverless for realists
Containers, microservices and serverless for realistsKarthik Gaekwad
 
How to contribute to cloud native computing foundation (CNCF)
How to contribute to cloud native computing foundation (CNCF)How to contribute to cloud native computing foundation (CNCF)
How to contribute to cloud native computing foundation (CNCF)Krishna-Kumar
 
Cloud Native Patterns with Bluemix Developer Console
Cloud Native Patterns with Bluemix Developer ConsoleCloud Native Patterns with Bluemix Developer Console
Cloud Native Patterns with Bluemix Developer ConsoleMatthew Perrins
 
CloudOpen 2014 - Mixing Your Open Source Cloud Cocktail
CloudOpen 2014 - Mixing Your Open Source Cloud CocktailCloudOpen 2014 - Mixing Your Open Source Cloud Cocktail
CloudOpen 2014 - Mixing Your Open Source Cloud CocktailMark Hinkle
 
Containers, OCI, CNCF, Magnum, Kuryr, and You!
Containers, OCI, CNCF, Magnum, Kuryr, and You!Containers, OCI, CNCF, Magnum, Kuryr, and You!
Containers, OCI, CNCF, Magnum, Kuryr, and You!Daniel Krook
 
The DIY Punk Rock DevOps Playbook
The DIY Punk Rock DevOps PlaybookThe DIY Punk Rock DevOps Playbook
The DIY Punk Rock DevOps Playbookbcantrill
 
VMware@Night: Container & Virtualisierung
VMware@Night: Container & VirtualisierungVMware@Night: Container & Virtualisierung
VMware@Night: Container & VirtualisierungDigicomp Academy AG
 
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayer
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayerTaking the Next Hot Mobile Game Live with Docker and IBM SoftLayer
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayerDaniel Krook
 
IBM Container Service Overview
IBM Container Service OverviewIBM Container Service Overview
IBM Container Service OverviewKyle Brown
 
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...Docker, Inc.
 
Containers and microservices for realists
Containers and microservices for realistsContainers and microservices for realists
Containers and microservices for realistsKarthik Gaekwad
 
The Internet-of-things: Architecting for the deluge of data
The Internet-of-things: Architecting for the deluge of dataThe Internet-of-things: Architecting for the deluge of data
The Internet-of-things: Architecting for the deluge of databcantrill
 
Alibaba Cloud Conference 2016 - Docker Open Source
Alibaba Cloud Conference   2016 - Docker Open Source Alibaba Cloud Conference   2016 - Docker Open Source
Alibaba Cloud Conference 2016 - Docker Open Source John Willis
 

What's hot (20)

Crash Course in Open Source Cloud Computing
Crash Course in Open Source Cloud Computing Crash Course in Open Source Cloud Computing
Crash Course in Open Source Cloud Computing
 
Open Source Tool Chains for Cloud Computing
Open Source Tool Chains for Cloud ComputingOpen Source Tool Chains for Cloud Computing
Open Source Tool Chains for Cloud Computing
 
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud Computing
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud ComputingInteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud Computing
InteropNY/CloudConnect 2014 - Quick Crash Course in Open Source Cloud Computing
 
Talk at the Boston Cloud Foundry Meetup June 2015
Talk at the Boston Cloud Foundry Meetup June 2015Talk at the Boston Cloud Foundry Meetup June 2015
Talk at the Boston Cloud Foundry Meetup June 2015
 
Cloud Computing Expo West - Crash Course in Open Source Cloud Computing
Cloud Computing Expo West - Crash Course in Open Source Cloud ComputingCloud Computing Expo West - Crash Course in Open Source Cloud Computing
Cloud Computing Expo West - Crash Course in Open Source Cloud Computing
 
Future of Open Source in a Cloudy World
Future of Open Source in a Cloudy WorldFuture of Open Source in a Cloudy World
Future of Open Source in a Cloudy World
 
Why kubernetes for Serverless (FaaS)
Why kubernetes for Serverless (FaaS)Why kubernetes for Serverless (FaaS)
Why kubernetes for Serverless (FaaS)
 
Containers, microservices and serverless for realists
Containers, microservices and serverless for realistsContainers, microservices and serverless for realists
Containers, microservices and serverless for realists
 
How to contribute to cloud native computing foundation (CNCF)
How to contribute to cloud native computing foundation (CNCF)How to contribute to cloud native computing foundation (CNCF)
How to contribute to cloud native computing foundation (CNCF)
 
Cloud Native Patterns with Bluemix Developer Console
Cloud Native Patterns with Bluemix Developer ConsoleCloud Native Patterns with Bluemix Developer Console
Cloud Native Patterns with Bluemix Developer Console
 
CloudOpen 2014 - Mixing Your Open Source Cloud Cocktail
CloudOpen 2014 - Mixing Your Open Source Cloud CocktailCloudOpen 2014 - Mixing Your Open Source Cloud Cocktail
CloudOpen 2014 - Mixing Your Open Source Cloud Cocktail
 
Containers, OCI, CNCF, Magnum, Kuryr, and You!
Containers, OCI, CNCF, Magnum, Kuryr, and You!Containers, OCI, CNCF, Magnum, Kuryr, and You!
Containers, OCI, CNCF, Magnum, Kuryr, and You!
 
The DIY Punk Rock DevOps Playbook
The DIY Punk Rock DevOps PlaybookThe DIY Punk Rock DevOps Playbook
The DIY Punk Rock DevOps Playbook
 
VMware@Night: Container & Virtualisierung
VMware@Night: Container & VirtualisierungVMware@Night: Container & Virtualisierung
VMware@Night: Container & Virtualisierung
 
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayer
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayerTaking the Next Hot Mobile Game Live with Docker and IBM SoftLayer
Taking the Next Hot Mobile Game Live with Docker and IBM SoftLayer
 
IBM Container Service Overview
IBM Container Service OverviewIBM Container Service Overview
IBM Container Service Overview
 
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...
DCSF 19 How Entergy is Mitigating Legacy Windows Operating System Vulnerabili...
 
Containers and microservices for realists
Containers and microservices for realistsContainers and microservices for realists
Containers and microservices for realists
 
The Internet-of-things: Architecting for the deluge of data
The Internet-of-things: Architecting for the deluge of dataThe Internet-of-things: Architecting for the deluge of data
The Internet-of-things: Architecting for the deluge of data
 
Alibaba Cloud Conference 2016 - Docker Open Source
Alibaba Cloud Conference   2016 - Docker Open Source Alibaba Cloud Conference   2016 - Docker Open Source
Alibaba Cloud Conference 2016 - Docker Open Source
 

Viewers also liked

Microservices Architecture (MSA) - Presentation made at The Open Group confer...
Microservices Architecture (MSA) - Presentation made at The Open Group confer...Microservices Architecture (MSA) - Presentation made at The Open Group confer...
Microservices Architecture (MSA) - Presentation made at The Open Group confer...Somasundram Balakrushnan
 
A Pattern Language for Microservices (@futurestack)
A Pattern Language for Microservices (@futurestack)A Pattern Language for Microservices (@futurestack)
A Pattern Language for Microservices (@futurestack)Chris Richardson
 
2015 03-11_todd-fritz_devnexus_2015
2015 03-11_todd-fritz_devnexus_20152015 03-11_todd-fritz_devnexus_2015
2015 03-11_todd-fritz_devnexus_2015Todd Fritz
 
Enterprise service bus(esb)
Enterprise service bus(esb)Enterprise service bus(esb)
Enterprise service bus(esb)prksh89
 
Python RESTful webservices with Python: Flask and Django solutions
Python RESTful webservices with Python: Flask and Django solutionsPython RESTful webservices with Python: Flask and Django solutions
Python RESTful webservices with Python: Flask and Django solutionsSolution4Future
 
Building Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Building Reactive Fast Data & the Data Lake with Akka, Kafka, SparkBuilding Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Building Reactive Fast Data & the Data Lake with Akka, Kafka, SparkTodd Fritz
 
Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Reactive Fast Data & the Data Lake with Akka, Kafka, SparkReactive Fast Data & the Data Lake with Akka, Kafka, Spark
Reactive Fast Data & the Data Lake with Akka, Kafka, SparkTodd Fritz
 
virtualization-vs-containerization-paas
virtualization-vs-containerization-paasvirtualization-vs-containerization-paas
virtualization-vs-containerization-paasrajdeep
 
Learn REST API with Python
Learn REST API with PythonLearn REST API with Python
Learn REST API with PythonLarry Cai
 

Viewers also liked (9)

Microservices Architecture (MSA) - Presentation made at The Open Group confer...
Microservices Architecture (MSA) - Presentation made at The Open Group confer...Microservices Architecture (MSA) - Presentation made at The Open Group confer...
Microservices Architecture (MSA) - Presentation made at The Open Group confer...
 
A Pattern Language for Microservices (@futurestack)
A Pattern Language for Microservices (@futurestack)A Pattern Language for Microservices (@futurestack)
A Pattern Language for Microservices (@futurestack)
 
2015 03-11_todd-fritz_devnexus_2015
2015 03-11_todd-fritz_devnexus_20152015 03-11_todd-fritz_devnexus_2015
2015 03-11_todd-fritz_devnexus_2015
 
Enterprise service bus(esb)
Enterprise service bus(esb)Enterprise service bus(esb)
Enterprise service bus(esb)
 
Python RESTful webservices with Python: Flask and Django solutions
Python RESTful webservices with Python: Flask and Django solutionsPython RESTful webservices with Python: Flask and Django solutions
Python RESTful webservices with Python: Flask and Django solutions
 
Building Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Building Reactive Fast Data & the Data Lake with Akka, Kafka, SparkBuilding Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Building Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
 
Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
Reactive Fast Data & the Data Lake with Akka, Kafka, SparkReactive Fast Data & the Data Lake with Akka, Kafka, Spark
Reactive Fast Data & the Data Lake with Akka, Kafka, Spark
 
virtualization-vs-containerization-paas
virtualization-vs-containerization-paasvirtualization-vs-containerization-paas
virtualization-vs-containerization-paas
 
Learn REST API with Python
Learn REST API with PythonLearn REST API with Python
Learn REST API with Python
 

Similar to server to cloud: converting a legacy platform to an open source paas

Technology insights: Decision Science Platform
Technology insights: Decision Science PlatformTechnology insights: Decision Science Platform
Technology insights: Decision Science PlatformDecision Science Community
 
Working with Developers
Working with DevelopersWorking with Developers
Working with DevelopersPaul Walk
 
Architectural Considerations for Startups
Architectural Considerations for StartupsArchitectural Considerations for Startups
Architectural Considerations for StartupsNiall Roche
 
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READY
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READYPaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READY
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READYRene Claudio
 
Startups: Streit, Scaleup - introduction and product demo
Startups: Streit, Scaleup - introduction and product demoStartups: Streit, Scaleup - introduction and product demo
Startups: Streit, Scaleup - introduction and product demoCloudOps Summit
 
3 Crucial Application Modernization Strategies for Enterprises.pptx
3 Crucial Application Modernization Strategies for Enterprises.pptx3 Crucial Application Modernization Strategies for Enterprises.pptx
3 Crucial Application Modernization Strategies for Enterprises.pptxArpitGautam20
 
ThatConference 2016 - Highly Available Node.js
ThatConference 2016 - Highly Available Node.jsThatConference 2016 - Highly Available Node.js
ThatConference 2016 - Highly Available Node.jsBrad Williams
 
A DevOps adoption playbook- achieving business value at scale
A DevOps adoption playbook- achieving business value at scaleA DevOps adoption playbook- achieving business value at scale
A DevOps adoption playbook- achieving business value at scaleSanjeev Sharma
 
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...Amazon Web Services
 
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterprise
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterpriseApache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterprise
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterpriseAdrian Trenaman
 
No Code is the Future of Software –How can they add value in 2022.pptx
No Code is the Future of Software –How can they add value in 2022.pptxNo Code is the Future of Software –How can they add value in 2022.pptx
No Code is the Future of Software –How can they add value in 2022.pptxArpitGautam20
 
AWS Initiate Berlin - Cloud Transformation und der Faktor Mensch
AWS Initiate Berlin - Cloud Transformation und der Faktor MenschAWS Initiate Berlin - Cloud Transformation und der Faktor Mensch
AWS Initiate Berlin - Cloud Transformation und der Faktor MenschAmazon Web Services
 
Webinar: How and Why to Containerize Your Legacy Applications
Webinar: How and Why to Containerize Your Legacy ApplicationsWebinar: How and Why to Containerize Your Legacy Applications
Webinar: How and Why to Containerize Your Legacy ApplicationsStorage Switzerland
 
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014IBM Systems UKI
 
Ema kognitio comparative analysis webinar slides
Ema kognitio comparative analysis webinar slidesEma kognitio comparative analysis webinar slides
Ema kognitio comparative analysis webinar slidesKognitio
 
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16AppDynamics
 
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!Ezhilarasan Natarajan
 
Understanding The Cloud For Enterprise Businesses.
Understanding The Cloud For Enterprise Businesses. Understanding The Cloud For Enterprise Businesses.
Understanding The Cloud For Enterprise Businesses. Triaxil
 
How OpenLegacy Tackles Enterprise Integration Challenges using API Technology
How OpenLegacy Tackles Enterprise Integration Challenges using API TechnologyHow OpenLegacy Tackles Enterprise Integration Challenges using API Technology
How OpenLegacy Tackles Enterprise Integration Challenges using API TechnologyHans B. Otharsson
 
7 habits of highly effective private cloud architects
7 habits of highly effective private cloud architects7 habits of highly effective private cloud architects
7 habits of highly effective private cloud architectsHARMAN Services
 

Similar to server to cloud: converting a legacy platform to an open source paas (20)

Technology insights: Decision Science Platform
Technology insights: Decision Science PlatformTechnology insights: Decision Science Platform
Technology insights: Decision Science Platform
 
Working with Developers
Working with DevelopersWorking with Developers
Working with Developers
 
Architectural Considerations for Startups
Architectural Considerations for StartupsArchitectural Considerations for Startups
Architectural Considerations for Startups
 
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READY
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READYPaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READY
PaaS POV_To PaaS or Not There really is no question_150601_FINAL_PRINT_READY
 
Startups: Streit, Scaleup - introduction and product demo
Startups: Streit, Scaleup - introduction and product demoStartups: Streit, Scaleup - introduction and product demo
Startups: Streit, Scaleup - introduction and product demo
 
3 Crucial Application Modernization Strategies for Enterprises.pptx
3 Crucial Application Modernization Strategies for Enterprises.pptx3 Crucial Application Modernization Strategies for Enterprises.pptx
3 Crucial Application Modernization Strategies for Enterprises.pptx
 
ThatConference 2016 - Highly Available Node.js
ThatConference 2016 - Highly Available Node.jsThatConference 2016 - Highly Available Node.js
ThatConference 2016 - Highly Available Node.js
 
A DevOps adoption playbook- achieving business value at scale
A DevOps adoption playbook- achieving business value at scaleA DevOps adoption playbook- achieving business value at scale
A DevOps adoption playbook- achieving business value at scale
 
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...
Application Darwinism: Why Most Enterprise Apps Will Move to the Cloud (SVC20...
 
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterprise
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterpriseApache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterprise
Apache coneu 2009-adrian-trenaman-adopting-open-source-in-the-enterprise
 
No Code is the Future of Software –How can they add value in 2022.pptx
No Code is the Future of Software –How can they add value in 2022.pptxNo Code is the Future of Software –How can they add value in 2022.pptx
No Code is the Future of Software –How can they add value in 2022.pptx
 
AWS Initiate Berlin - Cloud Transformation und der Faktor Mensch
AWS Initiate Berlin - Cloud Transformation und der Faktor MenschAWS Initiate Berlin - Cloud Transformation und der Faktor Mensch
AWS Initiate Berlin - Cloud Transformation und der Faktor Mensch
 
Webinar: How and Why to Containerize Your Legacy Applications
Webinar: How and Why to Containerize Your Legacy ApplicationsWebinar: How and Why to Containerize Your Legacy Applications
Webinar: How and Why to Containerize Your Legacy Applications
 
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014
PureApp Hybrid Cloud - Mark Willemse ING Presentation 11th September 2014
 
Ema kognitio comparative analysis webinar slides
Ema kognitio comparative analysis webinar slidesEma kognitio comparative analysis webinar slides
Ema kognitio comparative analysis webinar slides
 
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16
Microservices and the Modern IT Stack: Trends of Tomorrow - AppSphere16
 
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!
Understanding The Cloud For Enterprise Businesses, an eBook from Triaxil!
 
Understanding The Cloud For Enterprise Businesses.
Understanding The Cloud For Enterprise Businesses. Understanding The Cloud For Enterprise Businesses.
Understanding The Cloud For Enterprise Businesses.
 
How OpenLegacy Tackles Enterprise Integration Challenges using API Technology
How OpenLegacy Tackles Enterprise Integration Challenges using API TechnologyHow OpenLegacy Tackles Enterprise Integration Challenges using API Technology
How OpenLegacy Tackles Enterprise Integration Challenges using API Technology
 
7 habits of highly effective private cloud architects
7 habits of highly effective private cloud architects7 habits of highly effective private cloud architects
7 habits of highly effective private cloud architects
 

Recently uploaded

Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Steffen Staab
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsAndolasoft Inc
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...MyIntelliSource, Inc.
 
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected WorkerHow To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected WorkerThousandEyes
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsJhone kinadey
 
Hand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxHand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxbodapatigopi8531
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comFatema Valibhai
 
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...harshavardhanraghave
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfkalichargn70th171
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxComplianceQuest1
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...MyIntelliSource, Inc.
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfkalichargn70th171
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...panagenda
 
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceanilsa9823
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...ICS
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...kellynguyen01
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...Health
 
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AISyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AIABDERRAOUF MEHENNI
 

Recently uploaded (20)

Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
 
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected WorkerHow To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial Goals
 
Hand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxHand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptx
 
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.com
 
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS LiveVip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
 
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AISyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
SyndBuddy AI 2k Review 2024: Revolutionizing Content Syndication with AI
 

server to cloud: converting a legacy platform to an open source paas

  • 1. inBloom, Inc. server to cloud converting a legacy platform to an open source paas todd fritz April 3. 2014
  • 2. inBloom, Inc. agenda • whoami • goals • change • genesis • decompose • refactor • architecture • ajug • questions • references • appendix APRIL 2014 1
  • 3. inBloom, Inc. whoami bio: http://www.linkedin/com/in/tfritz • architect at inbloom  opinions contained within this presentation may not represent my employer, but I think they should • evangelist of layered, distributed, message-oriented-middleware • current focus is middleware through caching, nosql data store • exposed to different companies, projects, people and technologies • novice bass player • recent father of a five month old • scuba diver. next adventure:  https://www.bikiniatoll.com/divetour.html APRIL 2014 2 No sleep for you!
  • 4. inBloom, Inc. thanks credit for those who helped (or listened) • altisource  todd nist • inbloom  verlin henderson  paul lawler  vincent mayers  ben morgan  bill siggelkow • red hat  ray ploski APRIL 2014 3
  • 5. inBloom, Inc. inBloom, Inc. email: oss@inbloom.org twitter: @inBloomDev dev.inbloom.org APRIL 2014 4
  • 7. inBloom, Inc. objectives for next 45 minutes • to delay you from happy hour and inspire curiosity • discuss the benefits of change • shine a light on a path forward • cover the if, why and how to modernize • define basic cloud migration criteria • explain techniques to decompose legacy apps • virtualization and containerization • evangelize containers as an architecture enabler • discuss migration strategy and architectures • this talk does not (yet) include code examples (coming soon to atlanta java users group) APRIL 2014 6
  • 9. inBloom, Inc. what? change? why? APRIL 2014 8 an unknown manager in the wild, ready to spray a can of dilbert. http://d1r5i20o8cadcu.cloudfront.net/designs/images/76856/original/programmer_creattica_full.jpg
  • 10. inBloom, Inc. may we live in interesting times innovation is impossible without change • ―Software is eating the world.‖ – Marc Andreesson, 2011, Wall Street Journal  ―We are in the middle of a dramatic and broad technological and economic shift in which software companies are poised to take over large swathes of the economy. More and more major businesses and industries are being run on software and delivered as online services— from movies to agriculture to national defense.‖ • ―Every company is a software company -- or at least aspiring to be one. That reality will shake up industries, lead to huge successes and failures and potentially make or break brands.‖ – Larry Dignan • ―…this software revolution in every company will be similar to how enterprise resource planning changed the game for businesses and their processes.‖ – Forrester analyst John McCarthy APRIL 2014 9 http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats-the-key-to-business-model-success-.html
  • 11. inBloom, Inc. innovation economics • a growing economic doctrine that adapts conventional economics theory so that knowledge, technology, entrepreneurship, and innovation are at the center of the model  rather than independent forces that are largely unaffected by policy  good fit for companies that manage software • two fundamental tenets: 1. economic policy should drive productivity through innovation 2. market reliance on resources and price signals alone may not be as effective to create both productivity and economic growth • differs from conventional economic doctrines • companies benefit from innovation in obvious ways APRIL 2014 10
  • 12. inBloom, Inc. a path forward how does a company that has not traditionally been in the software space become a successful software company? also applies to a software company that is reinventing itself, and startups. 1. protect intellectual property 2. re-think software monetization models  based on how customers want to pay  subscription models 3. automate the entire software, device and entitlement lifecycle  software installation, provisioning, activation  subscription management, software updates and upgrades  software entitlements (features) 4. purpose-built software licensing and entitlement management APRIL 2014 11 http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats-the-key-to-business-model-success-.html
  • 13. inBloom, Inc. status quo gets left behind • today will not be tomorrow • cloud provides competitive advantage for some use cases  amazon is market leader  ongoing competition between cloud providers; amazon and google  encourages use standards and adoption of new tech and patterns • technology advances disrupt computing infrastructure and software to expose opportunity • quantum computing, e.g. d-wave qubit  ok, some controversy, but it is fast  significant advance in compute power  will disrupt software design and how we scale, e.g. compute grids  it is real, maturing, and is not going away  outpaces moore’s law as it scales  http://www.gizmag.com/d-wave-quantum-computer-supercomputer-ranking/27476/ APRIL 2014 12
  • 14. inBloom, Inc. cloud adoption – 36% increase – benefits APRIL 2014 13 http://www.secure-24.com/the-advantages-of-infrastructure-outsourcing/
  • 15. inBloom, Inc. good candidates for cloud 1. strong business sponsorship at tip of spear 2. well understood with few dependencies 3. uses common standards and implementations 4. can be decomposed or decoupled 5. already modularized or service oriented 6. already virtualized 7. favorable cost-benefit analysis 8. security model translates to cloud 9. opportunities to improve by modernization APRIL 2014 14 http://www.websitepulse.com/blog/the-great-cloud-migration-are-your-apps-ready
  • 16. inBloom, Inc. unfavorable candidates – who has one? 1. lacks strong business sponsorship 2. security equation difficult to understand 3. complex architecture and external dependencies 4. technology or deployment lock in 5. latency sensitive (real time apps) 6. not standards based or uses home-grown libraries 7. etl heavy (not parallelized) or long running jobs 8. government regulations, contractual requirements, or certifications (pci) 9. unfavorable economics (cost-benefit/risk analysis) 10. transaction lifecycles not well understood APRIL 2014 15 http://www.websitepulse.com/blog/the-great-cloud-migration-are-your-apps-ready
  • 17. inBloom, Inc. the go forward decision APRIL 2014 16
  • 19. inBloom, Inc. hello world! i am a legacy system APRIL 2014 18
  • 20. inBloom, Inc. what to do with it? break it apart; analyze employ an iterative methodology  leverage existing knowledge and literature  some analysis before  decompose and modularize (scale cube)  separation of concerns  proof of concepts are your friend deployment environments  private servers  cloud (private, public)  hybrid platform architectures  legacy  paas  xpaas APRIL 2014 19
  • 21. inBloom, Inc. terms • paas  “Platform as a service (PaaS)…provides a computing platform and a solution stack as a service. Along with software as a service (SaaS) and infrastructure as a service (IaaS), it is a service model of cloud computing… the consumer creates the software using tools…from the provider. The consumer also controls software deployment and configuration... The provider provides the networks, servers, storage, and other services that are required to host the consumer's application” -wikipedia • xpaas  standardization of enterprise paas  create platforms from a catalogue of paas/saas/iaas APRIL 2014 20
  • 22. inBloom, Inc. paas by segment gartner’s 2012 paas market share chart (from red hat’s xpaas whitepaper). APRIL 2014 21
  • 23. inBloom, Inc. xpaas topology APRIL 2014 22 https://img.en25.com/Web/RedHat/JB_xPaaS_Tech_Overview_11454037_v3_0913cd_web.pdf • enables specialization, layering, separated concerns, decoupling
  • 25. inBloom, Inc. i am the fragments of a legacy system APRIL 2014 24 hear me roar…
  • 26. inBloom, Inc. what have I gotten myself into? APRIL 2014 25 http://www.secure-24.com/the-advantages-of-infrastructure-outsourcing/ “legacy spaghetti” the code sucks… i can’t even build it…
  • 27. inBloom, Inc. getting started • involve devops from the beginning • if your company does not have devops then call pressureManager() • make decisions from quantitative assessments • agile systems analysis and integration modeling • agile modeling best practices • use the afk scale cube  http://akfpartners.com/techblog/2008/05/08/splitting-applications-or- services-for-scale/ • read ―The Art of Scalability‖ by abbott and fisher  http://theartofscalability.com/ • perform functional decomposition and service identification • the cloud is not ―all or nothing‖  phased migrations can realize immediate value  new technologies can coexist with legacy • iterative design ahead • use containers to enable decoupling, architectural flexibility, confine legacy APRIL 2014 26
  • 28. inBloom, Inc. legacy analysis and design • decompose into layers; functions and separate concerns • design decoupled components and services • isolate technologies within components (insulate lock-in) • conceptualize legacy components and services as ―legos‖ • future state runs alongside current state to provide value • take heed of transaction lifecycle, batch jobs, data retention and use cases • be mindful of customer impact, cost and schedule constraints • consider security at each layer and service APRIL 2014 27
  • 29. inBloom, Inc. success – value add criteria APRIL 2014 28 “For every complex question there is a simple and wrong solution.” - Albert Einstein avoid “Khan’s paradigm”: a top-down plan led by an overlord of super-humans will fail. my Java kung fu can crush any project. tactical • time, cost, quality strategic • sustainability, relevance, effect
  • 30. inBloom, Inc. agile modeling best practices APRIL 2014 29 http://www.agilemodeling.com/essays/bestPractices.htm
  • 32. inBloom, Inc. assembling the new system APRIL 2014 31
  • 33. inBloom, Inc. we can rebuild it • cynical optics  rather than one bowl of spaghetti; several small, independent plates  investment in analysis, design ahead, separating concerns has tangible benefits  use containers! APRIL 2014 32 before after
  • 34. inBloom, Inc. putting it together • favor continuous deployment • prefer reusable, modularized components • decoupled services; soa done right (microservice) • message oriented and event driven • parallelize development across business function • select the right tool for each component; polyglot • include automated unit and integration tests • leverage containerization instead of virtualization when possible (see next slide) APRIL 2014 33
  • 35. inBloom, Inc. why containers? APRIL 2014 34 http://www.slideshare.net/dotCloud/docker-intro-november
  • 36. inBloom, Inc. revisting paas requirements • ―Virtualization vs. Containers to support PaaS‖  by Dua, Raja, Kakadia  http://www.slideshare.net/rajdeep/conference-presentationv3  Basis of next three slides • paas focuses on developer productivity and abstracts out underlying infrastructure • 3 key paas requirements for the infrastructure 1. network, compute and storage programmatically managed and provisioned 2. h/a infrastructure (e.g. nodes) efficiently utilized 3. ability to bind applications/services to external network (dns, routers) APRIL 2014 35
  • 37. inBloom, Inc. paas requirements (cont.) 1. network, compute and storage programmatically managed and provisioned 2. h/a infrastructure (e.g. nodes) efficiently utilized 3. ability to bind applications/services to external network (dns, routers)  vms good for #1 & #2  apps can reside within: • vms • containers • vms with containers  containers better for #3 as resources better utilized and light weight APRIL 2014 36
  • 38. inBloom, Inc. paas requirements (cont.) • containers have weaknesses (for now)  standardization  strong security  os independence  robust monitoring • ―Containers have inherent advantage over VMs for PaaS use case‖. - Dua, Raja, Kakadia APRIL 2014 37
  • 39. inBloom, Inc. container platform contenders • warden (cloud foundry)  https://github.com/cloudfoundry/warden • docker  https://www.docker.io/ • google lmctfy (let me contain that for you)  https://github.com/google/lmctfy  december, 2013 • openvz APRIL 2014 38
  • 40. inBloom, Inc.APRIL 2014 39 container of the day
  • 41. inBloom, Inc. about docker docker is a micro container framework for paas • https://www.docker.io/learn_more/ • open-source • easier scalability • lightweight, portable, insulated containers • reusable from dev (―local cloud‖) through production • can run at scale on vms, bare metal, cloud; virtually anywhere • encapsulate any payload (application) • run consistently on and between virtually any server APRIL 2014 40
  • 42. inBloom, Inc. more about docker APRIL 2014 41 http://www.slideshare.net/dotCloud/docker-intro-november
  • 43. inBloom, Inc. brief overview about how it works • docker builds on lxc which offers system-level virtualization and has existed since linux 2.6.32 (December, 2009) – but use 3.8+ • docker has three parts  docker daemon runs as root to manage containers  docker containers spawn from images, which are tiny and can be versioned  docker repository allows images to be exchanged and versioned like code (public or private) • each container has its own ip address • link exposed ports and variables across containers through configuration using abassador containers to avoid hard coding (svendowideit):  consumer  redis-ambassador  redis • port and pipework to expose containers outside host • can share volumes, multi home, integrate containers into host network, and much more (ajug) • continuous integration can generate versioned docker images, web hooks, repo notifications • supervisor management tool to manage processes within container (http://supervisord.org/introduction.html) APRIL 2014 42
  • 44. inBloom, Inc. even more about docker • common use cases:  automate application packaging and deployment  lightweight paas environments  automate testing, continuous integration, and deployment  deploy and scale web apps, databases, backend services • growing adoption since dec 2013 • red hat fast-tracks docker apps for enterprise linux  http://www.infoworld.com/t/application-virtualization/red- hat-fast-tracks-docker-apps-enterprise-linux-238122 • production ready deployment planned for december, 2014.  Support services planned for early 2015 APRIL 2014 43
  • 45. inBloom, Inc. containers available for reuse APRIL 2014 44 http://www.slideshare.net/dotCloud/docker-intro-november a docker container image may already exist
  • 46. inBloom, Inc. docker image registry – versioning! APRIL 2014 45 http://www.slideshare.net/dotCloud/docker-intro-november artifactory for virtualization images?
  • 47. inBloom, Inc. New in Docker 0.9 • execution driver api  customize execution environment around container; enables use of other isolation tools • built in execution container - libcontainer  alongside lxc, boosts stability, insulates docker from different versions of lxc APRIL 2014 46
  • 49. inBloom, Inc. containers enable architecture • containers enable architecture and design • design, build, or migrate, each layer or module into a container • containers encapsulate technology, isolate lock-in, and are easy to scale • enables use of best tool; go polyglot • easy to upgrade what’s in a container  replace node.js with vert.x  technology portability • understand workload and transaction use cases (data stores, social) • service oriented (done right, not soap) • learn message oriented middleware (mom)  enterprise integration patterns (eip)  apache camel  queues (amqp) • prefer data streams to batch jobs • leverage power of compute grids and distributed caching • pay the piper and dedicate effort to data/domain architecture APRIL 2014 48
  • 51. inBloom, Inc. coming soon • v2 of this presentation  with code examples  in-depth architecture ideas  development concepts • to be presented to atlanta java users group (ajug) APRIL 2014 50
  • 54. inBloom, Inc. reference material • https://www.docker.io/ • http://deis.io/overview/ • http://www.ambysoft.com/essays/brokenTriangle.html • http://martinfowler.com/articles/microservices.html#MicroservicesAndSoa • http://www.susannemadsen.co.uk/1/post/2013/12/the-iron-triangle-and-the-tripleconstraintsare-outdated.html • http://www.slideshare.net/pet-computacao/software-evolution-from-legacy-systems-service-oriented-architecture- to-cloud-computing • http://www.cloudcomputingpatterns.org/Message-oriented_Middleware • https://img.en25.com/Web/RedHat/JB_xPaaS_Tech_Overview_11454037_v3_0913cd_web.pdf • http://www.infoq.com/articles/sustainable-architectural-design-decisions • http://www.sciencedirect.com/science/article/pii/S0268401201000135 • http://martinfowler.com/bliki/TolerantReader.html • http://www.cakesolutions.net/teamblogs/2014/01/28/deploying-scala-akka-based-applications-to-amazon-cloud/ • http://highscalability.com/blog/2013/5/8/typesafe-interview-scala-akka-is-an-iaas-for-your-process-ar.html • http://www.informationweek.com/software/moving-legacy-apps-to-the-cloud/d/d-id/1108964 • http://www.forbes.com/sites/louiscolumbus/2012/11/08/cloud-computing-and-enterprise-software-forecast-update- 2012/ • http://blogs-images.forbes.com/louiscolumbus/files/2013/01/Bain-Go-To-Market-System.jpg • http://www.infoq.com/articles/SaaSificationOfLegacyApps • http://www.agilemodeling.com/essays/bestPractices.htm • http://osintegrators.com/node/145 • http://appsembler.com/blog/paas-bakeoff-comparing-stackato-openshift-dotcloud-and-heroku-for-django-hosting- and-deployment/ APRIL 2014 53
  • 55. inBloom, Inc. More Reference Material • Redmonk on DB technology: http://www.youtube.com/watch?v=HClEcT8n5Lc&app=desktop • http://gigaom.com/2014/03/25/heres-the-google-vs-amazon-pricing-break-down/ • Decomposing applications for scalability and deployability  http://vimeo.com/49392435 • http://venturebeat.com/2008/10/13/the-cloud-isnt-for-everyone/ • http://blogs.flexerasoftware.com/ecm/2014/01/if-every-company-is-a-software-company-whats- the-key-to-business-model-success-.html • https://blog.codecentric.de/en/2014/01/lightweight-virtual-machines-made-simple-docker-run-100- virtual-maschines/ • https://blog.codecentric.de/en/2014/01/docker-networking-made-simple-3-ways-connect-lxc- containers/ • http://blog.docker.io/2014/03/docker-0-9-introducing-execution-drivers-and-libcontainer/ APRIL 2014 54
  • 56. inBloom, Inc. appendix (slides that did not fit within time constraint) APRIL 2014 55
  • 57. inBloom, Inc. paas -> xpaas an xpaas is composed of multiple, specialized paas systems ―…xPaaS services augment core container functionality with integration, business process management (BPM) and mobile capabilities.‖  integration paas (ipaas) -- simplifies connections, messages, route definitions, and data transformations  bpm paas (bpmpaas) -- process modeling, process engine, simplify definition and evolution of business processes  mobile paas (mpaas) -- push notifications, data synchronizations and back-end integration  … APRIL 2014 56
  • 58. inBloom, Inc. agile legacy systems analysis and integration modeling APRIL 2014 57 Methodology: http://www.agilemodeling.com/essays/agileLegacyIntegrationModeling.htm
  • 59. inBloom, Inc. the scale cube APRIL 2014 58
  • 60. inBloom, Inc. Analysis Considerations • Refine understanding of current and future state solutions  Client-Server (beware of stateful thick clients)  N-Tier  SaaS ready components? • Features, use cases, request lifecycle • Messaging models, usage patterns, volume and velocity – capacity planning • Messaging? Network configuration? • All aspects of security • Identify components and concerns, layers • Impact of latency • Caching, and Master Data Management (MDM) • Identify problems and do not ignore technical debt… • Product Management != Project Management (or scrum master) The unknown may lead to failure, delays or increased cost. APRIL 2014 59
  • 61. inBloom, Inc. Security First FEBRUARY 2014 60 • Foundational • Assess all concerns and services • Network, OS, Disk (data at rest) • Applications • Encryption • Data • Protecting Personally Identifiable Information (PII) • Securing logged information • Securing in-memory objects and caches • User Authentication and Authorization • Manage users, groups, roles and permissions, SSO • Separate abstractions for Authentication from Authorization (CAS, etc) • OAUTH, SAML2 • Learn about SENDS • Science-Enhanced Networked Domains and Secure Social Spaces • Security needs to be more than a technology solution • http://www.theatlantic.com/technology/archive/2011/03/cyber-security-cant-ignore-human- behavior/72826/ • Be aware of industry bias toward technical solutions with security. • Can’t control stupid human behaviors such as taping a password to keyboard. • APRIL
  • 62. inBloom, Inc. What? Perhaps you are wondering… • Why Docker? The next several slides provide background • (Borrowed from Docker’s site.) Keep in mind: • Docker containers encapsulate concerns • Avoids Holy Wars about specific architectures to implement • Great for the dozens of Spring projects..  Run each within its own Container APRIL 2014 61
  • 63. inBloom, Inc. how a docker works • uses linux kernel for containment (jailing)  chroot: changes root directory of process w/ child  cgroups: control groups • groups processes (to unit of thread) • pseudo filesystem • numerous subsystems functions implemented – CPU sets, etc • linux containers: lxc  file system isolation  network and process isolation  resource allocation APRIL 2014 62
  • 64. inBloom, Inc. Converting the Legacy App into Docker • Containers enable extreme choice – use what you want. • Container model facilitates separates concerns  Applications (various technologies)  Back End systems including ―Big Data‖  Messaging  Caching (e.g. Hazelcast!)  Microservices. Use Data as glue. APRIL 2014 63
  • 65. inBloom, Inc.APRIL 2014 64 http://www.slideshare.net/dotCloud/docker-intro-november
  • 66. inBloom, Inc. Docker Ecosystem APRIL 2014 65 http://www.slideshare.net/dotCloud/docker-intro-november
  • 67. inBloom, Inc. Why Developers should Care about Docker APRIL 2014 66 http://www.slideshare.net/dotCloud/docker-intro-november
  • 68. inBloom, Inc. DevOps & Docker APRIL 2014 67 http://www.slideshare.net/dotCloud/docker-intro-november
  • 69. inBloom, Inc. More about Docker • Deis is a framework that caps Docker and Heroku  http://deis.io/deis-0-5-1-docker-containers-all-the-way-down/  ―Deis…is an open source PaaS that makes it easy to deploy and scale Docker containers and Chef nodes used to host applications, databases, middleware and other services. Deis leverages Chef, Docker, Heroku Buildpacks to provide a private PaaS that is lightweight and flexible.‖  Supported Languages • Java, Scala, PHP, Ruby, Python, Node.js, Clojure, Play, Perl, Dart, Go. • Deis can deploy anything using Heroku Buildpacks or Dockerfiles.  Supported Providers • Any system including every public cloud, private cloud or bare metal. • Automatic provisioning for EC2, Rackspace, Digital Ocean • Integration testing with Maven and Docker  http://giallone.blogspot.co.uk/2014/03/integration-testing-with-maven-and.html • Industry timeline from 1995 to Docker  http://5pi.de/docker-intro/#/step-1 • Decker APRIL 2014 68
  • 70. inBloom, Inc. Message Oriented Middleware APRIL 2014 69