Astoria futures: offline-enabled data services

We mentioned that we were doing some early thinking of “Astoria Offline” back in Mix 2008, where we even demo’ed an early proof of concept. Now we’ve been working on various design aspects of Data Services for its future versions, and synchronization/offline support is one of them. It’s still an experimental thing with no official home or release vehicle, so this is the best time to follow the design process if you find the scenario interesting, as this is when it’s easiest to influence the direction we’ll go for.

A short way of describing this can be: “imagine you can point Visual Studio to a data service and say ‘take it offline’, and things just happen”.

Of course, the real world is more complicated than that :-)

Astoria Design Walkthrough: Thinking of a future with sync & offline

 

In this first note I’ll just touch on the scenarios we want to hit and go over a few guiding principles. In future posts I’ll elaborate more on the details.

We have many scenarios in mind for this infrastructure. The ones we’re thinking of tackling first:

· Outlook type of apps: I’m sure there is a fancier way of saying this, but anyone that has used Microsoft Outlook knows what I mean. The application is basically a 1-tier app that interacts with a local (embedded) database. In the background -and independent from UI activity- 2-way synchronization with a data service (e.g. a Microsoft Exchange server) happens. Often sync’ing against a database is not quite what you want…”Astoria Offline” will let you sync against your data-service layer, where the usual business logic/validation/etc will run just like in the online path.

· The description above sort of implies that server and client are built in collaboration, perhaps as part of the same development team. That’s certainly an scenario and we can do some things easier when that’s the case. But the other scenario we want to tackle is when client and server in a synchronization relationship are independent from each other (e.g. sync a service that’s just available for sync on the web).

· Local replicas of cloud-stored data: as more online services offer structured storage capabilities, and more of them use the Data Services REST interface, it becomes more interesting to be able to synchronize that data locally either for latency reduction, offline operation or other reasons.

· Data consolidation: if you have multiple data services that expose data from a variety of sources (some databases, some online/”cloud” stores, some custom repositories), you may want to synchronize a slice of data of each store to a local database, and then work with the data locally.

A couple of guiding principles:

· We will stick to a simple and open interface. What that means is that while we will definitely build a nice end-to-end integrated story for Visual Studio, it will be on top of a well-documented underlying data exchange using just HTTP and known formats. Anybody with an HTTP client and enough knowledge of our sync strategy should be able to synchronize with a data service.

· Data independence will remain there for sync as it is already for online access. Today when you access a data service the interface is the same regardless of whether the service is backed by a database, a cloud store, some custom application or whatever. With sync, the same applies. If the data service is sync-enabled you can sync with it, no matter what backs it.

· We are targeting data services for structured stores and business applications. That implies certain level of sophistication in the shape of data, such as assuming cross-item dependencies, store-level and application-level constraints that dictate consistent states of data, the need for making partial progress during synchronization, etc. Such support does come with some extra complexity, but we think it’s the right target.

We’re just taking on this space, so any feedback you may have is good. Are our initial scenarios interesting? Do you need this thing at all? Does the initial direction we’re looking at sound reasonable?

btw – if you are going to be at PDC, we have a full talk on this at the event.

I hope this “short video” format that Andy wants to do for our design notes adds a good little twist and makes them more interesting.

Pablo Castro
Software Architect
Microsoft Corporation
https://blogs.msdn.com/pablo

This post is part of the transparent design exercise in the Astoria Team. To understand how it works and how your feedback will be used please look at this post.

Comments

  • Anonymous
    October 22, 2008
    PingBack from http://blog.a-foton.ru/index.php/2008/10/23/astoria-futures-offline-enabled-data-services/
  • Anonymous
    October 23, 2008
    I definitely believe this is the right direction.  The shift to smart client technologies (WPF, silverlight, etc.) is going to demand sync/offline design models.  We have been deciding whether we wanted to tackle this development in a one-off scenario, and have decided against it due to time constraints and complexity.  I believe if you're team delivers a CTP in Q4 or early Q1, we may be in a position to start testing it in parallel with our development.
  • Anonymous
    October 23, 2008
    Tantalising post from the Astoria team.
  • Anonymous
    October 23, 2008
    The comment has been removed
  • Anonymous
    October 23, 2008
    Instead of a really really long comment in this post, I have blogged about our Scenario, Existing Architecture, and Project Requirements here:http://asheeshsoni.blogspot.com/2008/10/astoria-futures-offline-enabled-data.htmlThere is also a poll on the sort of clients that'll consume your Astoria Offline services.Feel free to discuss how you think your organization / applications could utilize Astoria Offline, and what features you look forward to in it.CheersAsheesh Soni
  • Anonymous
    October 26, 2008
    The comment has been removed
  • Anonymous
    October 27, 2008
    Sven: yes, our primary focus for the offline client storage is SQL Server Compact for devices and desktop scenarios, although we're also exploring having support for other options as well, such as SQL Server Express for the desktop case.Stories of what worked best in your applications are welcome, as it can help guide our decisions around this.-pablo
  • Anonymous
    October 27, 2008
    Pablo, thanks for answering. Unfortunately I have no stories to tell about what worked best. We're still in the planning stages when it comes to local data caching. In fact, we're still planning our move to Silverlight.The only thing I can offer is that the scenario where "server and client are built in collaboration, as part of the same development team" applies to us.And I think it will apply to many teams that are going to port their N-tiered Winforms apps to WPF/Silverlight + Astoria as we are. So if you have to postpone support for the other scenario "where client and server are independent" to V2, that would be acceptable, IMHO.-Sven
  • Anonymous
    October 27, 2008
    For very light weight applications (such as Windows Mobile) the choice to focus on CE is spot on. Unfortunatly, most applications (in my humble opinion) will focus on LAPTOP application development. Due to very limited nature of CE as a database (no t-sql, no views, stored procedures, no xml, no role based security) I would love to see focus put on the Express edition. This will allow for very robust client/database applications to be developed.
  • Anonymous
    October 28, 2008
    This sounds very much like an application we are developing at my company right now except that we were not able to use CE, we are using Sql Express 2008 and http merge replication from the desktop back to our server.  Compact edition does not support some of the features we use such as stored procedures and the new file stream data type.  I would like to see Sql Express supported as well as CE.
  • Anonymous
    October 28, 2008
    The comment has been removed
  • Anonymous
    October 29, 2008
    The comment has been removed
  • Anonymous
    October 30, 2008
    The comment has been removed
  • Anonymous
    November 03, 2008
    As we already discussed in a previous blog post , one of the problem spaces related to data services
  • Anonymous
    November 24, 2008
    Hi Pablo,Apart from having some client support for the sync framework (and the service side counterpart as well), are you planning to include feedsync extensions as part of the ATOM feed that can be get from the output of an existing ADO.NET service ?. This would be definitively good for using any technology that talks FeedSync on the other end.ThanksPablo.
  • Anonymous
    January 15, 2009
    I've given a number of presentations on ADO.NET Data Services (formerly codenamed: "Astoria")
  • Anonymous
    March 07, 2009
    In October of last year we started to talk publicly about an exploration project we called “Astoria