SlideShare a Scribd company logo
8 rules to build web app on
 top of Google AppEngine
         effectively
        Lessons learned




            www.comvai.com
Google App Engine



• Keep in mind Google AppEngine supports
  subset of Java EE specifications. Check at
  http://code.google.com/p/googleappengine/wiki/W



                  www.comvai.com
1. Design Data model as simple as
                possible
•   The App Engine Datastore is not traditional relational SQL database and
    there are several important differences.

•   AppEngine datastore is schemaless. Entities of the same kind can have
    different properties. The application itself is responsible for ensuring that
    entities conform to it.

•   If you want to migrate your existing data model to App Engine you will
    probably need it to redesign.

•   Data-model consistency will be split to the data-model and application.

•   Check app engine datastore limitations to understand it. It gives you better
    overview regarding your future data-model design.
    http://code.google.com/appengine/articles/datastore/overview.html
                                   www.comvai.com
How to
•   Use recommended High Replication Datastore HRD.

•   Use Objectify with JPA annotations over built-in JPA or JDO.

•   Prefer to use unowned relationships between entities.

•   Forget about count entities over filtered query result. Design your UI so
    that count is not being required.

•   If you need statistic calculations, do it on entity update.

•   Note: Building data model on top of built-in either JPA or JDO doesn't
    guarantee that application will be vendor independent because of different
    behavior of AppEngine datastore in some cases. Even it doesn't mean that's
    not possible to do so just requires understanding of AppEngine datastore
    behavior.
                                   www.comvai.com
2. Handle your data model via non
     default version of your GAE app



•   The AppEngine allows you to deploy more than one non default version of
    your application. Deploy specifically designed application to perform update
    of your data model only as a non default version to be independent from
    your main application release cycle.




                                  www.comvai.com
3. Price shields tips

•   Use Appstats out of the box tool to detect datastore bottleneck. Just plug
    in. It helps you to find the hidden unnecessary datastore operations that are
    dragging you down.

•   Use memcache. Datastore operations costs money and caching of "static"
    data could save you from using unnecessary datastore operations.

•   Use as many static files as possible. Static files are handled with high
    performance static front-end servers (CDN) which are highly optimized for
    this type of content.

•   See more
    http://www.gregtracy.com/revisiting-google-app-engines-pricing-changes

                                  www.comvai.com
4. Improve cold startup time
•   AppEngine instances starts quite often thus cold startup time (known as
    well as warmup request, loading request) is more important than in
    traditional Java EE application. Good startup time improves user experience.

•   Minimize number of your application java library dependencies as much as
    possible. Make sure if all your libs are really needed. Otherwise it will slow
    your cold startup time down.

•   Don't use JSP if you are already using another Frontend framework

•   Using JSPs will add additional libraries into your lib directory that are used
    for processing of JSP.
    http://www.listry.com/blog/2010/03/google-app-engine-cold-start-tip-dont

•   Use Objectify over built-in JPA or JDO.
    http://www.listry.com/blog/2010/03/google-app-engine-cold-start-guide-for
                                   www.comvai.com
5. Prefer Google Guice as DI framework




•   It's simple, small in size and powerful library and you probably won't need
    more.




                                  www.comvai.com
6. Use GWT for your desktop like web
                app


•   GWT together with GAE offers lot of built-in technics to improve your
    web app performance. Built-in features coming as advice from the book
    High Performance Web Sites.

•   It's better to have only one framework for the UI even it means to build
    some components yourself. Among other things it means less dependencies
    and simplified upgrade process.




                                www.comvai.com
How to GWT


•   Use built-in optimization technics with help of GWT's ClientBundles.

•   ClientBundles and ImageResource makes using images more efficient.

•   CssResource for CSS minification, CSS image strips and much more, see
    docs for ClientBundles (DataResource, TextResource,
    ExternalTextResource).

•   Switch on minification and obfuscation of the Java-JavaScript compiler.




                                  www.comvai.com
How to GAE



•   Content Delivery Network CDN

•   Gzip compression

•   Memcache




                            www.comvai.com
7. Use GWT MVP pattern




•   It's not easy to work with but worth of time. GWT has built-in support for
    MVP pattern.




                                 www.comvai.com
Benefits

•   Well suited for large scale application.

•   Separation of functionality into components. Helps simplify UI unit testing.

