SlideShare a Scribd company logo
Easy ORM-ness with Objectify-Appengine Meetu Maltiar Inphina Technologies
Overall Presentation Goal Google Datastore Basics Options available for managing persistence Objectify-Appengine Demo of an application using Objectify
Enough About Me Senior Software Engineer at Inphina Technologies that interest me:      Cloud Computing      Scala      Hadoop
Datastore Basics Entities Operations Keys Transactions
Entities An Entity is an object’s worth of data in the datastore In datastore an Entity is like HashMap-like object of type Entity  Datastore is conceptually a HashMap of keys to entities, and an Entity is conceptually a HashMap of name/value pairs
Operations Get() an entity as a whole from datastore Put() an entity as whole in datastore Delete() an entity from datastore Query() for entities matching criteria you define
Keys In the datastore, entities are identified by the id (or name) and a kind, which corresponds to the type of Object you are storing.  So, to get Employee #111 from datastore, we need to call something like get_from_datastore (“Employee”, 111)
Keys Continued There is actually a third parameter required to identify an entity and it is called parent Parent places the child in the same entity group as the parent Parent (which can be null for the un-parented, root entity) is also required to uniquely identify an Entity.
Keys Continued So, to get Employee #111 from datastore we need to call something equivalent to: get_from_datastore (“Employee”, 111, null) or, get_from_datastore (“Employee”, 111, the_parent).  Instead of passing three parameters datastore wraps it in a single Object called Key.
Transactions Data gets stored in gigantic form of thousands of machines In order to perform an atomic transaction datastore requires that entities lie on same servers. To give us more control over where our data is stored, the datastore has a concept of an entity group To give us more control over where our data is stored, the datastore has a concept of an entity group
Transactions Continued Within a Transaction we can access data from a single entity group Choose entity groups carefully Why not have everything in a single entity group? Google restricts number of requests per second per entity group
Executing Transactions When we execute get(), put(), delete() or query() in transaction We must operate it on single entity group All operations will either fail or succeed completely If another process modifies the data before commit datastore operation will fail
Tools
Persistence Options JPA/JDO Google Datastore Persistence Frameworks on GAE   Objectify-Appengine   Twig   Simple Datastore   Slim3
Google Datastore Challenges Supports just four operations It persists GAE-Specific entity classes rather than POJO’s Datastore Keys are untyped
JPA/JDO Challenges Extra Cruft Fetch Groups    Detaching    Owned/Unownedrelationships Leaky Abstraction Keys    Entity Groups    Indexes
Developers Dilemma
Objectify It lets you persist, retrieve, delete and query typed objects All native datastore features are supported It provides type safe key and query classes
Objectify Design Considerations Minimally impacts cold start time. It is light weight No external dependencies apart from GAE SDK
Working With Datastore Entity ent = new Entity(“car”); ent.setProperty(“color”, “red”); ent.setProperty(“doors”, 2); service.put(ent);
Objectify ORMNess Objects! Employee emp = new Employee(); emp.setFirstName(“John”); emp.setLastName(“Smith”); service.put(emp);
An Objectify Entity public class Employee {   @Id Long id;    private String firstName;    private String lastName; }
get() Operation Objectify ofy = Objectifyservice.begin(); Employee emp = ofy.get(Employee.class, 123); Map<Long, Employee> employees =  ofy.get(Employee.class, 123, 124, 125);
put() Operation Objectify ofy = Objectifyservice.begin(); Employee emp = new Employee(“John”, “adams”); ofy.put(emp); System.out.println(“Id Generated is ” + emp.getId()); List<Employee> employees = createEmployees(); ofy.put(employees);
delete() Operation Objectify ofy = Objectifyservice.begin(); ofy.delete(Employee.class, 123); Employee emp = // get Employee from some where ofy.delete(emp);
query() Operation Objectify ofy = Objectifyservice.begin(); List<Employee> employees =        ofy.query(Employee.class).filter(“firstName =”, “John”)
Demo     get()     put()     delete()     query()
Objectify Best Practices Use a DAO to register entities Automatic Scanning not advised adds to initialization time     will require dependency jars apart from GAE     will require changes in web.xml GAE spins down the instance when not in use. When it comes up the request is slow because of added initialization time. This is called cold start.
Objectify Best Practices … Use Batch Gets Instead of Queries Use Indexes sparingly By default every field of object will be indexed. It comes with heavy computational price. Use @Unindexed  on entity level and @Indexed at fields required for query Avoid @Parent In JPA “owned” entity relationship provides referential integrity checking and cascading deletes and saves. Not so here.
Happy Developer
Conclusion JDO/JPA learning curve is steep due to App Engine’s non-relational nature and unique concepts such as entity groups, owned and un-owned relationships. Google Datastore is low level. It makes no pretense of being relational but also does not allow working with objects. It just stores the objects of type com.google.appengine.api.datastore.Entity Objectify is light weight and it preserves the simplicity and transparency of low level API and does all work converting to and from POJOS to Entity Objects.
mmaltiar@inphina.com www.inphina.com http://thoughts.inphina.com
References Objectify-Appengine http://code.google.com/p/objectify-appengine/ Google IO 2011 Session on highly productive gwt rapid development with app-engine objectify-requestfactory and gwt-platform Twitter mining with Objectify-Appengine http://www.ibm.com/developerworks/java/library/j-javadev2-14/?ca=drs-

