213
Cloud Computing boot camp on the Google App Engine by Matthew McCullough of Ambient Ideas, LLC

Cloud Computing Bootcamp On The Google App Engine v1.2.1

Embed Size (px)

DESCRIPTION

Google App Engine talk as given by Matthew McCullough to the SEAJUG in Seattle Washington.

Citation preview

Page 1: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Cloud Computing boot camp

on the Google App Engine

by Matthew McCullough of Ambient Ideas, LLC

Page 2: Cloud Computing Bootcamp On The Google App Engine v1.2.1

MatthewTwitter @matthewmccull

Blog http://www.ambientideas.com/blog sidebar has all my social media links

Email [email protected]

GitHub http://github.com/matthewmccullough

Page 3: Cloud Computing Bootcamp On The Google App Engine v1.2.1

http://flushirts.spreadshirt.com/us/US/Shop/

Page 4: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Theory

& Backgro

und

Practi

ce

Page 5: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 6: Cloud Computing Bootcamp On The Google App Engine v1.2.1

1960

Page 7: Cloud Computing Bootcamp On The Google App Engine v1.2.1

“computation may someday be organized as a public utility”

-John McCarthy

Page 8: Cloud Computing Bootcamp On The Google App Engine v1.2.1

circa 2000

Page 9: Cloud Computing Bootcamp On The Google App Engine v1.2.1

“Cloud Computing”coined

Page 10: Cloud Computing Bootcamp On The Google App Engine v1.2.1

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

-Wikipedia

Page 11: Cloud Computing Bootcamp On The Google App Engine v1.2.1

“Users need not have knowledge of, expertise in, or control over the technology infrastructure in the "cloud" that supports them.”

-Wikipedia

Page 12: Cloud Computing Bootcamp On The Google App Engine v1.2.1

What is the Cloud?

Page 13: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Scalable

Page 14: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Dynamic

Page 15: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Pay-per-use

Page 16: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Stateless

Page 17: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Affinity-less

Page 18: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Scale up

Page 19: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Scale down

Page 20: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Grid

Page 21: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Why the Cloud?

Page 22: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Cost of startup

Page 23: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Experimentation

Page 24: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Transition to Production

Page 25: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No licensing fees

Page 26: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Instant availability

Page 27: Cloud Computing Bootcamp On The Google App Engine v1.2.1

What’s the most expensive item on a

startup’s balance sheet?

Page 28: Cloud Computing Bootcamp On The Google App Engine v1.2.1

You!

Page 29: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Time savings

Page 30: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Hardware setup time

Page 31: Cloud Computing Bootcamp On The Google App Engine v1.2.1

OS setup time

Page 32: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Database setup time

Page 33: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Web container setup time

Page 34: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Server setup

Page 35: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Server destruction

Page 36: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Cloud Players

Page 37: Cloud Computing Bootcamp On The Google App Engine v1.2.1

From most open to most constrained

Page 38: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace Cloud Servers(formerly Mosso)

Page 39: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace Cloud Sites

Page 40: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 41: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2

Page 42: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 43: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.ph

Page 44: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 45: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google App Engine

Page 46: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 47: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Levels of Abstraction

Page 48: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Operating System Images

Page 49: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Predetermined

Page 50: Cloud Computing Bootcamp On The Google App Engine v1.2.1

or abstracted away

Page 51: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Programming languages?

Page 52: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Ruby?

Page 53: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Java?

Page 54: Cloud Computing Bootcamp On The Google App Engine v1.2.1

PHP?

Page 55: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Python?

Page 56: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Anything?

Page 57: Cloud Computing Bootcamp On The Google App Engine v1.2.1

File Systems

Page 58: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace CloudTraditional File System

Page 59: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2S3 Buckets

Page 60: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2Elastic Block Storage

Page 61: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.phTraditional File System

Page 62: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google App EngineBigTable

Page 63: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Databases

Page 64: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace CloudMicrosoft SQL Server

Page 65: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace CloudMySQL

Page 66: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace Cloud<any db>

Page 67: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2Simple DB

Page 68: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2IBM DB2

Page 69: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.phPostgreSQL

Page 70: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.phMySQL

Page 71: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google App EngineBig Table

Page 72: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Operating Systems

Page 73: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Debian, Fedora, Ubuntuon Rackspace Cloud

Page 74: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Windows Serveron Amazon EC2

Page 75: Cloud Computing Bootcamp On The Google App Engine v1.2.1

1000 variants of Linuxon Amazon EC2

Page 76: Cloud Computing Bootcamp On The Google App Engine v1.2.1

CentOS Linuxon Mor.ph

Page 77: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Custom Linuxon Google App Engine

Page 78: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Pricing

Page 79: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Rackspace Cloud

Page 80: Cloud Computing Bootcamp On The Google App Engine v1.2.1

1.5¢ per hour

Page 81: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 82: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 83: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Amazon EC2

Page 84: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 85: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.ph

Page 86: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 87: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Fully supported level$1500/month

Page 88: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.phFree human inside

specially marked boxes!

Page 89: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google App Engine

Page 90: Cloud Computing Bootcamp On The Google App Engine v1.2.1

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

volume!

Page 91: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 92: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 93: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 94: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 95: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 96: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google App Engine

Page 97: Cloud Computing Bootcamp On The Google App Engine v1.2.1

April 8th, 2008

Page 98: Cloud Computing Bootcamp On The Google App Engine v1.2.1

small company

