<?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/"
	xmlns:georss="http://www.georss.org/georss" xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#" xmlns:media="http://search.yahoo.com/mrss/"
	>

<channel>
	<title>Chris Read &#187; Stuff</title>
	<atom:link href="http://blog.chris-read.net/category/stuff/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.chris-read.net</link>
	<description>He's just this guy, you know...</description>
	<lastBuildDate>Tue, 13 Sep 2011 11:41:41 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.com/</generator>
<cloud domain='blog.chris-read.net' port='80' path='/?rsscloud=notify' registerProcedure='' protocol='http-post' />
<image>
		<url>http://s2.wp.com/i/buttonw-com.png</url>
		<title>Chris Read &#187; Stuff</title>
		<link>http://blog.chris-read.net</link>
	</image>
	<atom:link rel="search" type="application/opensearchdescription+xml" href="http://blog.chris-read.net/osd.xml" title="Chris Read" />
	<atom:link rel='hub' href='http://blog.chris-read.net/?pushpress=hub'/>
		<item>
		<title>£106.50 per Terabyte Storage Server</title>
		<link>http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/</link>
		<comments>http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/#comments</comments>
		<pubDate>Thu, 02 Jun 2011 21:43:45 +0000</pubDate>
		<dc:creator>Chris Read</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Solaris]]></category>
		<category><![CDATA[Stuff]]></category>
		<category><![CDATA[Unix]]></category>

		<guid isPermaLink="false">http://blog.chris-read.net/?p=176</guid>
		<description><![CDATA[With the price of storage dropping all the time, there is a constant perception from people who don&#8217;t deal with it every day that &#8220;disk space is cheap&#8221;, especially when it comes to developers. The problem is that so called &#8220;Enterprise&#8221; storage costs are still astronomical compared to what people are used to paying for [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=176&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<h1><span class="Apple-style-span" style="font-size:13px;font-weight:normal;">With the price of storage dropping all the time, there is a constant perception from people who don&#8217;t deal with it every day that &#8220;disk space is cheap&#8221;, especially when it comes to developers. The problem is that so called &#8220;Enterprise&#8221; storage costs are still astronomical compared to what people are used to paying for home storage &#8211; even when using SATA disks.</span></h1>
<p>A lot of this extra cost comes from a perceived requirement for the highest available <strong>capacity</strong>, <strong>availability</strong> and <strong>performance</strong>. Achieving all three characteristics is expensive, but if you’re willing to sacrifice one of them then costs start to fall considerably. Lowering requirements on two of the three drops it even more.</p>
<p>One of the teams I work with has a requirement primarily on capacity. Performance and availability are nice, but capacity is the key. We generate gigabytes worth of log files every day, but didn&#8217;t have one place to store it all for easy analysis. Just before I joined the team they&#8217;d purchased the cheapest &#8220;Enterprise&#8221; storage system the IT team at the time would allow &#8211; it ended up costing in the region of £12k for 12TB of raw storage. That’s £1000 per TB!</p>
<p>In addition to the price, the other problems were accessibility and management of the data and managing growth. This inspired a hunt for something that would provide a cheaper and more flexible solution.</p>
<p>Our requirements were:</p>
<ul>
<li><strong>*nix based system. </strong>The current storage solution was based on Windows Storage Server, but all our systems and tools for this team are Linux based. Yes, Windows does technically provide things like an NFS server, but fighting with the file system permissions and overall performance are two things that impacted us.</li>
<li><strong>Cheap to expand.</strong> We need to have a clear path to grow the storage in the server easily by simply adding more disks.</li>
<li><strong>Large filesystems.</strong> There&#8217;s nothing more wasteful from a storage point of view than having lots of small filesystems. Besides the management overhead, there&#8217;s also many wasted blocks lying around un-used.</li>
<li><strong>Cheap to build</strong>. This inevitably means commodity hardware.</li>
<li><strong>Reasonable availability</strong>. We don&#8217;t need 99.999% uptime, but would be happy with somewhere in the region of 90%+</li>
<li><strong>Reasonable performance</strong>.<strong> </strong>Primary access to the data on this machine is via gigabit Ethernet. As long as it can keep up with the network card we’re happy…</li>
</ul>
<h2><span id="more-176"></span>Hardware Options</h2>
<p>The first thing we looked at was the <a href="http://blog.backblaze.com/2009/09/01/petabytes-on-a-budget-how-to-build-cheap-cloud-storage/">Backblaze</a> concept. Using a custom designed case (that&#8217;s actually quite easy to purchase) they manage to cram 45 SATA drives into a 4U chassis. That&#8217;s pretty impressive. Using cheap SATA hot swap port multiplier/backplanes and controllers allows for quite a low cost, but not without problems though. In the configuration they publish there are a number of problems:</p>
<ul>
<li>A mix of PCIe and PCI-X SATA controllers means that you need a LOT of slots on your motherboard. Boards with all those slots are not cheap.</li>
<li>Each of the 45 drives is presented to the operating system (Linux in this case, which is good). They then use software RAID for the volumes. Care needs to be taken when building a system like this though to ensure that you spread the drives for each array evenly across controllers so that a single controller or expander backplane failure does not take out an entire volume, which just adds to the management overhead.</li>
<li>The port multiplier chipset they use is only supported on Linux. This was a problem as we had initially planned to use OpenSolaris for this device as ZFS would make the storage management and expansion a no-brainer. The Oracle take over of Sun and their subsequent clamp down on OpenSolaris derailed this plan. I did do some performance testing with FreeBSD and their implementation of ZFS but the performance was terrible.</li>
<li>The cost is also not that cheap. Single orders of the custom case and power supply that go with it are actually pretty pricy.</li>
<li>Performance. I did a lot of testing, mostly with iozone. What I found though was that when running through the port multiplier, even when using NCQ, performance was pretty bad.</li>
</ul>
<p>The system I was using for my testing though had an onboard SAS controller and port expander. The SAS specification includes SATA support. Out of curiosity I decided to compare performance on that controller to what I got from the SATA chain. It was actually a lot better, which got me thinking about using SAS controllers with hardware RAID to simplify administration.</p>
<p>Initially I tried a pair of 8 port LSI controllers (<a href="http://www.lsi.com/storage_home/products_home/internal_raid/megaraid_sas/megaraid_sas_8208elp/">LSI 8208ELP</a>), but the cheaper end of the range have issues in their firmware and do not even boot with more than one controller present, so I replaced them with a single <a href="http://www.adaptec.com/en-us/products/controllers/hardware/sas/performance/sas-51245/">Adaptec 51245</a> controller. This made management and expansion a lot easier, as it has enough internal ports for the initial drives we planned on, and an external port that allows easy expansion.</p>
<h2>Current architecture</h2>
<p>The current system we have running in production is assembled from 100% off the shelf components. They are:</p>
<table width="408" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">
<p align="center"><strong>Description</strong></p>
</td>
<td valign="bottom" nowrap="nowrap" width="129">
<p align="center"><strong>Part</strong></p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="center"><strong>Count</strong></p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="center"><strong>Each</strong></p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="center"><strong>Total</strong></p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">SAS Cables</td>
<td valign="bottom" nowrap="nowrap" width="129"></td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">4</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£9.40</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£37.60</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">Drive Cage</td>
<td valign="bottom" nowrap="nowrap" width="129">NetStor NS170S Black</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">2</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£90.10</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£180.20</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">RAID Controller</td>
<td valign="bottom" nowrap="nowrap" width="129">Adaptec 51245</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">1</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£512.89</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£512.89</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">Case &amp; 650W PSU</td>
<td valign="bottom" nowrap="nowrap" width="129">Antec 4U22EPS650</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">1</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£192.36</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£192.36</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">Motherboard</td>
<td valign="bottom" nowrap="nowrap" width="129">Intel DP55WG</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">1</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£96.84</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£96.84</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">CPU</td>
<td valign="bottom" nowrap="nowrap" width="129">Intel i7 860</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">1</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£178.71</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£178.71</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">RAM</td>
<td valign="bottom" nowrap="nowrap" width="129">Kingston 4G DDR3 1600</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">2</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£63.96</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£127.92</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">VGA</td>
<td valign="bottom" nowrap="nowrap" width="129">PNY 8400GS</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">1</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£37.85</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£37.85</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">Data Disks</td>
<td valign="bottom" nowrap="nowrap" width="129">WD20EARS</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">10</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£76.58</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£765.80</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">NIC</td>
<td valign="bottom" nowrap="nowrap" width="129">Intel PRO/1000</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">2</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£0.00</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£0.00</p>
</td>
</tr>
<tr>
<td valign="bottom" nowrap="nowrap" width="120">OS Disks</td>
<td valign="bottom" nowrap="nowrap" width="129">ST3160318AS</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">2</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£0.00</p>
</td>
<td valign="bottom" nowrap="nowrap" width="53">
<p align="right">£0.00</p>
</td>
</tr>
</tbody>
</table>
<p>Cost (September 2010): £2130.17 (Excl VAT)</p>
<p>Total Raw Space: 20TB</p>
<p>Unit Cost: £106.50 per TB</p>
<p>Power Draw: 0.8A with sustained disk access, 1.16A peak on boot up.</p>
<p>The operating system we’ve selected is Ubuntu 10.04 LTS. We run the smaller disks we had spare in RAID1 for the OS. The data drives are in RAID6 on the WD&#8217;s.</p>
<h2>Hardware Build</h2>
<p>Here are some photos we took as we built the system:</p>

<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0041/' title='Boxed Internal Drive Cage'><img data-attachment-id='179' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0041.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Boxed Internal Drive Cage" title="Boxed Internal Drive Cage" /></a>
<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0043/' title='Rear of Drive Cage'><img data-attachment-id='180' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0043.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Rear of Drive Cage" title="Rear of Drive Cage" /></a>
<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0048/' title='Front View - Open'><img data-attachment-id='181' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0048.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Front View - Open" title="Front View - Open" /></a>
<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0062/' title='Motherboard'><img data-attachment-id='182' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0062.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Motherboard" title="Motherboard" /></a>
<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0060/' title='Data Drive'><img data-attachment-id='184' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0060.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Data Drive" title="Data Drive" /></a>
<a href='http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/img_0071/' title='Ready to rack'><img data-attachment-id='185' data-orig-size='4000,3000' data-liked='0'width="150" height="112" src="http://chrisread.files.wordpress.com/2011/06/img_0071.jpg?w=150&#038;h=112" class="attachment-thumbnail" alt="Ready to rack" title="Ready to rack" /></a>

<p><span class="Apple-style-span" style="font-size:20px;font-weight:bold;">Operating System Configuration</span></p>
<p>Using the hardware RAID controller allows us to simplify the Operating System configuration. Instead of having a block device for each physical disk, the controller presents a single block device for each array.</p>
<p>The filesystem we&#8217;re using is EXT4, created with the following options:</p>
<pre>-m 1 -O dir_index,has_journal,extent,sparse_super</pre>
<p>To try and speed things up we also set the noatime flag when mounting the filesystem.</p>
<p>The Adaptec Storage Manager application is used to monitor the health of the disks and will email us in the case of a drive failure.</p>
<h2>Performance</h2>
<p>With the current configuration, the performance is in no way spectacular, but it’s more than good enough for our needs. Write speeds are quite slow peaking at around 90MB/s, reads are good peaking at around 750MB/s.</p>
<h2>Client Access and Usage</h2>
<p>We&#8217;re currently running a mixed workload on the system and so far have had no complaints or problems. Every night we rsync all of our log files from our production machines, which is currently about 300GB per day.</p>
<p>Some of the people who are interested in this data access it via HTTP. We run an Apache server on the box (with compression enabled of course) to allow people easy access to browse and download what they need. Developers also access the logs read-only via NFS, and have a directory mounted via NFS called &#8220;playpen&#8221; that they use as a scratch pad for any of their research that requires more disk space than the 300GB or so they have available in their development machines.</p>
<h2>Going Forward</h2>
<p>In the 6 months or so we’ve had the machine we’ve almost used all the disk space. On a clear disk you can seek forever. We’ve placed an order for 2 more disk trays (<a href="http://www.netstor.com.tw/_03/03_02.php?OTI=">NetStor NS330S-8026</a>). These trays have built in SAS port expanders and allow us to daisy chain up to 7 trays off our external port. We’ve also ordered different hard drives. Instead of using the green WD drives we’ve decided to go for a bit more speed and get 7200RPM Hitachi Ultrastar 7K3000 SATA drives. This does add a lot more to the cost, but the performance pay off is worth it for us for expected higher write speeds. Once they’re up and running I’ll publish some comparative benchmarks.</p>
<p>Costs for the upgrade (Feb 2011): £9699.00</p>
<p>Total Raw Space: 64TB</p>
<p>Unit Cost: £151.50 per TB</p>
<h2>Update (23 June 2011)</h2>
<p>Right now there is some kind of major compatibility problem between the Adaptec card and the NetStor JBOD. I&#8217;ve been wrestling for over a week now with vendor support and still not getting anywhere.</p>
<br />  <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/chrisread.wordpress.com/176/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/chrisread.wordpress.com/176/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/chrisread.wordpress.com/176/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=176&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://blog.chris-read.net/2011/06/02/106-50-per-terabyte-storage-server/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Chris Read</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0041.jpg?w=150" medium="image">
			<media:title type="html">Boxed Internal Drive Cage</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0043.jpg?w=150" medium="image">
			<media:title type="html">Rear of Drive Cage</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0048.jpg?w=150" medium="image">
			<media:title type="html">Front View - Open</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0062.jpg?w=150" medium="image">
			<media:title type="html">Motherboard</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0060.jpg?w=150" medium="image">
			<media:title type="html">Data Drive</media:title>
		</media:content>

		<media:content url="http://chrisread.files.wordpress.com/2011/06/img_0071.jpg?w=150" medium="image">
			<media:title type="html">Ready to rack</media:title>
		</media:content>
	</item>
		<item>
		<title>Time for a change of scenery&#8230;</title>
		<link>http://blog.chris-read.net/2010/04/23/time-for-a-change-of-scenery/</link>
		<comments>http://blog.chris-read.net/2010/04/23/time-for-a-change-of-scenery/#comments</comments>
		<pubDate>Fri, 23 Apr 2010 19:25:20 +0000</pubDate>
		<dc:creator>Chris Read</dc:creator>
				<category><![CDATA[Stuff]]></category>

		<guid isPermaLink="false">http://blog.chris-read.net/?p=124</guid>
		<description><![CDATA[After more than 5 years at ThoughtWorks I&#8217;ve decided that it&#8217;s time for a change of scenery. As much as I enjoyed the challenge of consulting, meeting new people and seeing new places &#8211; I prefer spending time with my family more. It was a tough decision to make, but I think it&#8217;s the right [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=124&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>After more than 5 years at <a href="http://www.thoughtworks.com" target="_blank">ThoughtWorks</a> I&#8217;ve decided that it&#8217;s time for a change of scenery. As much as I enjoyed the challenge of consulting, meeting new people and seeing new places &#8211; I prefer spending time with my family more. It was a tough decision to make, but I think it&#8217;s the right one for me now. I will miss many people at TW, but on the plus side I&#8217;m again working with some great people who I missed when they left TW&#8230;</p>
<p>As I&#8217;m going to be doing DevOps type stuff all day every day at <a href="http://www.drwtrading.com" target="_blank">DRW</a> now, I&#8217;m hoping I&#8217;ll have more time to document and share the things I discover.</p>
<br />  <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/chrisread.wordpress.com/124/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/chrisread.wordpress.com/124/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/chrisread.wordpress.com/124/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=124&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://blog.chris-read.net/2010/04/23/time-for-a-change-of-scenery/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Chris Read</media:title>
		</media:content>
	</item>
		<item>
		<title>The Microsoft School of Error Messages</title>
		<link>http://blog.chris-read.net/2007/05/23/the-microsoft-school-of-error-messages/</link>
		<comments>http://blog.chris-read.net/2007/05/23/the-microsoft-school-of-error-messages/#comments</comments>
		<pubDate>Wed, 23 May 2007 21:32:35 +0000</pubDate>
		<dc:creator>Chris Read</dc:creator>
				<category><![CDATA[Software]]></category>
		<category><![CDATA[Stuff]]></category>

		<guid isPermaLink="false">http://www.chris-read.net/index.php/2007/05/23/the-microsoft-school-of-error-messages/</guid>
		<description><![CDATA[Up until now I&#8217;ve managed to avoid ranting here, but I can no longer resist! After all these years of experience, why are the error messages in windows still generally meaningless? Is it because there are so many of them? The problem I faced was trying to patch a game. Downloaded the patch, tried to [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=14&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Up until now I&#8217;ve managed to avoid ranting here, but I can no longer resist! After all these years of experience, why are the error messages in windows still generally meaningless? Is it because there are so many of them?</p>
<p>The problem I faced was trying to patch a game. Downloaded the patch, tried to apply it, but got the message &#8220;<strong>The application failed to initialize properly</strong> (<strong>0xc0000135</strong>)&#8221;. Much confusion. Downloaded from another source, tried again, same error. Tried on my laptop, and this time it worked perfectly. What&#8217;s the problem?</p>
<p>Turns out the patch is written in .Net, and I don&#8217;t have the correct version of the runtime installed on my desktop, but I do have it on my laptop. I only had .Net 1.0, and it needs a newer version. Good thing the error message told me that in the first place then, isn&#8217;t it&#8230;</p>
<br /><img alt="" border="0" src="http://feeds.wordpress.com/1.0/categories/chrisread.wordpress.com/14/" /> <img alt="" border="0" src="http://feeds.wordpress.com/1.0/tags/chrisread.wordpress.com/14/" /> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/chrisread.wordpress.com/14/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/chrisread.wordpress.com/14/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/chrisread.wordpress.com/14/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=14&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://blog.chris-read.net/2007/05/23/the-microsoft-school-of-error-messages/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Chris Read</media:title>
		</media:content>
	</item>
		<item>
		<title>Trac Wiki HTML Scraper</title>
		<link>http://blog.chris-read.net/2006/03/22/trac-wiki-html-scraper/</link>
		<comments>http://blog.chris-read.net/2006/03/22/trac-wiki-html-scraper/#comments</comments>
		<pubDate>Wed, 22 Mar 2006 14:50:38 +0000</pubDate>
		<dc:creator>Chris Read</dc:creator>
				<category><![CDATA[Software]]></category>
		<category><![CDATA[Stuff]]></category>

		<guid isPermaLink="false">http://www.chris-read.net/?p=5</guid>
		<description><![CDATA[A few of us are using Trac for an internal project at work, and at some stage in the process we decided to use the wiki as the distribution documentation. Everything has been going wonderfully, until we realized we that we wanted the documentation to be available without having to run Trac. After some digging [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=7&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>A few of us are using <a target="_blank" href="http://www.edgewall.com/trac/">Trac</a> for an internal project at work, and at some stage in the process we decided to use the wiki as the distribution documentation. Everything has been going wonderfully, until we realized we that we wanted the documentation to be available without having to run Trac. After some digging around, I found <a target="_blank" href="http://projects.edgewall.com/trac/ticket/1468">this ticket</a> on the Trac dev site where <a href="mailto:alec@swapoff.org">Alec Thomas</a> put up a diff to allow you to download Trac wiki pages as HTML. After applying the patch, I found that it worked well, but there was still no easy way to pull the whole wiki down as HTML. So I wrote a python script to do it, and the script is available <a href="http://www.chris-read.net/files/trac-html-scraper.py">here</a> for those who are interested.     <em><br />
</em></p>
<br /><img alt="" border="0" src="http://feeds.wordpress.com/1.0/categories/chrisread.wordpress.com/7/" /> <img alt="" border="0" src="http://feeds.wordpress.com/1.0/tags/chrisread.wordpress.com/7/" /> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/chrisread.wordpress.com/7/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/chrisread.wordpress.com/7/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/chrisread.wordpress.com/7/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=7&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://blog.chris-read.net/2006/03/22/trac-wiki-html-scraper/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Chris Read</media:title>
		</media:content>
	</item>
		<item>
		<title>The new site</title>
		<link>http://blog.chris-read.net/2006/03/09/the-new-site/</link>
		<comments>http://blog.chris-read.net/2006/03/09/the-new-site/#comments</comments>
		<pubDate>Thu, 09 Mar 2006 17:02:29 +0000</pubDate>
		<dc:creator>Chris Read</dc:creator>
				<category><![CDATA[Stuff]]></category>

		<guid isPermaLink="false">http://www.chris-read.net/?p=4</guid>
		<description><![CDATA[So, after a short stab at blogging over at http://netnix.blogspot.com, I decided to start blogging at a domain name that was more me. Not because what I was writing about was of huge interest to people, or had lots to say. It&#8217;s just because I can. I&#8217;m going to leave the NetNix stuff where it [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=6&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>So, after a short stab at blogging over at <a target="_blank" href="http://netnix.blogspot.com">http://netnix.blogspot.com</a>, I decided to start blogging at a domain name that was more me. Not because what I was writing about was of huge interest to people, or had lots to say. It&#8217;s just because I can. I&#8217;m going to leave the NetNix stuff where it is, as I don&#8217;t see the point of moving it. All new stuff will simply appear here.</p>
<p>Currently, the interesting stuff I&#8217;m working on is creating build production lines for software, and messing with virtualization. As soon as I have something interesting to report on either of these,  you will see it here&#8230;</p>
<br /><img alt="" border="0" src="http://feeds.wordpress.com/1.0/categories/chrisread.wordpress.com/6/" /> <img alt="" border="0" src="http://feeds.wordpress.com/1.0/tags/chrisread.wordpress.com/6/" /> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/chrisread.wordpress.com/6/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/chrisread.wordpress.com/6/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/chrisread.wordpress.com/6/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=blog.chris-read.net&amp;blog=4083712&amp;post=6&amp;subd=chrisread&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://blog.chris-read.net/2006/03/09/the-new-site/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Chris Read</media:title>
		</media:content>
	</item>
	</channel>
</rss>