More Related Content

What's hot

Certification preparation - Error Handling and Troubleshooting recap.pptx
Certification preparation - Error Handling and Troubleshooting recap.pptxCertification preparation - Error Handling and Troubleshooting recap.pptx
Certification preparation - Error Handling and Troubleshooting recap.pptx
Rohit Radhakrishnan
 
Testing database content with DBUnit. My experience.
Testing database content with DBUnit. My experience.Testing database content with DBUnit. My experience.
Testing database content with DBUnit. My experience.
Serhii Kartashov
 
hibernate with JPA
hibernate with JPAhibernate with JPA
hibernate with JPA
Mohammad Faizan
 
Intro To Hibernate
Intro To HibernateIntro To Hibernate
Intro To Hibernate
Amit Himani
 
Entity Persistence with JPA
Entity Persistence with JPAEntity Persistence with JPA
Entity Persistence with JPA
Subin Sugunan
 
Object identification and its management
Object identification and its managementObject identification and its management
Object identification and its management
Vinay Kumar Pulabaigari
 
ERRest in Depth
ERRest in DepthERRest in Depth
ERRest in Depth
WO Community
 
Introduction to JPA and Hibernate including examples
Introduction to JPA and Hibernate including examplesIntroduction to JPA and Hibernate including examples
Introduction to JPA and Hibernate including examples
ecosio GmbH
 
ERRest
ERRestERRest
ERRest
WO Community
 
Introduction to hibernate
Introduction to hibernateIntroduction to hibernate
Introduction to hibernate
hr1383
 
Jpa 2.1 Application Development
Jpa 2.1 Application DevelopmentJpa 2.1 Application Development
Jpa 2.1 Application Development
ThirupathiReddy Vajjala
 
Hibernate complete Training
Hibernate complete TrainingHibernate complete Training
Hibernate complete Training
sourabh aggarwal
 
JPA Best Practices
JPA Best PracticesJPA Best Practices
JPA Best Practices
Carol McDonald
 
ERRest - Designing a good REST service
ERRest - Designing a good REST serviceERRest - Designing a good REST service
ERRest - Designing a good REST service
WO Community
 
Introduction to Hibernate Framework
Introduction to Hibernate FrameworkIntroduction to Hibernate Framework
Introduction to Hibernate Framework
Raveendra R
 
Hibernate
HibernateHibernate
Spring data jpa
Spring data jpaSpring data jpa
Spring data jpa
Jeevesh Pandey
 
Hibernate training mumbai_hql
Hibernate training mumbai_hqlHibernate training mumbai_hql
Hibernate training mumbai_hql
vibrantuser
 
JPA 2.1 performance tuning tips
JPA 2.1 performance tuning tipsJPA 2.1 performance tuning tips
JPA 2.1 performance tuning tips
osa_ora
 

What's hot (19)

Certification preparation - Error Handling and Troubleshooting recap.pptx
Certification preparation - Error Handling and Troubleshooting recap.pptxCertification preparation - Error Handling and Troubleshooting recap.pptx
Certification preparation - Error Handling and Troubleshooting recap.pptx
 
Testing database content with DBUnit. My experience.
Testing database content with DBUnit. My experience.Testing database content with DBUnit. My experience.
Testing database content with DBUnit. My experience.
 
