<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="http://wiki.erights.org/mediawiki/skins/common/feed.css?207"?>
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/">
	<channel>
		<title>SturdyRef replication - Revision history</title>
		<link>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;action=history</link>
		<description>Revision history for this page on the wiki</description>
		<language>en</language>
		<generator>MediaWiki 1.15.5-7</generator>
		<lastBuildDate>Sat, 25 Apr 2026 20:09:36 GMT</lastBuildDate>
		<item>
			<title>Kevin Reid:&amp;#32;remove accidentally included title-in-body</title>
			<link>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=1605&amp;oldid=prev</link>
			<guid>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=1605&amp;oldid=prev</guid>
			<description>&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;</description>
			<pubDate>Thu, 06 Sep 2007 14:59:08 GMT</pubDate>			<dc:creator>Kevin Reid</dc:creator>			<comments>http://wiki.erights.org/wiki/Talk:SturdyRef_replication</comments>		</item>
		<item>
			<title>Kevin Reid:&amp;#32;new document</title>
			<link>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=3350&amp;oldid=prev</link>
			<guid>http://wiki.erights.org/mediawiki/index.php?title=SturdyRef_replication&amp;diff=3350&amp;oldid=prev</guid>
			<description>&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 20:09:37 --&gt;
&lt;/table&gt;</description>
			<pubDate>Thu, 06 Sep 2007 14:54:30 GMT</pubDate>			<dc:creator>Kevin Reid</dc:creator>			<comments>http://wiki.erights.org/wiki/Talk:SturdyRef_replication</comments>		</item>
	</channel>
</rss>