Google app engine para lean startups: the good, the bad and the ugly

  • 2,533 views
Uploaded on

Mais da metade da geração Y americana quer empreender, e na área de High Tech isso significa startups. Mas montar uma startup enxuta requer queimar etapas que devem ser encaradas excesso de peso em …

Mais da metade da geração Y americana quer empreender, e na área de High Tech isso significa startups. Mas montar uma startup enxuta requer queimar etapas que devem ser encaradas excesso de peso em seus concorrentes. Uma dessas escolhas seria a utilização de uma Platform as a Service, e dentre elas uma escalável e NoSQL como Google App Engine(GAE). Nessa apresentação cobriremos aspectos positivos, negativos e grotescos em GAE segundo nossos experimentos Java e Python sobre a mesma desde 2011. Se você prefere aprender com os erros dos outros e está curioso sobre Cloud Computing com GAE, essa apresentação é pra você.

More in: Education
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Be the first to comment
    Be the first to like this
No Downloads

Views

Total Views
2,533
On Slideshare
0
From Embeds
0
Number of Embeds
0

Actions

Shares
Downloads
4
Comments
0
Likes
0

Embeds 0

No embeds

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
    No notes for slide

Transcript

  • 1. Google App Engine para Startups Enxutas: The Good, The Bad and The Ugly Marcio Marchini marcio@betterdeveloper.net
  • 2. Explicando o Título 1. The Good, The Bad and The Ugly (Um clássico a ser assistido…)
  • 3. Explicando o Título 2.  Startups Enxutas (Um bom livro a ser lido…)
  • 4. Explicando o Título 3.  Goole App Engine (Uma Platform as a Service a ser explorada…)
  • 5. PaaS, IaaS, etc Ex. VOCÊ! Ex. GAE Ex. EC2 Fonte: Wikipedia
  • 6. GAE Datastore: Comparativo Imagem do Artigo: “Banco de dados como serviço” / revista “tema” / SERPRO
  • 7. GAE: PaaS Vamos ao que Interessa pra sua Startup Enxuta…
  • 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.  …
  • 9. Bebemos o Próprio Champagne… (nosso site é uma app GAE)
  • 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 L)
  • 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, GAE1.  Registre seu domínio em registro.br ou web.com ou outro Registrar qualquer2.  Crie uma conta (gratuita) em www.ZoneEdit.com3.  Adicione uma Zone no ZoneEdit, correspondente ao seu domínio4.  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údo1.  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, gratuitamente3.  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.
  • 19. Hello World no Estilo GAE Hello, World!
  • 20. GAE Hello World & Elasticidade (2011/06, Wicket)http://<helloworld>.appspot.com , simulando 250 usuários concorrentespor 10 minutos com http://sourceforge.net/projects/dieseltest/
  • 21. GAE Hello World & Elasticidade (2011/06, Wicket)
  • 22. GAE “Hello World” de Datastore (2011/06, Wicket)CRUD de Redes de Hotéis e Hotéis
  • 23. GAE “Hello World” de Datastore (2011/06, Wicket)GUI versusDatastore
  • 24. The Good: J (Coisas legais/boas no GAE)
  • 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
  • 26. Coisas boas GAE – Traffic Splitting•  A/B Testing etc etc
  • 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/pub? 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_handling_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 has support for Python, Go, and Java applications, taking the open source SDK provided by Google App Engine and implementing scalable services such as the datastore, memcache, blobstore, users API, 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
  • 33. The Bad: L (Coisas ruins no GAE – na nossa opinião)
  • 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/python/ 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/python/ runtime#The_Request_Timer diz 60. •  File Upload? Que mais demora >60s na web? •  Async URL fetch serve pra mitigar a maioria dos cenários
  • 36. New Relic não Rola L “The restrictions that exist under Google App Engine, such as those on background threads, as well as how processes are managed, mean that the Python agent as it is implemented at present will not work as is. There are no plans at this point to support Google App Engine.” è Use o Dashboard “toco-duro” GAE… L
  • 37. Apple iOS Push Notification não Rola L Sandbox: não podes abrir conexão socket pros servidores de Push da Apple è Precisas de uma máquina na EC2 etc que responda à sua app no GAE via REST e 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/detail? id=1164
  • 38. WebSockets não rola LAlgo tipo Trello, que usa WebSockets (segundo artigopublicado), não funciona pelo mesmo motivo(conexões socket persistentes / longas) § Mas tem a Channel API: https://developers.google.com/appengine/docs/java/channel/ overview The Channel API creates a persistent connection between your application and Google servers, allowing your application to send messages to JavaScript clients in real time without the use of polling. This is useful for applications designed to update users about new information immediately. è Sentiu-se atolando na areia movediça da plataforma proprietária?
  • 39. Minha Framework Web Favorita não vem pré-carregada L CherryPy não vem pré-carregada https:// developers.google.com/appengine/docs/python/tools/ libraries27 èTens que 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 J•  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 quiseres SQL ao invés de NoSQL
  • 44. Alguns Limites em geralè Fique atento… https://developers.google.com/appengine/ docs/python/runtime#Quotas_and_Limits
  • 45. Limites Free à Pagoè Datastore:è Log:
  • 46. Limites Free à Pagoè Bandwidth:è tasks: Mais: https://developers.google.com/appengine/docs/quotas
  • 47. The Ugly: LLL (Coisas bem ruins no GAE)
  • 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 ambas ter @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/RELEASE_NOTES.ORM
  • 51. Coisas bem ruins GAE: App Engine Data != Big Data1.  JÁ QUE Google tem MapReduce & tem NoSQL Datastore2.  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-queryb.  OU usar Library MapReduce http://code.google.com/p/ appengine-mapreduce/ , https://developers.google.com/ appengine/docs/python/dataprocessing/overview (“ALFA”) •  Que por ora só tem o Mapper API (sem Reduce) http:// googleappengine.blogspot.com.br/2010/07/introducing- mapper-api.html?m=1 , https://developers.google.com/ appengine/articles/mr/mapper
  • 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