hibernate with JPA
hibernate with JPAhibernate with JPA
hibernate with JPA
 
Intro To Hibernate
Intro To HibernateIntro To Hibernate
Intro To Hibernate
 
Entity Persistence with JPA
Entity Persistence with JPAEntity Persistence with JPA
Entity Persistence with JPA
 
Object identification and its management
Object identification and its managementObject identification and its management
Object identification and its management
 
ERRest in Depth
ERRest in DepthERRest in Depth
ERRest in Depth
 
Introduction to JPA and Hibernate including examples
Introduction to JPA and Hibernate including examplesIntroduction to JPA and Hibernate including examples
Introduction to JPA and Hibernate including examples
 
ERRest
ERRestERRest
ERRest
 
Introduction to hibernate
Introduction to hibernateIntroduction to hibernate
Introduction to hibernate
 
Jpa 2.1 Application Development
Jpa 2.1 Application DevelopmentJpa 2.1 Application Development
Jpa 2.1 Application Development
 
Hibernate complete Training
Hibernate complete TrainingHibernate complete Training
Hibernate complete Training
 
JPA Best Practices
JPA Best PracticesJPA Best Practices
JPA Best Practices
 
ERRest - Designing a good REST service
ERRest - Designing a good REST serviceERRest - Designing a good REST service
ERRest - Designing a good REST service
 
Introduction to Hibernate Framework
Introduction to Hibernate FrameworkIntroduction to Hibernate Framework
Introduction to Hibernate Framework
 
Hibernate
HibernateHibernate
Hibernate
 
Spring data jpa
Spring data jpaSpring data jpa
Spring data jpa
 
Hibernate training mumbai_hql
Hibernate training mumbai_hqlHibernate training mumbai_hql
Hibernate training mumbai_hql
 
JPA 2.1 performance tuning tips
JPA 2.1 performance tuning tipsJPA 2.1 performance tuning tips
JPA 2.1 performance tuning tips
 

Viewers also liked

Introducing scala
Introducing scalaIntroducing scala
Introducing scala
Meetu Maltiar
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
Meetu Maltiar
 
Fitnesse With Scala
Fitnesse With ScalaFitnesse With Scala
Fitnesse With Scala
Meetu Maltiar
 
Akka 2.0 Reloaded
Akka 2.0 ReloadedAkka 2.0 Reloaded
Akka 2.0 Reloaded
Meetu Maltiar
 
Data structures in scala
Data structures in scalaData structures in scala
Data structures in scala
Meetu Maltiar
 
Scala categorytheory
Scala categorytheoryScala categorytheory
Scala categorytheory
Meetu Maltiar
 
Scala Collections
Scala CollectionsScala Collections
Scala Collections
Meetu Maltiar
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
Meetu Maltiar
 
Introducing Akka
Introducing AkkaIntroducing Akka
Introducing Akka
Meetu Maltiar
 

Viewers also liked (9)

Introducing scala
Introducing scalaIntroducing scala
Introducing scala
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
 
Fitnesse With Scala
Fitnesse With ScalaFitnesse With Scala
Fitnesse With Scala
 
Akka 2.0 Reloaded
Akka 2.0 ReloadedAkka 2.0 Reloaded
Akka 2.0 Reloaded
 
Data structures in scala
Data structures in scalaData structures in scala
Data structures in scala
 
Scala categorytheory
Scala categorytheoryScala categorytheory
Scala categorytheory
 
Scala Collections
Scala CollectionsScala Collections
Scala Collections
 
Getting Started With Scala
Getting Started With ScalaGetting Started With Scala
Getting Started With Scala
 
Introducing Akka
Introducing AkkaIntroducing Akka
Introducing Akka
 

Similar to Easy ORMness with Objectify-Appengine

Java Web Programming on Google Cloud Platform [2/3] : Datastore
Java Web Programming on Google Cloud Platform [2/3] : DatastoreJava Web Programming on Google Cloud Platform [2/3] : Datastore
Java Web Programming on Google Cloud Platform [2/3] : Datastore
IMC Institute
 
S03 hybrid app_and_gae_datastore_v1.0
S03 hybrid app_and_gae_datastore_v1.0S03 hybrid app_and_gae_datastore_v1.0
S03 hybrid app_and_gae_datastore_v1.0
Sun-Jin Jang
 
