Mercurial > projects > ldc
diff tango/example/cluster/invalidate.d @ 132:1700239cab2e trunk
[svn r136] MAJOR UNSTABLE UPDATE!!!
Initial commit after moving to Tango instead of Phobos.
Lots of bugfixes...
This build is not suitable for most things.
author | lindquist |
---|---|
date | Fri, 11 Jan 2008 17:57:40 +0100 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tango/example/cluster/invalidate.d Fri Jan 11 17:57:40 2008 +0100 @@ -0,0 +1,38 @@ +private import tango.core.Thread; + +private import tango.util.log.Configurator; + +private import tango.net.cluster.tina.Cluster; + +private import tango.net.cluster.QueuedCache, + tango.net.cluster.CacheInvalidatee, + tango.net.cluster.CacheInvalidator; + +/******************************************************************************* + + Demonstrates how to invalidate cache entries across a cluster + via a channel + +*******************************************************************************/ + +void main() +{ + // access the cluster + auto cluster = (new Cluster).join; + + // wrap a cache instance with a network listener + auto dst = new CacheInvalidatee (cluster, "my.cache.channel", new QueuedCache!(char[], IMessage)(101)); + + // connect an invalidator to that cache channel + auto src = new CacheInvalidator (cluster, "my.cache.channel"); + + // stuff something in the local cache + dst.cache.put ("key", dst.EmptyMessage); + + // get it removed via a network broadcast + src.log.info ("invalidating 'key' across the cluster"); + src.invalidate ("key"); + + // wait for it to arrive ... + Thread.sleep (1); +}