O documento discute o Google App Engine para startups enxutas, destacando seus pontos positivos, negativos e desafios. As principais vantagens incluem desempenho, escalabilidade, facilidade de uso e custo baixo. Entre as desvantagens estão limitações como tempo de resposta máximo de 1 segundo e restrições de conectividade. Em geral, o GAE pode ser uma boa opção para startups enxutas, desde que se esteja ciente de suas limitações técnicas.
8. Lição Lean Startup #1: Web Site Estático Escalável
1. Uma App no App Engine pode ter parte estática
e parte dinâmica (Python, Java, etc)
2. O Web Site de sua empresa pode começar 100%
estático
3. E pode ser escalável… (brabilhões de visitantes)
4. E sem admin Linux, EC2 etc… ($$$)
5. E sem pagar taxa de hosting pra uso normal… ($)
6. E sem se incomodar com DDoS etc
7. …
10. Matamos a Cobra e Mostramos o Pau: Site Estático no GAE
1. Vamos escolher um site estático qualquer na web o e vamos
colocá-lo no GAE. Exemplo aleatório:
http://www.promote-web-sites.com
2. Vamos fazer download de suas páginas:
wget --mirror -p --convert-links -P . http://www.promote-
web-sites.com
3. Faz de conta que esse é o meu site. Vamos colocá-lo no
GAE? Mova as páginas HTML para uma pasta static ,
dentro do nossa pasta betdevgaenosql
mv ./www.promote-web-sites.com/*
/Users/mqm/betdevgaenosql/static
11. (2/4): Site Estático no GAE
4. Editemos app.yaml para poder servir páginas estáticas
12. (3/4): Site Estático no GAE – Testando Localmente
5. Clique Run (botão verde)
6. Visite:
http://localhost:8080/
7. Site estático!!
13. (4/4): Site Estático no GAE - Deploy
8. Clique Deploy no GAE Launcher (botão azul)
9. Visite: http://betdevgaenosql.appspot.com/
10.Site estático!!
(com URL feia )
14. Recapitulando
• Uma Google App (em Python, Java, etc) pode
servir conteúdo estático
• Podes fazer upload de seu site hoje
• Mas… como coloco uma URL raiz com meu
domínio (ex. www.betterdeveloper.net) ao invés
de *.appspot.com ?
15. Lição Lean Startup #2: Sua Página, Seu Domínio, GAE
1. Registre seu domínio em registro.br ou web.com ou outro
Registrar qualquer
2. Crie uma conta (gratuita) em www.ZoneEdit.com
3. Adicione uma Zone no ZoneEdit, correspondente ao seu
domínio
4. No seu Registrar, aponte o DNS para os valores do
ZoneEdit.com (ex. ns10.zoneedit.com , etc)
5. Adicione a entrada A e CNAME conforme abaixo
16. Sua Página, Seu Domínio, GAE
6. Crie uma conta gratuita Google Apps (<=10 contas no seu domínio)
7. Cria sua Google App nesse domínio
8. Crie o mapeamento de www no Google App para sua App
9. Deverá funcionar, igual ao www.betterdeveloper.net
17. Lição Lean Startup #3: Versões Distintas, Rollback
1. Temos que habilitar a versão 2 do site
2. Habilite o radio button, clique Make Default
3. Clique no “2”ao lado do radio button. Ele vai disparar a versão 2
do site
4. Clique no “1”ao lado do radio button. Ele vai disparar a versão 1
do site (original)
18. Lição Lean Startup #4: Versione seu conteúdo
1. Use Git ou Svn pra versionar os fontes do seu site. Use TAGs por
exemplo pra mapear pra versão ativa no ar (slide anterior)
2. Use uma conta gratuita xp-dev.com – pode ter 1 projeto não Open
Source, gratuitamente
3. Agora você tem rastreabilidade e governança de fontes e versões no ar,
gratuitamente. Fontes na Cloud (XP-Dev). “Binário”/site na Cloud
(GAE)”. Super Lean.
4. Ative o TRAC como sistema de tickets no XP-DEV. Pronto, agora até
suas sprints/backlogs/feature requests/bug fixes tem Roadmap na web
e governança na empresa.
25. Coisas boas GAE - Performance
• 5 milhões de pageviews / mês gratuitamente. Chega pra ti?
• Memchache distribuído, sem você precisar
instalar/configurar
• Conteúdo estático servido por servidores dedicados,
transparentemente. Não precisas penar configurando load
balancers / nginx etc e tal.
• Mantém sua app em RAM o máximo que dá (performance)
• Suporta tasks/background, no estilo cron
• Logging fácil, memcache fácil
• Utiliza o performático Jetty, envenenado:
http://www.infoq.com/news/2009/08/google-chose-jetty
• Suporte a SDPY na sua app
http://dev.chromium.org/spdy/spdy-whitepaper
27. Coisas boas GAE – IDEs etc
• Suporte a Python, Go, Java (e linguagens que rodam na
JVM)
• Roda frameworks tipo Java Apache Wicket, Python
CherryPy. Suporta GWT etc.
https://spreadsheets.google.com/a/betterdeveloper.net/p
ub?key=pRJ_0hajVrhacLjp3HqD5ew
• Suportado por Eclipse (plugin GAE), PyCharm etc
• Suporta Ant
• Podes testar localmente antes
• Console interativo Python – rode snippets direto no
servidor, “peek/poke”
• Sua app pode receber email, entra como http request (GAE
cuida disso).
28. Coisas boas GAE - Storage
• Datastore “schemaless”. Fácil prototipar e evoluir.
• O NoSQL pode buscar baseado em propriedades
• Versão dev local analisa perfil de uso e já otimiza índices
do datastore
• SDK suporta upload/download de dados em modo “bulk”
• JPA significa que podes entrar/sair do GAE com mais
facilidade (evita lock-in). Well… (veja The Ugly)
• Datastore pode gerar unique keys automaticamente
• Memcache obedece standard JCache
• Memcache viewer no Python SDK
• Podes fazer sync GAE-NoSQL MySQL externo com
https://github.com/k7d/approcket/wiki
29. Coisas boas GAE – Storage Relacional
• Não é só NoSQL. MySQL também suportado (Mas sem quota
gratuita)
• http://googleappengine.blogspot.com.br/2012/05/cloud-
sql-pick-plan-that-fits-your-app.html
• https://developers.google.com/cloud-sql/
30. Coisas boas GAE
• Console pra administração
• Múltiplas versões da app rodando concorrentemente
• Podes fazer uma app só pra sua “Intranet” – apenas
membros do seuDominio.com tem acesso
• 10 apps GAE por developer
• Sem Ads, mesmo nas apps free / conta free (ex. Gmail)
• Pode-se definir um limite máximo de custo por dia
• Boa integração com APIs Google: login, gtalk, imagens, etc
• Paypal ok:
http://www.dzone.com/links/setting_up_paypal_ipn_handlin
g_on_google_app_engi.html
• Possível mandar email pra app via XMPP, do console, pra
testes
31. Coisas boas GAE
• Duas implementações novas, não proprietárias
• http://en.wikipedia.org/wiki/AppScale
It hassupport for Python,Go,and Java applications,taking the open
source SDKprovided by Google App Engine and implementing scalable
servicessuch asthe datastore, memcache,blobstore,usersAPI,and
channel API.
• http://code.google.com/p/typhoonae/ (BETA)
32. Coisas boas GAE
• Google Data Centers
http://www.google.com/about/datacenters/inside/index.html
34. Coisas ruins GAE…
• Livros obsoletos. Exemplo: dica de “main”/Python
pra cache em Programming Google App Engine: não
mais necessário com Python 2.7 (veja
https://developers.google.com/appengine/docs/p
ython/python25/migrate27#wsgi )
35. Coisas ruins GAE…
• Feito pra requests que demorem <1s. Se demorar
>60s, você é assassinado (no livro – obsoleto - fala
30s, mas
https://developers.google.com/appengine/docs/p
ython/runtime#The_Request_Timer diz 60.
• File Upload?Que maisdemora >60sna web?
• Async URLfetch serve pra mitigar a maioria dos
cenários
36. New Relic não Rola
“The restrictionsthat exist under Google App Engine,
such asthose on background threads, aswell ashow
processesare managed, mean that the Python agent as
it isimplemented at present will not work asis.There are
no plansat thispoint to support Google App Engine.”
Use o Dashboard “toco-duro” GAE…
37. Apple iOS Push Notification não Rola
Sandbox: não podes abrir conexão socket pros
servidores de Push da Apple
Precisasde uma máquina na EC2 etc que
responda à sua app no GAEvia RESTe essa sim faz o
push pra Apple.Sugestão: RabbitMQ/REST
http://code.google.com/p/amqp-rest/
Ou: espera o Beta graduar:
http://code.google.com/p/googleappengine/issues/det
ail?id=1164
38. WebSockets não rola
Algo tipo Trello, que usa WebSockets (segundo artigo
publicado), não funciona pelo mesmo motivo (conexões
socket persistentes/ longas)
Mastem a Channel API:
https://developers.google.com/appengine/docs/java/channel/o
verview
The Channel API createsa persistent connection between your application
and Google servers,allowing your application to send messagesto
JavaScript clientsin real time without the use of polling.Thisisuseful for
applicationsdesigned to update usersabout new information immediately.
Sentiu-se atolando na areia movediça da plataforma proprietária?
39. Minha Framework Web Favorita não vem pré-carregada
CherryPy não vem pré-carregada
https://developers.google.com/appengine/docs/python
/tools/libraries27
Tensque empacotar o zip junto e
dinamicamente adicionar no path
Ou seja: não é problema, funciona ok
40. Coisas ruins GAE
• Modelo limitado/Sandbox – mais proteção, mas… mais
restrição
• (2011) Não suporta(va) Full Text Search (pense CMS).
Aparentemente ok em 2012:
http://googleappengine.blogspot.com.br/2012/05/looking-for-search-
find-it-on-google.html
• (2011) Algumas operações, só com SDK de linha de comando.
Inexistência de GUI Launcher pra Linux (só Windows e Mac).
• Nem todas APIs oficiais são implementadas (ex trivial:
Thread/ThreadGroup Java)
• Muita coisa JPA aponta pra JDO, que está obsoleto
• (2011) Console Java mais limitado que o Python
• (2011) Servidor DEV/PC não suporta “background tasks” no
Python (GAE Era Preview até Setembro de 2011!!!)
41. Coisas ruins GAE
• Domínio customizado requer conta Google Apps (mas é free
pra 10 contas de usuário/colaborador/funcionário/whatever)
• Ativar 1 conta GAE/Developer requer 1 telefone celular. 3
domínios? Arrume 3 celulares
• Não faz routing de domínio puro (foo.com) pra app. Tem que
ser algo como www.foo.com
• Se usares www, tens que primeiro habilitar Sites, mudar
esse de www pra www2 ou algo assim, pra sua app poder
servir www.seuDominio.com
• Tipo de autenticação da App não pode mudar após criado o
seu ID
• Multithreaded p/ Python demorou a ser ativado (só agora
com Python 2.7). Era CGI ao invés de WSGI. (Mas Java já era
MT ok)
42. Coisas ruins GAE: PhD pra entender Índices
• Todas as queries usam índices
• Alguns índices são gerados automaticamente pra você
• Queries mais elaboradas precisam de índices pré-
definidos/criados no arquivo index.yaml
• Caso a query precise de um índice e esse não exista ainda,
vai dar erro/exceção
• O sistema tenta criar os índices pra você baseado nas queries
de desenvolvimento DEV/PC
43. Google Could SQL é pago
Não dá pra ser enxuto se quiseresSQL ao invésde NoSQL
44. Alguns Limites em geral
Fique atento…
https://developers.google.com/appengine/docs/python/runti
me#Quotas_and_Limits
48. Coisas bem ruins GAE
• Acesso SSH? Esquece
• Precisou de uma ferramenta extra, tipo Sphinx? Esquece!
Lembre: Não tens um console Linux. PaaS!
49. Coisas bem ruins GAE: HTTPS
• Não suporta (va) HTTPS se sua app está com um domain
“bonito” tipo foo.bar.com (mas OK na forma
foo.appspot.com).
http://code.google.com/p/googleappengine/issues/detail?
id=792
• Isso vai me dificultar adicionar pagamento online VISA no
www.betterdeveloper.net
• Teoricamente arrumado em 06/2012 com SNI (Server
Name Indication) @ US$9/mês ou VIP (Virtual IP) @
US$99/mês -
http://googleappengine.blogspot.com.br/2012/06/google
-app-engine-170-released-at.html
50. Coisas bem ruins GAE: JPA “Alfa” (tvz ok em 2012?)
• (2011) Implementação JPA em cima de Datanucleous não
era oficialmente suportada pelo pessoal Datanucleous.
Muita limitação, muita dor de cabeça!!!
• Exemplo: Uma entidade "pai"e uma "filha" nao podem
ambaster @Id sendo um Long. A do filho tem que usar a
classe proprietária Key da Google.
Vejam http://code.google.com/p/datanucleus-
appengine/issues/detail?id=26 . Foi pro espaço sua
portabilidade JPA!!!!
Aparentemente arrumaram em 2012:
http://code.google.com/p/datanucleus-
appengine/source/browse/branches/2_0_0/dist/RELEA
SE_NOTES.ORM
51. Coisas bem ruins GAE: App Engine Data != Big Data
1. JÁ QUE Google tem MapReduce & tem NoSQL Datastore
2. E JÁ QUE GAE roda na infra Google
• ENTÃO OBVIAMENTE minha GAE App pode ter BigData e eu
fazer MapReduce nos dados, certo? NÃO! Infelizmente, tens
que:
a. OU usar o produto BigQuery
https://cloud.google.com/products/big-query
b. OU usar Library MapReduce
http://code.google.com/p/appengine-mapreduce/ ,
https://developers.google.com/appengine/docs/python/da
taprocessing/overview (“ALFA”)
• Que por ora só tem o Mapper API (sem Reduce)
http://googleappengine.blogspot.com.br/2010/07/introd
ucing-mapper-api.html?m=1 ,
52. Coisas bem ruins GAE: Queries impossíveis GQL
Testar 2 inequalidades de 2 propriedades distintas não rola
53. Coisas ruins GAE
• Portabilidade Problemática. Será que
http://en.wikipedia.org/wiki/AppScale é viável? Não
testei.
Sentiu-se atolando na areia movediça da plataforma proprietária?
54. Conclusão
• Às Vezes o Barato Sai Caro… O Desafio é escolher o barato
certo (Linux Admin ou GAE Fees?)
• Try Before You Buy
• Your Mileage May Vary
• “Valeu à Pena? Tudo Vale a Pena se a Alma Não é
Pequena” --– Fernando Pessoa
• Investigue tb Heroku, Azure, etc
• Investigue tb Do-It-Yourself com Amazon EC2 e/ou
Amazon SimpleDB e/ou Amazon MapReduce (Hadoop)
55. Obrigado! E Lembre-se…
“To Know and not to do, is not to know”
http://en.wikipedia.org/wiki/Google_App_Engine
56. Slides em PDF no Site
http://www.BetterDeveloper.net/downloads.html