JavaOne 2007 - TS4721
JavaOne 2007 - TS4721 JavaOne 2007 - TS4721
JavaOne 2007 - TS4721
Edgar Silva
 
Java Enterprise Performance - Unburdended Applications
Java Enterprise Performance - Unburdended ApplicationsJava Enterprise Performance - Unburdended Applications
Java Enterprise Performance - Unburdended Applications
Lucas Jellema
 
The 90-Day Startup with Google AppEngine for Java
The 90-Day Startup with Google AppEngine for JavaThe 90-Day Startup with Google AppEngine for Java
The 90-Day Startup with Google AppEngine for Java
David Chandler
 
Spring data requery
Spring data requerySpring data requery
Spring data requery
Sunghyouk Bae
 
Spring Data JPA in detail with spring boot
Spring Data JPA in detail with spring bootSpring Data JPA in detail with spring boot
Spring Data JPA in detail with spring boot
rinky1234
 
Struts2
Struts2Struts2
PHP Barcelona 2010 - Architecture and testability
PHP Barcelona 2010 - Architecture and testabilityPHP Barcelona 2010 - Architecture and testability
PHP Barcelona 2010 - Architecture and testability
Giorgio Sironi
 
PyCon India 2010 Building Scalable apps using appengine
PyCon India 2010 Building Scalable apps using appenginePyCon India 2010 Building Scalable apps using appengine
PyCon India 2010 Building Scalable apps using appengine
Pranav Prakash
 
SPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
SPCA2013 - SharePoint Nightmares - Coding Patterns and PracticesSPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
SPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
NCCOMMS
 
Django design-patterns
Django design-patternsDjango design-patterns
Django design-patterns
Agiliq Info Solutions India Pvt Ltd
 
Performance Tuning of .NET Application
Performance Tuning of .NET ApplicationPerformance Tuning of .NET Application
Performance Tuning of .NET Application
Mainul Islam, CSM®
 
ORM JPA
ORM JPAORM JPA
Wcf data services
Wcf data servicesWcf data services
Wcf data services
Eyal Vardi
 
Data Seeding via Parameterized API Requests
Data Seeding via Parameterized API RequestsData Seeding via Parameterized API Requests
Data Seeding via Parameterized API Requests
RapidValue
 
Spring Data JPA USE FOR CREATING DATA JPA
Spring Data JPA USE FOR CREATING DATA  JPASpring Data JPA USE FOR CREATING DATA  JPA
Spring Data JPA USE FOR CREATING DATA JPA
michaelaaron25322
 
Deferred Processing in Ruby - Philly rb - August 2011
Deferred Processing in Ruby - Philly rb - August 2011Deferred Processing in Ruby - Philly rb - August 2011
Deferred Processing in Ruby - Philly rb - August 2011
rob_dimarco
 
Dapper performance
Dapper performanceDapper performance
Dapper performance
Suresh Loganatha
 
Introducing Struts 2
Introducing Struts 2Introducing Struts 2
Introducing Struts 2
wiradikusuma
 

Similar to Easy ORMness with Objectify-Appengine (20)

Java Web Programming on Google Cloud Platform [2/3] : Datastore
Java Web Programming on Google Cloud Platform [2/3] : DatastoreJava Web Programming on Google Cloud Platform [2/3] : Datastore
Java Web Programming on Google Cloud Platform [2/3] : Datastore
 
S03 hybrid app_and_gae_datastore_v1.0
S03 hybrid app_and_gae_datastore_v1.0S03 hybrid app_and_gae_datastore_v1.0
S03 hybrid app_and_gae_datastore_v1.0
 
JavaOne 2007 - TS4721
JavaOne 2007 - TS4721 JavaOne 2007 - TS4721
JavaOne 2007 - TS4721
 
Java Enterprise Performance - Unburdended Applications
Java Enterprise Performance - Unburdended ApplicationsJava Enterprise Performance - Unburdended Applications
Java Enterprise Performance - Unburdended Applications
 
The 90-Day Startup with Google AppEngine for Java
The 90-Day Startup with Google AppEngine for JavaThe 90-Day Startup with Google AppEngine for Java
The 90-Day Startup with Google AppEngine for Java
 
Spring data requery
Spring data requerySpring data requery
Spring data requery
 
Spring Data JPA in detail with spring boot
Spring Data JPA in detail with spring bootSpring Data JPA in detail with spring boot
Spring Data JPA in detail with spring boot
 
