cloud computing bootcamp on the google app engine for iasa v1.2.4

168
a journey to the darker side of Cloud Computing by Matthew McCullough

Upload: iasa

Post on 16-Jan-2015

746 views

Category:

Technology


1 download

DESCRIPTION

October presentation on Cloud Computing at IASA Denver by Matthew McCullough

TRANSCRIPT

Page 1: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

a journey to the darker side of

Cloud Computing

by Matthew McCullough

Page 2: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Matthew McCullough

Page 3: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 4: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 5: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

10min

?min

15min

?min

20min

?min

Page 6: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

➊A brief History

Page 7: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

1960

Page 8: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 9: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

“computation may someday be organized as a public utility”

-John McCarthy

Page 10: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Shared Time

Page 11: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

circa 2006

Page 12: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

“It starts with the premise that the data services and architecture should be on servers. We call it cloud computing – they should be in a “cloud” somewhere.”

-Eric Schmidt

Page 13: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

SaaS

Page 14: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Virtualized Serverswith an API

Page 15: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

➋What is the Cloud?

Page 16: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

A style of computing in which dynamically scalable and often virtualized resources are provided as a service over the Internet.

-NIST (draft)

Page 17: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

[Developers] need not have knowledge of, expertise in, or control over the technology infrastructure in the cloud that supports them.

-Aggregate of Tim O’Reilly, Luis M. Vaquero

Page 18: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Scalable

Page 19: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Dynamic

Page 20: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Pay-per-use

Page 21: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Minimal state

Page 22: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Affinity-less

Page 23: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Scale up

Page 24: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Scale down

Page 25: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Grid?

Page 26: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

➌Why the Cloud?

Page 27: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Cost of startup

Page 28: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Experimentation

Page 29: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Transition to Production

Page 30: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No licensing fees

Page 31: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Instant availability

Page 32: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

What’s the most expensive item on a

startup’s balance sheet?

Page 33: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

You!

Page 34: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Time savings

Page 35: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Hardware setup time

Page 36: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

OS setup time

Page 37: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Database setup time

Page 38: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Web container setup time

Page 39: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Server setup

Page 40: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Server destruction

Page 41: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

❹Cloud Players

Page 42: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

From most open to most constrained

Page 43: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Rackspace Cloud SitesRackspace Cloud Servers

Page 44: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Amazon EC2

Page 45: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google App Engine

Page 46: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Levels of Abstraction

Page 47: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Operating System Images

Page 48: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Predetermined

Page 49: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

or abstracted away

Page 50: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Programming languages?

Page 51: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Anything?

Page 52: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

PHP?

Page 53: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Python?

Page 54: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Java?

Page 55: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

File Systems

Page 56: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Rackspace CloudTraditional File System

Page 57: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Amazon EC2Elastic Block Storage

Page 58: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Mor.phTraditional File System

Page 59: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google App EngineNone

Page 60: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Datastores

Page 61: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Amazon EC2Simple DB

Page 62: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google App EngineBig Table

Page 63: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Operating Systems

Page 64: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Debian, Fedora, Ubuntuon Rackspace Cloud

Page 65: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Windows Serveron Amazon EC2

Page 66: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

1000 variants of Linuxon Amazon EC2

Page 67: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

CentOS Linuxon Mor.ph

Page 68: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Custom Linuxon Google App Engine

Page 69: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Pricing

Page 70: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Rackspace Cloud

Page 71: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

1.5¢ per hour

Page 72: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 73: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 74: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Amazon EC2

Page 75: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 76: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google App Engine

Page 77: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

We’ll give it away free and make up for it in

volume!

Page 78: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 79: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 80: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 81: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

❺Google App Engine

Page 82: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

April 8th, 2008

Page 83: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 84: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google AppEngine

Page 85: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Python

Page 86: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 87: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

April 7th, 2009

Page 88: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 89: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Java!

Page 90: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 91: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

But more like

