cloud computing bootcamp on the google app engine [v1.1]

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

Upload: matthew-mccullough

Post on 11-May-2015

1.263 views

Category:

Education


1 download

DESCRIPTION

Matthew McCullough's presentation to DOSUG on the Google App Engine's new Java language and JSP/servlet support. Covers the current definition of what Cloud means, and why you'd want to use it. All materials are highly subject to change, as this talk covers the Java Beta GAE support on the App Engine just 27 days after launch.

TRANSCRIPT

Page 1: Cloud Computing Bootcamp On The Google App Engine [v1.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.1]

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

Page 3: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Page 4: Cloud Computing Bootcamp On The Google App Engine [v1.1]

1960

Page 5: Cloud Computing Bootcamp On The Google App Engine [v1.1]

circa 2 0 0 0

Page 6: Cloud Computing Bootcamp On The Google App Engine [v1.1]

What is the Cloud?

Page 7: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Scalable

Page 8: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Dynamic

Page 9: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Pay-per-use

Page 10: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Stateless

Page 11: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Affinity-less

Page 12: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Scale up

Page 13: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Scale down

Page 14: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Grid

Page 15: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Why the Cloud?

Page 16: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Cost of startup

Page 17: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Experimentation

Page 18: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Transition to Production

Page 19: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No licensing fees

Page 20: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Instant Availability

Page 21: Cloud Computing Bootcamp On The Google App Engine [v1.1]

What’s the most expensive item on a

startup’s balance sheet?

Page 22: Cloud Computing Bootcamp On The Google App Engine [v1.1]

You!

Page 23: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Server setup

Page 24: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Server destruction

Page 25: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Time savings

Page 26: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Developer & Consultant Time

Page 27: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Cloud Players

Page 28: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App Engine

Page 29: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Rackspace Mosso

Page 30: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.ph

Page 31: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2

Page 32: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Levels of Abstraction

Page 33: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Any language?

Page 34: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Ruby?

Page 35: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Java?

Page 36: Cloud Computing Bootcamp On The Google App Engine [v1.1]

PHP?

Page 37: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Python?

Page 38: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Anything?

Page 39: Cloud Computing Bootcamp On The Google App Engine [v1.1]

OS Images

Page 40: Cloud Computing Bootcamp On The Google App Engine [v1.1]

or Predetermined

Page 41: Cloud Computing Bootcamp On The Google App Engine [v1.1]

or Abstracted

Page 42: Cloud Computing Bootcamp On The Google App Engine [v1.1]

File Systems

Page 43: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.phTraditional File System

Page 44: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2S3 Buckets

Page 45: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2Elastic Block Storage

Page 46: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Rackspace MossoTraditional File System

Page 47: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App EngineN/A

Page 48: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Databases

Page 49: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2Simple DB

Page 50: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2IBM DB2

Page 51: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App EngineBig Table

Page 52: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.phPostgreSQL

Page 53: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.phMySQL

Page 54: Cloud Computing Bootcamp On The Google App Engine [v1.1]

MossoMySQL

Page 55: Cloud Computing Bootcamp On The Google App Engine [v1.1]

MossoMicrosoft SQL Server

Page 56: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mosso<any db>

Page 57: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Operating Systems

Page 58: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Windows Serveron Amazon EC2

Page 59: Cloud Computing Bootcamp On The Google App Engine [v1.1]

1000 variants of Linuxon Amazon EC2

Page 60: Cloud Computing Bootcamp On The Google App Engine [v1.1]

CentOS Linuxon Mor.ph

Page 61: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Debian, Fedora, Ubuntuon Mosso

Page 62: Cloud Computing Bootcamp On The Google App Engine [v1.1]

<obfuscated>on Google App Engine

Page 63: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Pricing

Page 64: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon EC2

Page 65: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mosso

Page 66: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.ph

Page 67: Cloud Computing Bootcamp On The Google App Engine [v1.1]

$1500/month

Page 68: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.phFree human inside

specially marked boxes!

Page 69: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App Engine

Page 70: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App Engine

We’ll give it away free and make it up in volume!

Page 71: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 72: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Page 73: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 74: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google App Engine

Page 75: Cloud Computing Bootcamp On The Google App Engine [v1.1]

April 8th, 2008

Page 76: Cloud Computing Bootcamp On The Google App Engine [v1.1]

small company

Page 77: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 78: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Python!

Page 79: Cloud Computing Bootcamp On The Google App Engine [v1.1]

April 7th, 2009

Page 80: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Java!

Page 81: Cloud Computing Bootcamp On The Google App Engine [v1.1]

But more like

Page 82: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Java!⅘

Page 83: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Getting Started with

GAE

Page 84: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Free to start

Page 85: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Cell Phone #

Page 86: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Regular Google Account

Page 87: Cloud Computing Bootcamp On The Google App Engine [v1.1]

10,000 first wave

Page 88: Cloud Computing Bootcamp On The Google App Engine [v1.1]