•   Built-in browser history management. MVP is not concerned with browser
    history management, but Activities and Places may be used very well with
    MVP development.

•   Built-in event bus as a central point for app events.

•   Caching all of your code books via GWT event bus as a central pipe to go
    to the backend.


                                   www.comvai.com
8. Use Apache Wicket for website

•   The component based web framework. Version 1.5 or higher optimized for
    Google AppEngine

•   In Java ecosystem there is a lot of front-end frameworks thus to choose the
    right one depends on many varying factors. We like Apache Wicket because
    it's Java, feature rich component-oriented framework with good API. As
    version 1.5 it very well operates on App Engine. So it's up to you and your
    requirements but ones Apache Wicket is good fit for you we recommend it.

•   Add wicketstuff-gae-initializer dependency along side with wicket core
    dependencies

•   Alternative Play framework as it has specific module for App Engine.

                                 www.comvai.com
•   Visit http://www.comvai.com/google-app-engine-development and register
    yourself to get development of your Google AppEngine project's Proof of
    Concept for free.

•   Validate suitability of your project to be built on top of Google App Engine.




                                  www.comvai.com

More Related Content

More from Aurel Medvegy

Web software development
Web software developmentWeb software development
Web software development
Aurel Medvegy
 
Web 2.0 development
Web 2.0 developmentWeb 2.0 development
Web 2.0 development
Aurel Medvegy
 
Make google app
Make google appMake google app
Make google app
Aurel Medvegy
 
Google webtools
Google webtoolsGoogle webtools
Google webtools
Aurel Medvegy
 
Google websites
Google websitesGoogle websites
Google websites
Aurel Medvegy
 
Google website applications
Google website applicationsGoogle website applications
Google website applications
Aurel Medvegy
 
Google web tools
Google web toolsGoogle web tools
Google web tools
Aurel Medvegy
 
Google web tools kit
Google web tools kitGoogle web tools kit
Google web tools kit
Aurel Medvegy
 
Google web software
Google web softwareGoogle web software
Google web software
Aurel Medvegy
 
Google web development
Google web developmentGoogle web development
Google web development
Aurel Medvegy
 
Google web code
Google web codeGoogle web code
Google web code
Aurel Medvegy
 
Google web 2.0
Google web 2.0Google web 2.0
Google web 2.0
Aurel Medvegy
 
Google sites development
Google sites developmentGoogle sites development
Google sites development
Aurel Medvegy
 
Google site development
Google site developmentGoogle site development
Google site development
Aurel Medvegy
 
Google development
Google developmentGoogle development
Google development
Aurel Medvegy
 
Google apps reseller
Google apps resellerGoogle apps reseller
Google apps reseller
Aurel Medvegy
 
Google apps development
Google apps developmentGoogle apps development
Google apps development
Aurel Medvegy
 
Google appps
Google apppsGoogle appps
Google appps
Aurel Medvegy
 
Google appengine
Google appengineGoogle appengine
Google appengine
Aurel Medvegy
 
Google appengine apps
Google appengine appsGoogle appengine apps
Google appengine apps
Aurel Medvegy
 

More from Aurel Medvegy (20)

Web software development
Web software developmentWeb software development
Web software development
 
Web 2.0 development
Web 2.0 developmentWeb 2.0 development
Web 2.0 development
 
Make google app
Make google appMake google app
Make google app
 
Google webtools
Google webtoolsGoogle webtools
Google webtools
 
Google websites
Google websitesGoogle websites
Google websites
 
Google website applications
Google website applicationsGoogle website applications
Google website applications
 
Google web tools
Google web toolsGoogle web tools
Google web tools
 
Google web tools kit
Google web tools kitGoogle web tools kit
Google web tools kit
 
Google web software
Google web softwareGoogle web software
Google web software
 
Google web development
Google web developmentGoogle web development
Google web development
 
Google web code
Google web codeGoogle web code
Google web code
 
Google web 2.0
Google web 2.0Google web 2.0
Google web 2.0
 
Google sites development
Google sites developmentGoogle sites development
Google sites development
 
Google site development
Google site developmentGoogle site development
Google site development
 
Google development
Google developmentGoogle development
Google development
 
Google apps reseller
Google apps resellerGoogle apps reseller
Google apps reseller
 
Google apps development
Google apps developmentGoogle apps development
Google apps development
 