Struts2
Struts2Struts2
Struts2
 
PHP Barcelona 2010 - Architecture and testability
PHP Barcelona 2010 - Architecture and testabilityPHP Barcelona 2010 - Architecture and testability
PHP Barcelona 2010 - Architecture and testability
 
PyCon India 2010 Building Scalable apps using appengine
PyCon India 2010 Building Scalable apps using appenginePyCon India 2010 Building Scalable apps using appengine
PyCon India 2010 Building Scalable apps using appengine
 
SPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
SPCA2013 - SharePoint Nightmares - Coding Patterns and PracticesSPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
SPCA2013 - SharePoint Nightmares - Coding Patterns and Practices
 
Django design-patterns
Django design-patternsDjango design-patterns
Django design-patterns
 
Performance Tuning of .NET Application
Performance Tuning of .NET ApplicationPerformance Tuning of .NET Application
Performance Tuning of .NET Application
 
ORM JPA
ORM JPAORM JPA
ORM JPA
 
Wcf data services
Wcf data servicesWcf data services
Wcf data services
 
Data Seeding via Parameterized API Requests
Data Seeding via Parameterized API RequestsData Seeding via Parameterized API Requests
Data Seeding via Parameterized API Requests
 
Spring Data JPA USE FOR CREATING DATA JPA
Spring Data JPA USE FOR CREATING DATA  JPASpring Data JPA USE FOR CREATING DATA  JPA
Spring Data JPA USE FOR CREATING DATA JPA
 
Deferred Processing in Ruby - Philly rb - August 2011
Deferred Processing in Ruby - Philly rb - August 2011Deferred Processing in Ruby - Philly rb - August 2011
Deferred Processing in Ruby - Philly rb - August 2011
 
Dapper performance
Dapper performanceDapper performance
Dapper performance
 
Introducing Struts 2
Introducing Struts 2Introducing Struts 2
Introducing Struts 2
 

Recently uploaded

Dandelion Hashtable: beyond billion requests per second on a commodity server
Dandelion Hashtable: beyond billion requests per second on a commodity serverDandelion Hashtable: beyond billion requests per second on a commodity server
Dandelion Hashtable: beyond billion requests per second on a commodity server
Antonios Katsarakis
 
AWS Cloud Cost Optimization Presentation.pptx
AWS Cloud Cost Optimization Presentation.pptxAWS Cloud Cost Optimization Presentation.pptx
AWS Cloud Cost Optimization Presentation.pptx
HarisZaheer8
 
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
 
dbms calicut university B. sc Cs 4th sem.pdf
dbms  calicut university B. sc Cs 4th sem.pdfdbms  calicut university B. sc Cs 4th sem.pdf
dbms calicut university B. sc Cs 4th sem.pdf
Shinana2
 
Generating privacy-protected synthetic data using Secludy and Milvus
Generating privacy-protected synthetic data using Secludy and MilvusGenerating privacy-protected synthetic data using Secludy and Milvus
Generating privacy-protected synthetic data using Secludy and Milvus
Zilliz
 
FREE A4 Cyber Security Awareness Posters-Social Engineering part 3
FREE A4 Cyber Security Awareness  Posters-Social Engineering part 3FREE A4 Cyber Security Awareness  Posters-Social Engineering part 3
FREE A4 Cyber Security Awareness Posters-Social Engineering part 3
Data Hops
 
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
 
5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides
DanBrown980551
 
June Patch Tuesday
June Patch TuesdayJune Patch Tuesday
June Patch Tuesday
Ivanti
 
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
alexjohnson7307
 
Fueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte WebinarFueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte Webinar
Zilliz
 
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdfHow to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
Chart Kalyan
 
WeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation TechniquesWeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation Techniques
Postman
 
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-EfficiencyFreshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
ScyllaDB
 
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
 
Building Production Ready Search Pipelines with Spark and Milvus
Building Production Ready Search Pipelines with Spark and MilvusBuilding Production Ready Search Pipelines with Spark and Milvus
Building Production Ready Search Pipelines with Spark and Milvus
Zilliz
 
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
Alex Pruden
 
Columbus Data & Analytics Wednesdays - June 2024
Columbus Data & Analytics Wednesdays - June 2024Columbus Data & Analytics Wednesdays - June 2024
Columbus Data & Analytics Wednesdays - June 2024
Jason Packer
 
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
 