obsessed

Page 89: Cloud Computing Bootcamp On The Google App Engine [v1.1]

95 minutes

Page 90: Cloud Computing Bootcamp On The Google App Engine [v1.1]

25,000 second wave

Page 91: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Ideas & Demos

Page 92: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mobile Apps

Page 93: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 94: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Technology Stack

Page 95: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Servlet API

Page 96: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Jetty

Page 97: Cloud Computing Bootcamp On The Google App Engine [v1.1]

JSPs

Page 98: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Java Mail API

Page 99: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Google Web Toolkit

Page 100: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Authentication

Page 101: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Integration withGoogle Accounts

Page 102: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Admin & User Level Permissions

Page 103: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Java Cache API

Page 104: Cloud Computing Bootcamp On The Google App Engine [v1.1]

JSR-107 / JCache

Page 105: Cloud Computing Bootcamp On The Google App Engine [v1.1]

BigTable

Page 106: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Database

Page 107: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Can import from existing DB

Page 108: Cloud Computing Bootcamp On The Google App Engine [v1.1]

JDO

Page 109: Cloud Computing Bootcamp On The Google App Engine [v1.1]

JPA

Page 110: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No

Page 111: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No Gorm

Page 112: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No Hibernate

Page 113: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No file writing

Page 114: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No threads

Page 115: Cloud Computing Bootcamp On The Google App Engine [v1.1]

lack of server affinity

Page 116: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Who moved my cheese?

Page 117: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Even for sequential requests

Page 118: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No sockets

Page 119: Cloud Computing Bootcamp On The Google App Engine [v1.1]

But... can use URLFetchfor HTTP/HTTPS resources

Page 120: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No JNI

Page 121: Cloud Computing Bootcamp On The Google App Engine [v1.1]

No more than 30s

Page 122: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Ouch!

Page 123: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Custom timeout response

Page 124: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 125: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Application ID

Page 126: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Globally Unique

Page 127: Cloud Computing Bootcamp On The Google App Engine [v1.1]

required for deployment

Page 128: Cloud Computing Bootcamp On The Google App Engine [v1.1]

xxxxx.appspot.com

Page 129: Cloud Computing Bootcamp On The Google App Engine [v1.1]

SDK

Page 130: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 131: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Shell scripts to manage apps

Page 132: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Source code included

Page 133: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Versioned by the JARs you include

Page 134: Cloud Computing Bootcamp On The Google App Engine [v1.1]

DataNucleus

Page 135: Cloud Computing Bootcamp On The Google App Engine [v1.1]

JDO for BigTable

Page 136: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 137: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Subset of JDK 1.6

Page 138: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Custom Class Loaders

Page 139: Cloud Computing Bootcamp On The Google App Engine [v1.1]

“Sandbox”

Page 140: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Whitelist of Classes

Page 141: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Caution!

Page 142: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Can work on desktop,not on GAE

Page 143: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Compression

Page 144: Cloud Computing Bootcamp On The Google App Engine [v1.1]

gzip

Page 145: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Accept-Encoding:gzip

Page 146: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Admin Console

Page 147: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Statistics

Page 148: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Graphs of Usage

Page 149: Cloud Computing Bootcamp On The Google App Engine [v1.1]

System Health

Page 150: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 151: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 152: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Pay forextreme usage

Page 153: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Daily Budget

Page 154: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Budgetper resource type

Page 155: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Logging

Page 156: Cloud Computing Bootcamp On The Google App Engine [v1.1]

java.util.logging

Page 157: Cloud Computing Bootcamp On The Google App Engine [v1.1]

System.out == infoSystem.err == warning

Page 158: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Log4j

Page 159: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 160: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Dev Tools

Page 161: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Eclipse

Page 162: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Jetty Demo Container

Page 163: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Bundled withGWT plugin

Page 164: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Ant

Page 165: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Maven

Page 166: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Page 167: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Ecosphere

Page 168: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Hyperic

Page 169: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Yup, those guys

Page 170: Cloud Computing Bootcamp On The Google App Engine [v1.1]

CloudStatus.com

Page 171: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 172: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Mor.ph

Page 173: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Layer on top of EC2

Page 174: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Humans

Page 175: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Eclectic Info

Page 176: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Amazon Mechanical Turk

Page 177: Cloud Computing Bootcamp On The Google App Engine [v1.1]
Page 178: Cloud Computing Bootcamp On The Google App Engine [v1.1]

AmazonElastic Map Reduce

Apache Hadoop

Page 179: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Cloud Fallout

Page 180: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Large Setups more economical to self-host

Page 181: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Out of your hands

Page 182: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Uptime?

Page 183: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Do you trust the vendor?

Page 184: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Persistence can be weird

Page 185: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Give it a try!

Page 186: Cloud Computing Bootcamp On The Google App Engine [v1.1]

Resources

• http://mor.ph

• http://appengine.google.com

• http://mosso.com

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