Page 99: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 100: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 101: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Python!

Page 102: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 103: Cloud Computing Bootcamp On The Google App Engine v1.2.1

April 7th, 2009

Page 104: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 105: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Java!

Page 106: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 107: Cloud Computing Bootcamp On The Google App Engine v1.2.1

But more like

Page 108: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Banned

Java

Page 109: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Getting Started with

GAE

Page 110: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Free to start

Page 111: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Cell Phone #

Page 112: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Regular Google Account

Page 113: Cloud Computing Bootcamp On The Google App Engine v1.2.1

10,000: first wave

Page 114: Cloud Computing Bootcamp On The Google App Engine v1.2.1

95 minutes

Page 115: Cloud Computing Bootcamp On The Google App Engine v1.2.1

25,000: second wave

Page 116: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Everyone: third wave

Page 117: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 118: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Technology Stack

Page 119: Cloud Computing Bootcamp On The Google App Engine v1.2.1

SDK

Page 120: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 121: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Shell scripts to manage apps

Page 122: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Source code included

Page 123: Cloud Computing Bootcamp On The Google App Engine v1.2.1

SDK-version-locked by the SDK JARs you

include

Page 124: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Subset of JDK 1.6

Page 125: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Custom Class Loaders

Page 126: Cloud Computing Bootcamp On The Google App Engine v1.2.1

“Sandbox”

Page 127: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Whitelist of Classes

Page 128: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Caution!

Page 129: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Can work on desktop,not on GAE

Page 130: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Application ID

Page 131: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Globally Unique

Page 132: Cloud Computing Bootcamp On The Google App Engine v1.2.1

required for deployment

Page 133: Cloud Computing Bootcamp On The Google App Engine v1.2.1

xxxxx.appspot.com

Page 134: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Servlet API

Page 135: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Jetty

Page 136: Cloud Computing Bootcamp On The Google App Engine v1.2.1

JSPs

Page 137: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Java Mail API

Page 138: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Google Web Toolkit

Page 139: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Authentication(2 options)

Page 140: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Integration withGoogle Accounts

Page 141: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 142: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Admin & User Level Permissions

Page 143: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Roll your own(hint: use SpringSecurity)

Page 144: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Memcache(as an alternative to persistent disk storage)

Page 145: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Low level API

Page 146: Cloud Computing Bootcamp On The Google App Engine v1.2.1

JSR-107 / JCache(javax.cache)

Page 147: Cloud Computing Bootcamp On The Google App Engine v1.2.1

BigTable

Page 148: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Relational Database?

Page 149: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Relational Database

Page 150: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Can import from existing DB

Page 151: Cloud Computing Bootcamp On The Google App Engine v1.2.1

JDO

Page 152: Cloud Computing Bootcamp On The Google App Engine v1.2.1

JPA

Page 153: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Limited GORM-JPA

Page 154: Cloud Computing Bootcamp On The Google App Engine v1.2.1

DataNucleus

Page 155: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 156: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Logging

Page 157: Cloud Computing Bootcamp On The Google App Engine v1.2.1

java.util.logging

Page 158: Cloud Computing Bootcamp On The Google App Engine v1.2.1

System.out == infoSystem.err == warning

Page 159: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Log4j

Page 160: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 161: Cloud Computing Bootcamp On The Google App Engine v1.2.1

a few NOs

Page 162: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No Hibernate

Page 163: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No file writing

Page 164: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No threads

Page 165: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No server affinity

Page 166: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Even for sequential requests

Page 167: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No sockets

Page 168: Cloud Computing Bootcamp On The Google App Engine v1.2.1

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

Page 169: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No JNI

Page 170: Cloud Computing Bootcamp On The Google App Engine v1.2.1

No more than 30s

Page 171: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Ouch!

Page 172: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Customtimeout response

Page 173: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 174: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 175: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Admin Console

Page 176: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Statistics

Page 177: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Graphs of Usage

Page 178: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 179: Cloud Computing Bootcamp On The Google App Engine v1.2.1

System Health

Page 180: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 181: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Logs

Page 182: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 183: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Pay forlarge usage

Page 184: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Daily Budgets

Page 185: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Budget per resource type

Page 186: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Dev Tools

Page 187: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Eclipse

Page 188: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Jetty Demo Container

Page 189: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Bundled withGWT plugin

Page 190: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Ant

Page 191: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Maven

Page 192: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Grails Plugin

Page 193: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 194: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Ideas & Demos

Page 195: Cloud Computing Bootcamp On The Google App Engine v1.2.1

http://appengine.google.com/

Page 196: Cloud Computing Bootcamp On The Google App Engine v1.2.1

http://*.appspot.com

Page 197: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Page 198: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Ecosphere

Page 199: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Hyperic

Page 200: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Yup, those guys

Page 201: Cloud Computing Bootcamp On The Google App Engine v1.2.1

CloudStatus.com

Page 202: Cloud Computing Bootcamp On The Google App Engine v1.2.1
Page 203: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Mor.ph

Page 204: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Remember, that layeron top of EC2?

Page 205: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Humans

Page 206: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Cloud Fallout

Page 207: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Large Setups more economical to self-host

Page 208: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Out of your hands

Page 209: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Uptime?

Page 210: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Do you trust the vendor?

Page 211: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Persistence can be weird

Page 212: Cloud Computing Bootcamp On The Google App Engine v1.2.1

Give it a try!

Page 213: Cloud Computing Bootcamp On The Google App Engine v1.2.1

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/