SAP S/4 HANA sourcing and procurement to Public cloud
SAP S/4 HANA sourcing and procurement to Public cloudSAP S/4 HANA sourcing and procurement to Public cloud
SAP S/4 HANA sourcing and procurement to Public cloud
maazsz111
 

Recently uploaded (20)

Dandelion Hashtable: beyond billion requests per second on a commodity server
Dandelion Hashtable: beyond billion requests per second on a commodity serverDandelion Hashtable: beyond billion requests per second on a commodity server
Dandelion Hashtable: beyond billion requests per second on a commodity server
 
AWS Cloud Cost Optimization Presentation.pptx
AWS Cloud Cost Optimization Presentation.pptxAWS Cloud Cost Optimization Presentation.pptx
AWS Cloud Cost Optimization Presentation.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
 
dbms calicut university B. sc Cs 4th sem.pdf
dbms  calicut university B. sc Cs 4th sem.pdfdbms  calicut university B. sc Cs 4th sem.pdf
dbms calicut university B. sc Cs 4th sem.pdf
 
Generating privacy-protected synthetic data using Secludy and Milvus
Generating privacy-protected synthetic data using Secludy and MilvusGenerating privacy-protected synthetic data using Secludy and Milvus
Generating privacy-protected synthetic data using Secludy and Milvus
 
FREE A4 Cyber Security Awareness Posters-Social Engineering part 3
FREE A4 Cyber Security Awareness  Posters-Social Engineering part 3FREE A4 Cyber Security Awareness  Posters-Social Engineering part 3
FREE A4 Cyber Security Awareness Posters-Social Engineering part 3
 
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
 
5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides
 
June Patch Tuesday
June Patch TuesdayJune Patch Tuesday
June Patch Tuesday
 
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
leewayhertz.com-AI in predictive maintenance Use cases technologies benefits ...
 
Fueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte WebinarFueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte Webinar
 
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdfHow to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
 
WeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation TechniquesWeTestAthens: Postman's AI & Automation Techniques
WeTestAthens: Postman's AI & Automation Techniques
 
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-EfficiencyFreshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
 
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...
 
Building Production Ready Search Pipelines with Spark and Milvus
Building Production Ready Search Pipelines with Spark and MilvusBuilding Production Ready Search Pipelines with Spark and Milvus
Building Production Ready Search Pipelines with Spark and Milvus
 
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
zkStudyClub - LatticeFold: A Lattice-based Folding Scheme and its Application...
 
Columbus Data & Analytics Wednesdays - June 2024
Columbus Data & Analytics Wednesdays - June 2024Columbus Data & Analytics Wednesdays - June 2024
Columbus Data & Analytics Wednesdays - June 2024
 
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
 
SAP S/4 HANA sourcing and procurement to Public cloud
SAP S/4 HANA sourcing and procurement to Public cloudSAP S/4 HANA sourcing and procurement to Public cloud
SAP S/4 HANA sourcing and procurement to Public cloud
 