Google appps
Google apppsGoogle appps
Google appps
 
Google appengine
Google appengineGoogle appengine
Google appengine
 
Google appengine apps
Google appengine appsGoogle appengine apps
Google appengine apps
 

Recently uploaded

“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
Edge AI and Vision Alliance
 
Introduction of Cybersecurity with OSS at Code Europe 2024
Introduction of Cybersecurity with OSS  at Code Europe 2024Introduction of Cybersecurity with OSS  at Code Europe 2024
Introduction of Cybersecurity with OSS at Code Europe 2024
Hiroshi SHIBATA
 
UI5 Controls simplified - UI5con2024 presentation
UI5 Controls simplified - UI5con2024 presentationUI5 Controls simplified - UI5con2024 presentation
UI5 Controls simplified - UI5con2024 presentation
Wouter Lemaire
 
Presentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of GermanyPresentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of Germany
innovationoecd
 
Taking AI to the Next Level in Manufacturing.pdf
Taking AI to the Next Level in Manufacturing.pdfTaking AI to the Next Level in Manufacturing.pdf
Taking AI to the Next Level in Manufacturing.pdf
ssuserfac0301
 
Ocean lotus Threat actors project by John Sitima 2024 (1).pptx
Ocean lotus Threat actors project by John Sitima 2024 (1).pptxOcean lotus Threat actors project by John Sitima 2024 (1).pptx
Ocean lotus Threat actors project by John Sitima 2024 (1).pptx
SitimaJohn
 
How to use Firebase Data Connect For Flutter
How to use Firebase Data Connect For FlutterHow to use Firebase Data Connect For Flutter
How to use Firebase Data Connect For Flutter
Daiki Mogmet Ito
 
OpenID AuthZEN Interop Read Out - Authorization
OpenID AuthZEN Interop Read Out - AuthorizationOpenID AuthZEN Interop Read Out - Authorization
OpenID AuthZEN Interop Read Out - Authorization
David Brossard
 
Mariano G Tinti - Decoding SpaceX
Mariano G Tinti - Decoding SpaceXMariano G Tinti - Decoding SpaceX
Mariano G Tinti - Decoding SpaceX
Mariano Tinti
 
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
名前 です男
 
How to Get CNIC Information System with Paksim Ga.pptx
How to Get CNIC Information System with Paksim Ga.pptxHow to Get CNIC Information System with Paksim Ga.pptx
How to Get CNIC Information System with Paksim Ga.pptx
danishmna97
 
Choosing The Best AWS Service For Your Website + API.pptx
Choosing The Best AWS Service For Your Website + API.pptxChoosing The Best AWS Service For Your Website + API.pptx
Choosing The Best AWS Service For Your Website + API.pptx
Brandon Minnick, MBA
 
Your One-Stop Shop for Python Success: Top 10 US Python Development Providers
Your One-Stop Shop for Python Success: Top 10 US Python Development ProvidersYour One-Stop Shop for Python Success: Top 10 US Python Development Providers
Your One-Stop Shop for Python Success: Top 10 US Python Development Providers
akankshawande
 
Recommendation System using RAG Architecture
Recommendation System using RAG ArchitectureRecommendation System using RAG Architecture
Recommendation System using RAG Architecture
fredae14
 
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
saastr
 
WeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation TechniquesWeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation Techniques
Postman
 
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy SurveyTrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc
 
Project Management Semester Long Project - Acuity
Project Management Semester Long Project - AcuityProject Management Semester Long Project - Acuity
Project Management Semester Long Project - Acuity
jpupo2018
 
UiPath Test Automation using UiPath Test Suite series, part 6
UiPath Test Automation using UiPath Test Suite series, part 6UiPath Test Automation using UiPath Test Suite series, part 6
UiPath Test Automation using UiPath Test Suite series, part 6
DianaGray10
 
Programming Foundation Models with DSPy - Meetup Slides
Programming Foundation Models with DSPy - Meetup SlidesProgramming Foundation Models with DSPy - Meetup Slides
Programming Foundation Models with DSPy - Meetup Slides
Zilliz
 

Recently uploaded (20)

“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
“Building and Scaling AI Applications with the Nx AI Manager,” a Presentation...
 
