cloud computing bootcamp on the google app engine v1.2.1

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

Upload: matthew-mccullough

Post on 19-May-2015

4.041 views

Category:

Education


1 download

DESCRIPTION

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

TRANSCRIPT

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/