<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Jeremy Madea</title>
	<atom:link href="http://madea.net/feed/" rel="self" type="application/rss+xml" />
	<link>http://madea.net</link>
	<description>Systems Architect &#38; Consultant</description>
	<lastBuildDate>Thu, 10 May 2012 10:34:51 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.2</generator>
		<item>
		<title>*facepalm*</title>
		<link>http://madea.net/facepalm/</link>
		<comments>http://madea.net/facepalm/#comments</comments>
		<pubDate>Sat, 14 Apr 2012 13:24:12 +0000</pubDate>
		<dc:creator>madea</dc:creator>
				<category><![CDATA[geek life]]></category>
		<category><![CDATA[facepalm]]></category>

		<guid isPermaLink="false">http://madea.net/?p=9</guid>
		<description><![CDATA[I host sites, including this one, on virtual server instances running on a cloud computing infrastructure.  This offers many advantages, but the most important one to me is the isolation from hardware problems. The cloud is built on fully redundant hardware and if a hardware failure occurs, my virtual server just fails over to another [...]]]></description>
			<content:encoded><![CDATA[<p>I host sites, including this one, on virtual server instances running on a cloud computing infrastructure.  This offers many advantages, but the most important one to me is the isolation from hardware problems. The cloud is built on fully redundant hardware and if a hardware failure occurs, my virtual server just fails over to another node. For many years, I hosted sites on dedicated servers and disk failures were an occasional and very irritating problem. Switching to cloud-based virtual servers was supposed to end all that.</p>
<p>But here&#8217;s the thing. The virtual servers have virtual disks. And those virtual disks can, in strange circumstance, become corrupted just as real disks can. It&#8217;s not really a hardware problem; it&#8217;s a <em>virtual</em> hardware problem.</p>
<p>It&#8217;s rare. I have it on good authority that the engineers for the company that provides the cloud management system to the hosting company I use have only seen the issue a handful of times in almost half a decade.</p>
<p>I saw it twice in two days.</p>
<p>The two days immediately after I sent links to my <a title="Resumé" href="http://madea.net/resume/">resumé</a> out to more than half a dozen employers.</p>
<p>*facepalm*</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
]]></content:encoded>
			<wfw:commentRss>http://madea.net/facepalm/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>A Robustness Corollary</title>
		<link>http://madea.net/a-robustness-corollary/</link>
		<comments>http://madea.net/a-robustness-corollary/#comments</comments>
		<pubDate>Tue, 31 Jan 2012 21:02:32 +0000</pubDate>
		<dc:creator>madea</dc:creator>
				<category><![CDATA[Tech]]></category>
		<category><![CDATA[browsers]]></category>
		<category><![CDATA[HTTP]]></category>
		<category><![CDATA[standards]]></category>

		<guid isPermaLink="false">http://madea.net/?p=16</guid>
		<description><![CDATA[You’re probably familiar with the robustness principle which is usually stated as: Be liberal in what you accept, and conservative in what you send. When it comes to standards, I’d like to offer a corollary: Be precise in your description and flexible in your interpretation.  &#160; An example of where this corollary could be applied is in [...]]]></description>
			<content:encoded><![CDATA[<p>You’re probably familiar with the <a title="Robustness Principle" href="http://en.wikipedia.org/wiki/Robustness_principle" target="_blank">robustness principle</a> which is usually stated as:</p>
<blockquote><p><em>Be liberal in what you accept, and conservative in what you send.</em></p></blockquote>
<p>When it comes to standards, I’d like to offer a corollary:</p>
<p><strong>Be precise in your description and flexible in your interpretation. </strong></p>
<p>&nbsp;</p>
<p>An example of where this corollary could be applied is in some browser developers’ handling of HTTP’s 301 “Moved Permanently” responses. According to   RFC 2616, section 10.3.2 “301 Moved Permanently”:</p>
<blockquote><p>The requested resource has been assigned a new permanent URI and any future references to this resource SHOULD use one of the returned URIs. Clients with link editing capabilities ought to automatically re-link references to the Request-URI to one or more of the new references returned by the server, where possible. This response is cacheable unless indicated otherwise.</p></blockquote>
<p>That’s all well and good but permanence is an elusive thing on the web. Websites and applications tend to change quite a lot, especially during development. And when aren’t they under development? Even if mistakes were never made, the ownership of domains (and therefore URIs) is subject to change.</p>
<p>None of that would pose a problem in this instance if it weren’t for browser developers who cache 301 responses for a resource indefinitely and use one of the returned URIs for all future references to that resource.</p>
<p>But, but, but! . . . That’s what the RFC says they SHOULD do, right? And isn’t a good thing that they want to be called “unconditionally compliant?”</p>
<p>Yes. But that misses the point. The phrase “<em>any future references to this resource</em>” can be quite flexibly interpreted. Any future references handled by what exactly? Some browser developers have decided it should mean any future references handled by an <em>installation</em> of their browser. It would be a lot more reasonable, especially from the perspective of web developers, if the browser developers simply interpreted it to mean an <em>instance</em> instead, at least, in the absence of specific caching instructions.</p>
<p>&nbsp;</p>
]]></content:encoded>
			<wfw:commentRss>http://madea.net/a-robustness-corollary/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Feeble Visions</title>
		<link>http://madea.net/feeble-visions/</link>
		<comments>http://madea.net/feeble-visions/#comments</comments>
		<pubDate>Wed, 18 Jan 2012 21:07:05 +0000</pubDate>
		<dc:creator>madea</dc:creator>
				<category><![CDATA[Tech]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[design]]></category>
		<category><![CDATA[future]]></category>
		<category><![CDATA[interaction]]></category>
		<category><![CDATA[rant]]></category>
		<category><![CDATA[tech]]></category>

		<guid isPermaLink="false">http://madea.net/?p=19</guid>
		<description><![CDATA[Here is an awesome rant on the feeble vision some big players have for the future of interaction design. The author, Bret Victor, a onetime “human interface inventor” at Apple, complains that the vision of the future where we are sliding around “pictures behind glass” isn’t really visionary but just a tiny step from where we are now. I’m [...]]]></description>
			<content:encoded><![CDATA[<p>Here is <a title="A Brief Rant on the Future of Interaction Design" href="http://worrydream.com/ABriefRantOnTheFutureOfInteractionDesign/" target="_blank">an awesome rant</a> on the feeble vision some big players have for the future of interaction design.</p>
<p>The author, Bret Victor, a onetime “human interface inventor” at Apple, complains that the vision of the future where we are sliding around “pictures behind glass” isn’t really <em>visionary</em> but just a tiny step from where we are now.</p>
<p>I’m inclined to agree.</p>
<p>Moreover, I think this vision isn’t just limited; it’s limit<em>ing</em> too. If we can’t conceive of richer ways to interact with our computers, we’ll be restricting our ability to see what problems we can solve with them.</p>
]]></content:encoded>
			<wfw:commentRss>http://madea.net/feeble-visions/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

