6 1 Introduction
serverwithout notification to clients unlessclients explicitly poll the server. Also, in
pull-basedmode, servers must be interrupted continuously to deal with requests from
clients. Furthermore, the information that clients can obtain from a server is limited
to when and what clients know to ask for. Conventional DBMSs offer primarily
pull-baseddata delivery.
In the push-only mode of data delivery,the transfer of data from servers to clients
is initiated by a server push in the absence of any specific request from clients.
Themain difficulty of the push-based approach is in deciding which data would be
of common interest, and when to sendthem toclients –alternatives are periodic,
irregular,or conditional. Thus, the usefulness of server push depends heavily upon
theaccuracy of a server to predict the needs of clients. In push-based mode, servers
disseminate information to either an unbounded set of clients (random broadcast)
whocan listen to a medium or selective set of clients (multicast),who belong to some
categoriesof recipients that may receive the data.
The hybrid mode of data deliverycombines the client-pull and server-push mech-
anisms. The continuous (or continual) query approach (e.g., [Liu et al., 1996],[Terry
etal., 1992],[Chen et al., 2000],[Pandey et al., 2003]) presents one possible way of
combiningthe pull and push modes: namely, the transfer of information from servers
toclients is first initiated by a client pull (by posing the query), and the subsequent
transferof updated information to clients is initiated by a server push.
Thereare three typical frequency measurements that can be used to classify the
regularityof data delivery. They are periodic, conditional, and ad-hoc or irregular.
In periodic delivery,data are sent from the server to clientsat regular intervals.
The intervalscan be defined by systemdefault or by clients using their profiles. Both
pulland push can be performed in periodic fashion. Periodic delivery is carried out
ona regular and pre-specified repeating schedule. A client request for IBM’s stock
priceevery week is an example of a periodic pull. An example of periodic push is
when an application can send out stock pricelisting ona regularbasis, say every
morning.Periodic push is particularly useful for situations in which clients might not
be availableat all times, or might be unable to react towhat has been sent, such as in
themobile setting where clients can become disconnected.
In conditional delivery,data are sentfrom servers whenever certain conditions
installed by clients in their profiles are satisfied. Such conditions can be as simple
asa given time span or as complicated as event-condition-action rules. Conditional
deliveryis mostlyused in thehybrid or push-onlydelivery systems. Using condi-
tional push, data are sent out according to a pre-specified condition, rather than
any particular repeating schedule. An application that sends out stock prices only
when theychange is anexample of conditional push. An application that sends out a
balancestatement only when the total balance is 5% below the pre-defined balance
thresholdis an example of hybrid conditional push. Conditional push assumes that
changesare critical to the clients, and that clients are always listening and need to
respond to what is being sent. Hybrid conditional push further assumes that missing
someupdate information is not crucial to the clients.
Ad-hoc deliveryis irregular and is performed mostly in a pure pull-based system.
Data are pulled from servers to clients in an ad-hoc fashion wheneverclients request