Data Model
The main elements of Google Wave’s data model are:
Wave – Each wave has a globally unique wave ID and consists of a set of wavelets.
Wavelet – A wavelet has an ID that is unique within its containing wave and is composed of a participant list and a set of documents. The wavelet is the entity to which Concurrency Control / Operational Transformations apply.
Participant – A participant is identified by a wave address, which is a text string in the same format as an email address (local-part@domain). A participant may be a user, a group or a robot. Each participant may occur at most once in the participant list.
Document – A document has an ID that is unique within its containing wavelet and is composed of an XML document and a set of “stand-off” annotations. Stand-off annotations are pointers into the XML document and are independent of the XML document structure. They are used to represent text formatting, spelling suggestions and hyper-links. Documents form a tree within the wavelet.
Wave View – A wave view is the subset of wavelets in a wave that a particular user has access to. A user gains access to a wavelet either by being a participant on the wavelet or by being a member of a group that is a participant (groups may be nested).
Operational Transformation
The operational transformation is an integral part of wave. Any wave which is being edited shows up to all users currently under a wave. Users can see in real time what the others are typing and also the server is notified of the changes being happening wait for the server to accept changes. It is cached in case of latency. After the server replies all the actions are carried out in bulk. operations are carried out in a character basis to the server as well as to all the clients unless it involves large scale data manipulation like the upload of images or playing music. All XML documents which are exchanged between the client and the server carry a checksum which helps in the rapid identification of erroneous communications.
Client-Server Protocol
Operations. Wavelets, the basic component of a wave, go through a series of changes called operational transformations. These changes need to be propagated and applied to each client otherwise a client gets out of sync.
Operation Sequencing. All operations applied to wavelets are sent in strict order. An operation is not sent until the server has responded to the previous one. The server orders the operations based on a version number. Each client needs to apply the operations respecting the proper order.
Opening a wavelet. To start communicating on a wavelet, a client sends an Open Request containing the Wave ID and the Wavelet ID to the server. The server responds with a snapshot – the serialized state of the wavelet – or a history hash of the corresponding version.
Server-client Communication. The server sends to the client one of the following: a delta (a sequence of one or more operations), a version number or a history hash.
Client-server Communication. The client sends: a delta or a version number.
Recovery. When the communication fails, the clients starts by reopening the servlet by sending a history of hashes previously received from the server.

Iamatechie was awarded as one of the 

Spring Source dmServer is a completely modular, OSGi-based Java server which is designed to run Java based applications and applications which are powered by Spring. dmServer provides flexibility and reliability in handling such applications. a diagram explaining the dmServer is given below.
Speaking of Goolge Wave it offers the functionality of an email program , instant messenger ,a collaborative document sharing and editing tool. The concepts aren’t new just that the many existing concepts have been married together to create a new experience.In Goolge wave anyone can be part of wave and people could be added to an existing wave . Any part of the wave could be edited by anyone within the wave.

Microsoft’s Azure Services Platform is a cloud platform aimed at delivering cloud computing services and a whole range of computing solutions based on cloud computing.This a significant step by Microsoft in the field of cloud computing following Microsoft’s online services.Azure Services Platform is an application platform which is part of the cloud that allows applications to be hosted and run at Microsoft datacenters cross various locations. It provides a cloud operating system called Windows Azure that serves as a runtime for the applications and provides a set of services that allows development, management and hosting of managed applications off-premises and on-premises. All Azure Services and applications built using them run on top of Windows Azure.
Recent Comments