Easy ORMness with Objectify-Appengine

  • 1. Easy ORM-ness with Objectify-Appengine Meetu Maltiar Inphina Technologies
  • 2. Overall Presentation Goal Google Datastore Basics Options available for managing persistence Objectify-Appengine Demo of an application using Objectify
  • 3. Enough About Me Senior Software Engineer at Inphina Technologies that interest me: Cloud Computing Scala Hadoop
  • 4. Datastore Basics Entities Operations Keys Transactions
  • 5. Entities An Entity is an object’s worth of data in the datastore In datastore an Entity is like HashMap-like object of type Entity Datastore is conceptually a HashMap of keys to entities, and an Entity is conceptually a HashMap of name/value pairs
  • 6. Operations Get() an entity as a whole from datastore Put() an entity as whole in datastore Delete() an entity from datastore Query() for entities matching criteria you define
  • 7. Keys In the datastore, entities are identified by the id (or name) and a kind, which corresponds to the type of Object you are storing. So, to get Employee #111 from datastore, we need to call something like get_from_datastore (“Employee”, 111)
  • 8. Keys Continued There is actually a third parameter required to identify an entity and it is called parent Parent places the child in the same entity group as the parent Parent (which can be null for the un-parented, root entity) is also required to uniquely identify an Entity.
  • 9. Keys Continued So, to get Employee #111 from datastore we need to call something equivalent to: get_from_datastore (“Employee”, 111, null) or, get_from_datastore (“Employee”, 111, the_parent). Instead of passing three parameters datastore wraps it in a single Object called Key.
  • 10. Transactions Data gets stored in gigantic form of thousands of machines In order to perform an atomic transaction datastore requires that entities lie on same servers. To give us more control over where our data is stored, the datastore has a concept of an entity group To give us more control over where our data is stored, the datastore has a concept of an entity group
  • 11. Transactions Continued Within a Transaction we can access data from a single entity group Choose entity groups carefully Why not have everything in a single entity group? Google restricts number of requests per second per entity group
  • 12. Executing Transactions When we execute get(), put(), delete() or query() in transaction We must operate it on single entity group All operations will either fail or succeed completely If another process modifies the data before commit datastore operation will fail
  • 13. Tools
  • 14. Persistence Options JPA/JDO Google Datastore Persistence Frameworks on GAE Objectify-Appengine Twig Simple Datastore Slim3
  • 15. Google Datastore Challenges Supports just four operations It persists GAE-Specific entity classes rather than POJO’s Datastore Keys are untyped
  • 16. JPA/JDO Challenges Extra Cruft Fetch Groups Detaching Owned/Unownedrelationships Leaky Abstraction Keys Entity Groups Indexes
  • 18. Objectify It lets you persist, retrieve, delete and query typed objects All native datastore features are supported It provides type safe key and query classes
  • 19. Objectify Design Considerations Minimally impacts cold start time. It is light weight No external dependencies apart from GAE SDK
  • 20. Working With Datastore Entity ent = new Entity(“car”); ent.setProperty(“color”, “red”); ent.setProperty(“doors”, 2); service.put(ent);
  • 21. Objectify ORMNess Objects! Employee emp = new Employee(); emp.setFirstName(“John”); emp.setLastName(“Smith”); service.put(emp);
  • 22. An Objectify Entity public class Employee { @Id Long id; private String firstName; private String lastName; }
  • 23. get() Operation Objectify ofy = Objectifyservice.begin(); Employee emp = ofy.get(Employee.class, 123); Map<Long, Employee> employees = ofy.get(Employee.class, 123, 124, 125);
  • 24. put() Operation Objectify ofy = Objectifyservice.begin(); Employee emp = new Employee(“John”, “adams”); ofy.put(emp); System.out.println(“Id Generated is ” + emp.getId()); List<Employee> employees = createEmployees(); ofy.put(employees);
  • 25. delete() Operation Objectify ofy = Objectifyservice.begin(); ofy.delete(Employee.class, 123); Employee emp = // get Employee from some where ofy.delete(emp);
  • 26. query() Operation Objectify ofy = Objectifyservice.begin(); List<Employee> employees = ofy.query(Employee.class).filter(“firstName =”, “John”)
  • 27. Demo get() put() delete() query()
  • 28. Objectify Best Practices Use a DAO to register entities Automatic Scanning not advised adds to initialization time will require dependency jars apart from GAE will require changes in web.xml GAE spins down the instance when not in use. When it comes up the request is slow because of added initialization time. This is called cold start.
  • 29. Objectify Best Practices … Use Batch Gets Instead of Queries Use Indexes sparingly By default every field of object will be indexed. It comes with heavy computational price. Use @Unindexed on entity level and @Indexed at fields required for query Avoid @Parent In JPA “owned” entity relationship provides referential integrity checking and cascading deletes and saves. Not so here.
  • 31. Conclusion JDO/JPA learning curve is steep due to App Engine’s non-relational nature and unique concepts such as entity groups, owned and un-owned relationships. Google Datastore is low level. It makes no pretense of being relational but also does not allow working with objects. It just stores the objects of type com.google.appengine.api.datastore.Entity Objectify is light weight and it preserves the simplicity and transparency of low level API and does all work converting to and from POJOS to Entity Objects.
  • 33. References Objectify-Appengine http://code.google.com/p/objectify-appengine/ Google IO 2011 Session on highly productive gwt rapid development with app-engine objectify-requestfactory and gwt-platform Twitter mining with Objectify-Appengine http://www.ibm.com/developerworks/java/library/j-javadev2-14/?ca=drs-