<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="http://wiki.erights.org/mediawiki/skins/common/feed.css?207"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
		<id>http://wiki.erights.org/mediawiki/index.php?action=history&amp;feed=atom&amp;title=SturdyRef_replication</id>
		<title>SturdyRef replication - Revision history</title>
		<link rel="self" type="application/atom+xml" href="http://wiki.erights.org/mediawiki/index.php?action=history&amp;feed=atom&amp;title=SturdyRef_replication"/>
		<link rel="alternate" type="text/html" href="http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;action=history"/>
		<updated>2026-04-25T09:24:11Z</updated>
		<subtitle>Revision history for this page on the wiki</subtitle>
		<generator>MediaWiki 1.15.5-7</generator>

	<entry>
		<id>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=1605&amp;oldid=prev</id>
		<title>Kevin Reid:&amp;#32;remove accidentally included title-in-body</title>
		<link rel="alternate" type="text/html" href="http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=1605&amp;oldid=prev"/>
				<updated>2007-09-06T14:59:08Z</updated>
		
		<summary type="html">&lt;p&gt;remove accidentally included title-in-body&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;This is [[User:Kevin Reid]]'s idea for implementing transparent load-balancing replication for services exposed over [[Pluribus]].&lt;br /&gt;
&lt;br /&gt;
==Premises==&lt;br /&gt;
&lt;br /&gt;
We have a set of hosts running replicas of the actual service (ignoring their internal communication topology), and (possibly identical) a set of hosts which are exposed to the Internet and provide some mechanism (e.g. round robin DNS) for letting a client connect to an arbitrary one of them.&lt;br /&gt;
&lt;br /&gt;
==Implementation==&lt;br /&gt;
&lt;br /&gt;
Each of the exposed hosts is running a 'pseudo-[[vat]]'; all pseudo-vats have the same [[VatID]]. The clients hold ordinary [[SturdyRef]]s referring to this VatID.&lt;br /&gt;
&lt;br /&gt;
A pseudo-vat implements [[CapTP]] trivially: it ignores all incoming messages except [[nonceLocator#lookupSwiss/2]]. A successful lookup returns a [[live reference]] to a [[presence]] of the relevant object in one of the replica-vats.&lt;br /&gt;
&lt;br /&gt;
In order to preserve transparency, the pseudo-vat must not support any feature (e.g. incoming [[3Desc]]s, [[WormholeOp]], etc.) which would require it to connect to other vats, as then its non-singular nature could be revealed.&lt;br /&gt;
&lt;br /&gt;
==Notes==&lt;br /&gt;
&lt;br /&gt;
The pseudo-vat should be a reasonably simple application of the CapTP-in-E subsystem (if it isn't possible, CapTP-in-E needs to be redesigned).&lt;br /&gt;
&lt;br /&gt;
However, in order to support the [[3-vat introduction]] for the redirected-to live ref, the [[NonceLocator]]s provided by the replica-vats must be able to accept acceptFrom messages specifying the pseudo-vat's [[VatID]]; the normal [[gift table]] mechanism would require that there be a live connection between the pseudo-vat-instance and the replica-vat.&lt;/div&gt;</summary>
		<author><name>Kevin Reid</name></author>	</entry>

	<entry>
		<id>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=3350&amp;oldid=prev</id>
		<title>Kevin Reid:&amp;#32;new document</title>
		<link rel="alternate" type="text/html" href="http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=3350&amp;oldid=prev"/>
				<updated>2007-09-06T14:54:30Z</updated>
		
		<summary type="html">&lt;p&gt;new document&lt;/p&gt;

		&lt;table style=&quot;background-color: white; color:black;&quot;&gt;
		&lt;col class='diff-marker' /&gt;
		&lt;col class='diff-content' /&gt;
		&lt;col class='diff-marker' /&gt;
		&lt;col class='diff-content' /&gt;
		&lt;tr valign='top'&gt;
		&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;←Older revision&lt;/td&gt;
		&lt;td colspan='2' style=&quot;background-color: white; color:black;&quot;&gt;Revision as of 14:54, 6 September 2007&lt;/td&gt;
		&lt;/tr&gt;
		&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;nbsp;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;background: #cfc; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;color: red; font-weight: bold; text-decoration: none;&quot;&gt;Replication&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;nbsp;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;background: #cfc; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;color: red; font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background: #eee; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;This is [[User:Kevin Reid]]'s idea for implementing transparent load-balancing replication for services exposed over [[Pluribus]].&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background: #eee; color:black; font-size: smaller;&quot;&gt;&lt;div&gt;This is [[User:Kevin Reid]]'s idea for implementing transparent load-balancing replication for services exposed over [[Pluribus]].&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background: #eee; color:black; font-size: smaller;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt; &lt;/td&gt;&lt;td style=&quot;background: #eee; color:black; font-size: smaller;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;!-- diff generator: internal 2026-04-25 09:24:12 --&gt;
&lt;/table&gt;</summary>
		<author><name>Kevin Reid</name></author>	</entry>

	</feed>