Introduction of Cybersecurity with OSS at Code Europe 2024
Introduction of Cybersecurity with OSS  at Code Europe 2024Introduction of Cybersecurity with OSS  at Code Europe 2024
Introduction of Cybersecurity with OSS at Code Europe 2024
 
UI5 Controls simplified - UI5con2024 presentation
UI5 Controls simplified - UI5con2024 presentationUI5 Controls simplified - UI5con2024 presentation
UI5 Controls simplified - UI5con2024 presentation
 
Presentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of GermanyPresentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of Germany
 
Taking AI to the Next Level in Manufacturing.pdf
Taking AI to the Next Level in Manufacturing.pdfTaking AI to the Next Level in Manufacturing.pdf
Taking AI to the Next Level in Manufacturing.pdf
 
Ocean lotus Threat actors project by John Sitima 2024 (1).pptx
Ocean lotus Threat actors project by John Sitima 2024 (1).pptxOcean lotus Threat actors project by John Sitima 2024 (1).pptx
Ocean lotus Threat actors project by John Sitima 2024 (1).pptx
 
How to use Firebase Data Connect For Flutter
How to use Firebase Data Connect For FlutterHow to use Firebase Data Connect For Flutter
How to use Firebase Data Connect For Flutter
 
OpenID AuthZEN Interop Read Out - Authorization
OpenID AuthZEN Interop Read Out - AuthorizationOpenID AuthZEN Interop Read Out - Authorization
OpenID AuthZEN Interop Read Out - Authorization
 
Mariano G Tinti - Decoding SpaceX
Mariano G Tinti - Decoding SpaceXMariano G Tinti - Decoding SpaceX
Mariano G Tinti - Decoding SpaceX
 
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
みなさんこんにちはこれ何文字まで入るの?40文字以下不可とか本当に意味わからないけどこれ限界文字数書いてないからマジでやばい文字数いけるんじゃないの?えこ...
 
How to Get CNIC Information System with Paksim Ga.pptx
How to Get CNIC Information System with Paksim Ga.pptxHow to Get CNIC Information System with Paksim Ga.pptx
How to Get CNIC Information System with Paksim Ga.pptx
 
Choosing The Best AWS Service For Your Website + API.pptx
Choosing The Best AWS Service For Your Website + API.pptxChoosing The Best AWS Service For Your Website + API.pptx
Choosing The Best AWS Service For Your Website + API.pptx
 
Your One-Stop Shop for Python Success: Top 10 US Python Development Providers
Your One-Stop Shop for Python Success: Top 10 US Python Development ProvidersYour One-Stop Shop for Python Success: Top 10 US Python Development Providers
Your One-Stop Shop for Python Success: Top 10 US Python Development Providers
 
Recommendation System using RAG Architecture
Recommendation System using RAG ArchitectureRecommendation System using RAG Architecture
Recommendation System using RAG Architecture
 
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
Deep Dive: AI-Powered Marketing to Get More Leads and Customers with HyperGro...
 
WeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation TechniquesWeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation Techniques
 
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy SurveyTrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy Survey
 
Project Management Semester Long Project - Acuity
Project Management Semester Long Project - AcuityProject Management Semester Long Project - Acuity
Project Management Semester Long Project - Acuity
 
UiPath Test Automation using UiPath Test Suite series, part 6
UiPath Test Automation using UiPath Test Suite series, part 6UiPath Test Automation using UiPath Test Suite series, part 6
UiPath Test Automation using UiPath Test Suite series, part 6
 
Programming Foundation Models with DSPy - Meetup Slides
Programming Foundation Models with DSPy - Meetup SlidesProgramming Foundation Models with DSPy - Meetup Slides
Programming Foundation Models with DSPy - Meetup Slides
 