Page 92: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Banned

Java⅘

Page 93: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Getting Started with

GAE

Page 94: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Free to start

Page 95: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Cell Phone #

Page 96: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Regular Google Account

Page 97: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

10,000: first wave

Page 98: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

95 minutes

Page 99: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

25,000: second wave

Page 100: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Everyone: third wave

Page 101: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Technology Stack

Page 102: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

SDK

Page 103: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 104: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Shell scripts to manage apps

Page 105: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Source code included

Page 106: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

SDK-version-locked by the SDK JARs you

include

Page 107: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Subset of JDK 1.6

Page 108: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Custom Class Loaders

Page 109: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Sandbox

Page 110: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Whitelist of Classes

Page 111: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Caution!

Page 112: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Might work on desktop,but not on GAE

Page 113: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Application ID

Page 114: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Globally Unique

Page 115: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

required for deployment

Page 116: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

___.appspot.com

Page 117: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Servlet API

Page 118: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Jetty

Page 119: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

JSPs

Page 120: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Java Mail API

Page 121: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Google Web Toolkit

Page 122: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Authentication(2 options)

Page 123: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Integration withGoogle Accounts

Page 124: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 125: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Admin & User Level Permissions

Page 126: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Roll your own(hint: use SpringSecurity)

Page 127: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Memcache(as an alternative to persistent disk storage)

Page 128: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Low level API

Page 129: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

JSR-107 / JCache(javax.cache)

Page 130: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

BigTable

Page 131: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Relational Database?

Page 132: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Relational Database

Page 133: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Can import from existing DB

Page 134: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

JDO

Page 135: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

JPA

Page 136: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Low level BigTable API

Page 137: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Limited GORM-JPA

Page 138: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

DataNucleus

Page 139: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 140: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Logging

Page 141: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

java.util.logging

Page 142: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

System.out == infoSystem.err == warning

Page 143: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Log4j

Page 144: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 145: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

❻Dark Clouds

Page 146: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

a few GAE NOs

Page 147: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No Hibernate

Page 148: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No file writing

Page 149: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No threads

Page 150: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No server affinity

Page 151: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Even for sequential requests

Page 152: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No sockets

Page 153: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

But... you can use URLFetchfor HTTP/HTTPS resources

Page 154: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No JNI

Page 155: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

No more than 30s

Page 156: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4
Page 157: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

common Concerns

Page 158: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Large Setups more economical to self-host

Page 159: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Out of your hands

Page 160: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Uptime?

Page 161: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Do you trust the vendor?

Page 162: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Databases without foreign keys is a new

frontier

Page 163: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

“The interesting thing about cloud computing is that we’ve redefined cloud computing to include everything that we already do... Maybe I’m an idiot, but I have no idea what anyone is talking about... It’s complete gibberish. It’s insane. When is this idiocy going to stop?

-Larry Ellison

Page 164: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

a journey to the darker side of

Cloud Computing

Page 165: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Code Examples http://github.com/matthewmccullough

Twitter

@matthewmccull

Email

[email protected]

Blog

http://www.ambientideas.com/blog sidebar has my social networking profile links

Page 166: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Resources

• http://mor.ph

• http://appengine.google.com

• http://www.rackspacecloud.com/cloud_hosting_products/servers(formerly http://mosso.com)

• http://aws.amazon.com/ec2/

Page 167: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Resources

• http://www.browsermob.com

• http://highscalability.com/

• http://highscalability.com/useful-cloud-computing-blogs

• http://www.youtube.com/watch?v=ri796Hx8las&feature=channel

Page 168: Cloud Computing Bootcamp On The Google App Engine For Iasa V1.2.4

Photo Credits

• www.ambientideasphotography.com [clouds]

• http://en.wikipedia.org/wiki/John_McCarthy_(computer_scientist)

• http://www.nga.org/Images/AM07SAT09HIRES.JPG

• All others purchased through iStockPhoto.com