Google app programming

  • 1. 8 rules to build web app on top of Google AppEngine effectively Lessons learned www.comvai.com
  • 2. Google App Engine • Keep in mind Google AppEngine supports subset of Java EE specifications. Check at http://code.google.com/p/googleappengine/wiki/W www.comvai.com
  • 3. 1. Design Data model as simple as possible • The App Engine Datastore is not traditional relational SQL database and there are several important differences. • AppEngine datastore is schemaless. Entities of the same kind can have different properties. The application itself is responsible for ensuring that entities conform to it. • If you want to migrate your existing data model to App Engine you will probably need it to redesign. • Data-model consistency will be split to the data-model and application. • Check app engine datastore limitations to understand it. It gives you better overview regarding your future data-model design. http://code.google.com/appengine/articles/datastore/overview.html www.comvai.com
  • 4. How to • Use recommended High Replication Datastore HRD. • Use Objectify with JPA annotations over built-in JPA or JDO. • Prefer to use unowned relationships between entities. • Forget about count entities over filtered query result. Design your UI so that count is not being required. • If you need statistic calculations, do it on entity update. • Note: Building data model on top of built-in either JPA or JDO doesn't guarantee that application will be vendor independent because of different behavior of AppEngine datastore in some cases. Even it doesn't mean that's not possible to do so just requires understanding of AppEngine datastore behavior. www.comvai.com
  • 5. 2. Handle your data model via non default version of your GAE app • The AppEngine allows you to deploy more than one non default version of your application. Deploy specifically designed application to perform update of your data model only as a non default version to be independent from your main application release cycle. www.comvai.com
  • 6. 3. Price shields tips • Use Appstats out of the box tool to detect datastore bottleneck. Just plug in. It helps you to find the hidden unnecessary datastore operations that are dragging you down. • Use memcache. Datastore operations costs money and caching of "static" data could save you from using unnecessary datastore operations. • Use as many static files as possible. Static files are handled with high performance static front-end servers (CDN) which are highly optimized for this type of content. • See more http://www.gregtracy.com/revisiting-google-app-engines-pricing-changes www.comvai.com
  • 7. 4. Improve cold startup time • AppEngine instances starts quite often thus cold startup time (known as well as warmup request, loading request) is more important than in traditional Java EE application. Good startup time improves user experience. • Minimize number of your application java library dependencies as much as possible. Make sure if all your libs are really needed. Otherwise it will slow your cold startup time down. • Don't use JSP if you are already using another Frontend framework • Using JSPs will add additional libraries into your lib directory that are used for processing of JSP. http://www.listry.com/blog/2010/03/google-app-engine-cold-start-tip-dont • Use Objectify over built-in JPA or JDO. http://www.listry.com/blog/2010/03/google-app-engine-cold-start-guide-for www.comvai.com
  • 8. 5. Prefer Google Guice as DI framework • It's simple, small in size and powerful library and you probably won't need more. www.comvai.com
  • 9. 6. Use GWT for your desktop like web app • GWT together with GAE offers lot of built-in technics to improve your web app performance. Built-in features coming as advice from the book High Performance Web Sites. • It's better to have only one framework for the UI even it means to build some components yourself. Among other things it means less dependencies and simplified upgrade process. www.comvai.com
  • 10. How to GWT • Use built-in optimization technics with help of GWT's ClientBundles. • ClientBundles and ImageResource makes using images more efficient. • CssResource for CSS minification, CSS image strips and much more, see docs for ClientBundles (DataResource, TextResource, ExternalTextResource). • Switch on minification and obfuscation of the Java-JavaScript compiler. www.comvai.com
  • 11. How to GAE • Content Delivery Network CDN • Gzip compression • Memcache www.comvai.com
  • 12. 7. Use GWT MVP pattern • It's not easy to work with but worth of time. GWT has built-in support for MVP pattern. www.comvai.com
  • 13. Benefits • Well suited for large scale application. • Separation of functionality into components. Helps simplify UI unit testing. • Built-in browser history management. MVP is not concerned with browser history management, but Activities and Places may be used very well with MVP development. • Built-in event bus as a central point for app events. • Caching all of your code books via GWT event bus as a central pipe to go to the backend. www.comvai.com
  • 14. 8. Use Apache Wicket for website • The component based web framework. Version 1.5 or higher optimized for Google AppEngine • In Java ecosystem there is a lot of front-end frameworks thus to choose the right one depends on many varying factors. We like Apache Wicket because it's Java, feature rich component-oriented framework with good API. As version 1.5 it very well operates on App Engine. So it's up to you and your requirements but ones Apache Wicket is good fit for you we recommend it. • Add wicketstuff-gae-initializer dependency along side with wicket core dependencies • Alternative Play framework as it has specific module for App Engine. www.comvai.com
  • 15. Visit http://www.comvai.com/google-app-engine-development and register yourself to get development of your Google AppEngine project's Proof of Concept for free. • Validate suitability of your project to be built on top of Google App Engine. www.comvai.com