<?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>Deserialized &#187; Caching</title>
	<atom:link href="http://deserialized.com/category/caching/feed/" rel="self" type="application/rss+xml" />
	<link>http://deserialized.com</link>
	<description>The Ramblings of a Web Architect</description>
	<lastBuildDate>Mon, 23 Jan 2012 16:33:09 +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>Reverse Proxy Performance – Varnish vs. Squid (Part 2)</title>
		<link>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-2/</link>
		<comments>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-2/#comments</comments>
		<pubDate>Wed, 09 Sep 2009 01:32:38 +0000</pubDate>
		<dc:creator>Bryan Migliorisi</dc:creator>
				<category><![CDATA[Caching]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[Varnish]]></category>

		<guid isPermaLink="false">http://deserialized.com/?p=37</guid>
		<description><![CDATA[In part one of this series I tested the raw throughput performance of Varnish and Squid.  My results are consistent with all the blogs and comments floating around the blogosphere – Varnish blows away Squid. Unfortunately, the first series of tests were somewhat uninformative.  Since they only tested the raw performance of serving cached content [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fdeserialized.com%2Fcaching%2Freverse-proxy-performance-varnish-vs-squid-part-2%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fdeserialized.com%2Fcaching%2Freverse-proxy-performance-varnish-vs-squid-part-2%2F&amp;source=Deserialized&amp;style=normal&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p><img style="border-right-width: 0px; margin: 0px 20px 0px 0px; display: inline; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" title="squid-vs-varnish" src="http://deserialized.com/wp-content/uploads/2009/09/squidvsvarnish.gif" border="0" alt="squid-vs-varnish" width="133" height="153" align="left" /></p>
<p>In <a title="Reverse Proxy Performance – Varnish vs. Squid (Part 1)" href="http://deserialized.com/reverse-proxy-performance-varnish-vs-squid-part-1/">part one</a> of this series I tested the raw throughput performance of <a title="Varnish is a state-of-the-art, high-performance HTTP accelerator" href="http://varnish.projects.linpro.no/">Varnish</a> and <a href="http://www.squid-cache.org/">Squid</a>.  My results are consistent with all the blogs and comments floating around the blogosphere – Varnish blows away Squid.</p>
<p>Unfortunately, the first series of tests were somewhat uninformative.  Since they only tested the raw performance of serving cached content from memory, it did not mimic a real world scenario of serving cached content as well as fetching content from the backend and caching it.</p>
<p>While we would hope for a primed, full cache, it is unlikely to happen and you will undoubtedly see a decent amount of backend requests from your caching proxy.</p>
<p>A better test of the two proxies would involve a large set of random URLs, but not <em>too</em> random because we want to simulate both cache hits and cache misses.  To accomplish this, I wrote a small PHP script that would take two parameters: total number of URLs to generate and the hostname for those URLs.</p>
<h2>Generating a usable URL list</h2>
<p>Generating the list is simple.  This script looks like this:</p>
<pre class="brush: php"><?php
        ob_start();
        $total = $_GET['total'];
        $host = $_GET['host'];
        for ($i = 0; $i < $total; $i++) {
                // generate random numbers
                srand(time());
                $random = mt_rand(10, 40);
                $random2 =  mt_rand(1, 100);

                if (substr($random2,0,1) > 1) {
			$as="?as=$random2";
		} else {
			$as = "";
		}
                echo "http://$host/varnish/gen/$random$as\n";
                flush(); ob_flush();
        }
        echo "http://$host/varnish/gen/$random$as";
?></pre>
<p>All this does is create a long list of URLs.  I used PHPs output buffering mechanisms to flush the buffer which is necessary when creating large URL lists so that you don’t wait forever.  Maybe it could have been written better but I don't care – that wasn't the point of this test.</p>
<p>The URLs that are created are in the format of:</p>
<pre class="brush: bash">http://host/varnish/gen/50?as=100

http://host/varnish/gen/50</pre>
<p>This URL is mapped to another PHP file that simply generates dummy data of the size specified in the URL.  In the above cases, the files would be 50Kb large.  The query parameter “as” is just a useless piece of information that is meant to tell the proxy to cache it.  If the “as” query parameter does not exist, the proxy will forward the request to the backend and not cache it.  Its a simple way to generate cacheable and non-cacheable URLs.</p>
<p>To generate the list and store it in a local file, I used this command:</p>
<pre class="brush: bash">curl http://192.168.165.101/varnish/makelist.php?total=10000&amp;host=192.168.165.104:8080
	&gt; urls-10k.txt</pre>
<p><strong>Verify the results of the script</strong></p>
<p>For your own sanity, make sure that the script did in fact generate a list of URLs that suits your needs.</p>
<p>Count the amount of URLs generated:</p>
<pre class="brush: bash">cat urls-10k.txt | wc –l</pre>
<p>(yes, I know it creates one extra URL … Its fine by me.)</p>
<p>Count the amount of cacheable URLs containing the “as” query parameter:</p>
<pre class="brush: bash">cat urls-10k.txt | grep as | wc –l</pre>
<p>Count the amount of unique cacheable URLs:</p>
<pre class="brush: bash">cat urls-10k.txt | grep as | sort | uniq | wc –l</pre>
<h2>Running the tests</h2>
<p>In part one I used ApacheBench to load the servers but for these tests, I used <a title="Siege is an http regression testing and benchmarking utility" href="http://www.joedog.org/index/siege-home">Siege</a> and <a title="http_load runs multiple http fetches in parallel, to test the throughput of a web server" href="http://acme.com/software/http_load/">http_load</a> which both allowed me to load URLs from a file.</p>
<p>I started with Varnish using the following commands:</p>
<pre class="brush: bash">curl http://192.168.165.101/varnish/makelist.php?total=100000&amp;host=192.168.165.104:8080
	&gt; urls-100k.txt
http_load -parallel 10 -fetches 100000 urls-100k.txt
http_load -parallel 25 -fetches 100000 urls-100k.txt
http_load -parallel 50 -fetches 100000 urls-100k.txt
http_load -parallel 100 -fetches 100000 urls-100k.txt
http_load -parallel 200 -fetches 100000 urls-100k.txt
http_load -parallel 400 -fetches 100000 urls-100k.txt</pre>
<p>In between each http_load command, I restarted the Varnish service so that each test ran with an empty cache.  When I was done with the Varnish tests, I ran the same tests against Squid using the same commands above.</p>
<h2>The results</h2>
<p>The results of these tests represent the typical web application much better than the original tests did.</p>
<p>This first graph shows the average time for the proxy to accept a connection.  As concurrency goes up, it is expected that the time to connect would go up too.  Squid suffers more than Varnish does, but the difference is negligible.</p>
<p><a href="http://deserialized.com/wp-content/uploads/2009/09/image.png"><img style="border-right-width: 0px; display: inline; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" title="image" src="http://deserialized.com/wp-content/uploads/2009/09/image_thumb.png" border="0" alt="image" width="580" height="188" /></a></p>
<p>The second graph is much more interesting.  As concurrency goes up, the Time-To-First-Byte for Squid goes up very sharply while Varnish holds its ground and remains very quick around 25ms.</p>
<p><a href="http://deserialized.com/wp-content/uploads/2009/09/image1.png"><img style="border-right-width: 0px; display: inline; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" title="image" src="http://deserialized.com/wp-content/uploads/2009/09/image_thumb1.png" border="0" alt="image" width="579" height="188" /></a></p>
<p>This third graph shows another interesting behavior.  As concurrency goes up, Varnish begins to even itself out at just under 800 fetches per second while Squid peaks at around 1100 fetches per second with around 50 concurrent connects and then sharply drops off as concurrency goes up.</p>
<p><a href="http://deserialized.com/wp-content/uploads/2009/09/image2.png"><img style="border-right-width: 0px; display: inline; border-top-width: 0px; border-bottom-width: 0px; border-left-width: 0px" title="image" src="http://deserialized.com/wp-content/uploads/2009/09/image_thumb2.png" border="0" alt="image" width="579" height="187" /></a></p>
<h2>Conclusion</h2>
<p>Squid versus Varnish is just another holy war that may never end.  The tests that I have performed have been very helpful for me and my team but your results may vary.  Of course, there are many more things to consider and I plan to write about some of the major differences between Squid and Varnish.</p>
<p>My results show that in raw cache hit performance, Varnish puts Squid to shame.  In real world scenarios I found that Squid can hold its own when dealing with small amounts of traffic, but it’s performance drops off very sharply as it begins to handle more connections. Varnish handles them without a sweat, as it was designed to do.</p>
<p>My next blog post will detail the differences between Varnish and Squid’s architecture, features, and the reasons I am pushing for Varnish in our environment.</p>
<p><strong>Edit:</strong></p>
<p>Some people are complaining in comments on Reddit and HackerNews that I have not provided any information about the hardware or operating system for my tests.  This information was posted in <a href="http://deserialized.com/reverse-proxy-performance-varnish-vs-squid-part-1/">Part one</a> of this post.</p>
]]></content:encoded>
			<wfw:commentRss>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-2/feed/</wfw:commentRss>
		<slash:comments>27</slash:comments>
		</item>
		<item>
		<title>Reverse Proxy Performance &#8211; Varnish vs. Squid (Part 1)</title>
		<link>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-1/</link>
		<comments>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-1/#comments</comments>
		<pubDate>Thu, 03 Sep 2009 01:15:57 +0000</pubDate>
		<dc:creator>Bryan Migliorisi</dc:creator>
				<category><![CDATA[Caching]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[Varnish]]></category>

		<guid isPermaLink="false">http://deserialized.com/?p=30</guid>
		<description><![CDATA[Typical web applications require dozens of SQL queries to generate a single page.&#160; When your application is serving over 1,000,000 pages per day, you quickly realize that the performance bottleneck is your database.&#160; The typical answer to slow database queries is “just use memcached!”&#160; Memcached and other data caches can only take you so far.&#160; [...]]]></description>
			<content:encoded><![CDATA[<div class="tweetmeme_button" style="float: right; margin-left: 10px;">
			<a href="http://api.tweetmeme.com/share?url=http%3A%2F%2Fdeserialized.com%2Fcaching%2Freverse-proxy-performance-varnish-vs-squid-part-1%2F"><br />
				<img src="http://api.tweetmeme.com/imagebutton.gif?url=http%3A%2F%2Fdeserialized.com%2Fcaching%2Freverse-proxy-performance-varnish-vs-squid-part-1%2F&amp;source=Deserialized&amp;style=normal&amp;b=2" height="61" width="50" /><br />
			</a>
		</div>
<p><img style="border-bottom: 0px; border-left: 0px; margin: 0px 20px 0px 0px; display: inline; border-top: 0px; border-right: 0px" title="squid-vs-varnish" border="0" alt="squid-vs-varnish" align="left" src="http://deserialized.com/wp-content/uploads/2009/09/squidvsvarnish.gif" width="133" height="153" /> Typical web applications require dozens of SQL queries to generate a single page.&#160; When your application is serving over 1,000,000 pages per day, you quickly realize that the performance bottleneck is your database.&#160; The typical answer to slow database queries is “just use <a href="http://www.danga.com/memcached/">memcached</a>!”&#160; <a href="http://www.danga.com/memcached/">Memcached</a> and other data caches can only take you so far.&#160; This is where reverse proxies come in.&#160; There are a handful of them out there, including <a title="nginx [engine x] is a HTTP server and mail proxy server" href="http://nginx.net/">Nginx</a>, <a title="Perlbal is a Perl-based reverse proxy load balancer and web server" href="http://www.danga.com/perlbal/">Perlbal</a>, <a title="Squid is a caching proxy for the Web supporting HTTP, HTTPS, FTP, and more" href="http://www.squid-cache.org/">Squid</a> and <a title="Varnish is a state-of-the-art, high-performance HTTP accelerator. It uses the advanced features in Linux 2.6, FreeBSD 6/7 and Solaris 10 to achieve its high performance." href="http://varnish.projects.linpro.no/">Varnish</a>.&#160; Which to use is up to you.</p>
<p>&#160;</p>
<h2>Deciding what is best for you</h2>
<p>Assuming that you have taken a step back and really analyzed your problem first, the next step is to analyze the possible solutions.&#160; For us, Varnish seems like the best option with Squid close behind.&#160; To be fair, I’ve set up a test server with both Varnish and Squid running.&#160; I’ll use <a title="ab is a tool for benchmarking your Apache Hypertext Transfer Protocol (HTTP) server" href="http://httpd.apache.org/docs/2.0/programs/ab.html">ApacheBench</a> to generate load and requests.</p>
<p>I’ve analyzed our pages to see what the typical page size is and recorded the average page sizes for 5 different page types.&#160; They range from around 10KB to 35KB (<a href="http://developer.yahoo.com/performance/rules.html#gzip">gzipped</a>).&#160; For my test, I’ll be benchmarking with 10KB, 15KB, 20KB, 30KB, 40KB, and 50KB files to get a good range of different size requests.</p>
<p>To test under different load capacities, I’ll use <a title="ab is a tool for benchmarking your Apache Hypertext Transfer Protocol (HTTP) server" href="http://httpd.apache.org/docs/2.0/programs/ab.html">ApacheBench</a> to generate loads with different amounts of concurrent users ranging from 10 to 400.</p>
<p>&#160;</p>
<h2>The test</h2>
<p>I’ll be using two identical machines on the same local class C network to eliminate (as much as possible) network latency.&#160; </p>
<p><strong>The machines look something like this:</strong></p>
<ul>
<li>Pentium 4 3GHz (8KB Level 1, 512KB Level 2) </li>
<li>2GB (4x512 DDR 400MHz) </li>
<li>120GB ATA Western Digital Caviar WD1200JB </li>
<li>CentOS 5 </li>
</ul>
<p>(I don't have more information than that.&#160; Suffice to say that it is a few years old and not very powerful)</p>
<p>I am using Varnish 2.04 and Squid 2.6.STABLE21.&#160; There are newer versions of Squid but i am using this version because the 3.x branch is missing features found in the 2.x branch and I have read several reports of 2.7 crashing, etc.</p>
<p>&#160;</p>
<p><strong>The command to run the load test looks something like this:</strong></p>
<p>ab –c concurrent_users –n total_requests “url”</p>
<p>This will let you specify how many concurrent users to run and how many requests to make.&#160; I have the proxy servers running on ServerA and I run the benchmark from ServerB.</p>
<p>&#160;</p>
<h2>The results</h2>
<p>In general, Varnish seems to perform twice as well as Squid does.&#160; In every test, Varnish serves nearly 2x more requests per second and has half the average response time.</p>
<table border="2" cellspacing="0">
<tbody>
<tr valign="bottom">
<td class="style1" colspan="2" align="center">&#160;</td>
<td class="style1" bgcolor="#d7e4bd" valign="middle" colspan="3" align="center"><font color="#9bbb59" size="5" face="Calibri"><b>Varnish</b></font></td>
<td class="style1" bgcolor="#d7e4bd" valign="middle" colspan="3" align="center"><font color="#9bbb59" size="5" face="Calibri"><b>Squid</b></font></td>
</tr>
<tr valign="bottom">
<td valign="middle" width="40" align="center"><font size="3" face="Calibri">File Size</font></td>
<td valign="middle" width="59" align="center"><font size="3" face="Calibri">Concurrent Users</font></td>
<td valign="middle" width="58" align="center"><font size="3" face="Calibri">(V) Requests per second</font></td>
<td valign="middle" width="64" align="center"><font size="3" face="Calibri">(V) Avg across all requests</font></td>
<td valign="middle" width="60" align="center"><font size="3" face="Calibri">(V) Average Request (ms)</font></td>
<td valign="middle" width="59" align="center"><font size="3" face="Calibri">(S) Requests per second</font></td>
<td valign="middle" width="65" align="center"><font size="3" face="Calibri">(S) Avg across all requests</font></td>
<td valign="middle" width="57" align="center"><font size="3" face="Calibri">(S) Average Request (ms)</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6592</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.152</font></td>
<td width="60" align="center"><font size="3" face="Calibri">1</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3078</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.325</font></td>
<td width="57" align="center"><font size="3" face="Calibri">3</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6915</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.145</font></td>
<td width="60" align="center"><font size="3" face="Calibri">3</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3568</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.280</font></td>
<td width="57" align="center"><font size="3" face="Calibri">7</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">7071</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.141</font></td>
<td width="60" align="center"><font size="3" face="Calibri">7</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3539</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.283</font></td>
<td width="57" align="center"><font size="3" face="Calibri">14</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6860</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.146</font></td>
<td width="60" align="center"><font size="3" face="Calibri">13</font></td>
<td width="59" align="center"><font siz<br />
e="3" face="Calibri">3565</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.280</font></td>
<td width="57" align="center"><font size="3" face="Calibri">28</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">7252</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.138</font></td>
<td width="60" align="center"><font size="3" face="Calibri">27</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3506</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.285</font></td>
<td width="57" align="center"><font size="3" face="Calibri">57</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">10k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">7181</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.139</font></td>
<td width="60" align="center"><font size="3" face="Calibri">56</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3518</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.284</font></td>
<td width="57" align="center"><font size="3" face="Calibri">113</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4636</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.216</font></td>
<td width="60" align="center"><font size="3" face="Calibri">2</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2949</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.339</font></td>
<td width="57" align="center"><font size="3" face="Calibri">3</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5954</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.168</font></td>
<td width="60" align="center"><font size="3" face="Calibri">4</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3168</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.316</font></td>
<td width="57" align="center"><font size="3" face="Calibri">7</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6036</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.166</font></td>
<td width="60" align="center"><font size="3" face="Calibri">8</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3118</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.321</font></td>
<td width="57" align="center"><font size="3" face="Calibri">16</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6060</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.165</font></td>
<td width="60" align="center"><font size="3" face="Calibri">16</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3247</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.308</font></td>
<td width="57" align="center"><font size="3" face="Calibri">30</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6066</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.165</font></td>
<td width="60" align="center"><font size="3" face="Calibri">32</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3226</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.310</font></td>
<td width="57" align="center"><font size="3" face="Calibri">61</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">15k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">6048</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.165</font></td>
<td width="60" align="center"><font size="3" face="Calibri">66</font></td>
<td width="59" align="center"><font size="3" face="Calibri">3092</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.323</font></td>
<td width="57" align="center"><font size="3" face="Calibri">129</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4689</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.213</font></td>
<td width="60" align="center"><font size="3" face="Calibri">2</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2553</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.392</font></td>
<td width="57" align="center"><font size="3" face="Calibri">3</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5342</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.187</font></td>
<td width="60" align="center"><font size="3" face="Calibri">4</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2675</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.374</font></td>
<td width="57" align="center"><font size="3" face="Calibri">9</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="cen<br />
ter"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5422</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.184</font></td>
<td width="60" align="center"><font size="3" face="Calibri">9</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2799</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.357</font></td>
<td width="57" align="center"><font size="3" face="Calibri">17</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5446</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.184</font></td>
<td width="60" align="center"><font size="3" face="Calibri">18</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2861</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.349</font></td>
<td width="57" align="center"><font size="3" face="Calibri">34</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5430</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.184</font></td>
<td width="60" align="center"><font size="3" face="Calibri">36</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2795</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.358</font></td>
<td width="57" align="center"><font size="3" face="Calibri">71</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">20k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">5400</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.185</font></td>
<td width="60" align="center"><font size="3" face="Calibri">74</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2656</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.376</font></td>
<td width="57" align="center"><font size="3" face="Calibri">150</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4135</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.242</font></td>
<td width="60" align="center"><font size="3" face="Calibri">2</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2331</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.429</font></td>
<td width="57" align="center"><font size="3" face="Calibri">4</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4485</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.223</font></td>
<td width="60" align="center"><font size="3" face="Calibri">5</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2308</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.433</font></td>
<td width="57" align="center"><font size="3" face="Calibri">10</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4488</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.223</font></td>
<td width="60" align="center"><font size="3" face="Calibri">11</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2221</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.450</font></td>
<td width="57" align="center"><font size="3" face="Calibri">22</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4446</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.225</font></td>
<td width="60" align="center"><font size="3" face="Calibri">22</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2217</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.451</font></td>
<td width="57" align="center"><font size="3" face="Calibri">45</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4311</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.232</font></td>
<td width="60" align="center"><font size="3" face="Calibri">46</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2180</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.459</font></td>
<td width="57" align="center"><font size="3" face="Calibri">91</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">25k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">4160</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.240</font></td>
<td width="60" align="center"><font size="3" face="Calibri">96</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2026</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.493</font></td>
<td width="57" align="center"><font size="3" face="Calibri">197</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3463</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.289</font></td>
<td width="60" align="center"><font size="3" face="Calibri">2</font></td>
<td width="59" align="center"><font size="<br />
3" face="Calibri">1936</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.516</font></td>
<td width="57" align="center"><font size="3" face="Calibri">5</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3689</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.271</font></td>
<td width="60" align="center"><font size="3" face="Calibri">6</font></td>
<td width="59" align="center"><font size="3" face="Calibri">2002</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.499</font></td>
<td width="57" align="center"><font size="3" face="Calibri">12</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3661</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.273</font></td>
<td width="60" align="center"><font size="3" face="Calibri">13</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1887</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.530</font></td>
<td width="57" align="center"><font size="3" face="Calibri">26</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3627</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.276</font></td>
<td width="60" align="center"><font size="3" face="Calibri">27</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1778</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.562</font></td>
<td width="57" align="center"><font size="3" face="Calibri">56</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3589</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.279</font></td>
<td width="60" align="center"><font size="3" face="Calibri">55</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1746</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.573</font></td>
<td width="57" align="center"><font size="3" face="Calibri">114</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">30k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">3541</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.282</font></td>
<td width="60" align="center"><font size="3" face="Calibri">112</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1798</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.556</font></td>
<td width="57" align="center"><font size="3" face="Calibri">222</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2752</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.363</font></td>
<td width="60" align="center"><font size="3" face="Calibri">3</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1602</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.624</font></td>
<td width="57" align="center"><font size="3" face="Calibri">6</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2824</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.354</font></td>
<td width="60" align="center"><font size="3" face="Calibri">8</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1584</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.631</font></td>
<td width="57" align="center"><font size="3" face="Calibri">15</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2826</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.354</font></td>
<td width="60" align="center"><font size="3" face="Calibri">17</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1492</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.670</font></td>
<td width="57" align="center"><font size="3" face="Calibri">33</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2827</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.354</font></td>
<td width="60" align="center"><font size="3" face="Calibri">35</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1551</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.645</font></td>
<td width="57" align="center"><font size="3" face="Calibri">64</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2822</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.354</font></td>
<td width="60" align="center"><font size="3" face="Calibri">70</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1538</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.65</font></td>
<td width="57" align="center"><font size="3" face="Calibri">130</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">40k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2794</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.358</font></td>
<td width="60" align="center"><font size="3" face="Calibri">143</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1372</font></td>
<td width="65<br />
" align="center"><font size="3" face="Calibri">0.728</font></td>
<td width="57" align="center"><font size="3" face="Calibri">291</font></td>
</tr>
<tr valign="bottom">
<td bgcolor="#748c42" width="40">&#160;</td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="58"></td>
<td bgcolor="#748c42" width="64"></td>
<td bgcolor="#748c42" width="60"></td>
<td bgcolor="#748c42" width="59"></td>
<td bgcolor="#748c42" width="65"></td>
<td bgcolor="#748c42" width="57"></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">10</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2254</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.443</font></td>
<td width="60" align="center"><font size="3" face="Calibri">4</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1401</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.713</font></td>
<td width="57" align="center"><font size="3" face="Calibri">7</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">25</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2265</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.441</font></td>
<td width="60" align="center"><font size="3" face="Calibri">11</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1379</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.725</font></td>
<td width="57" align="center"><font size="3" face="Calibri">18</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">50</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2266</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.441</font></td>
<td width="60" align="center"><font size="3" face="Calibri">22</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1368</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.731</font></td>
<td width="57" align="center"><font size="3" face="Calibri">36</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">100</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2268</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.441</font></td>
<td width="60" align="center"><font size="3" face="Calibri">44</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1360</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.735</font></td>
<td width="57" align="center"><font size="3" face="Calibri">73</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">200</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2266</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.441</font></td>
<td width="60" align="center"><font size="3" face="Calibri">88</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1230</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.813</font></td>
<td width="57" align="center"><font size="3" face="Calibri">162</font></td>
</tr>
<tr valign="bottom">
<td width="40" align="center"><font size="3" face="Calibri">50k</font></td>
<td width="59" align="center"><font size="3" face="Calibri">400</font></td>
<td width="58" align="center"><font size="3" face="Calibri">2267</font></td>
<td width="64" align="center"><font size="3" face="Calibri">0.441</font></td>
<td width="60" align="center"><font size="3" face="Calibri">176</font></td>
<td width="59" align="center"><font size="3" face="Calibri">1216</font></td>
<td width="65" align="center"><font size="3" face="Calibri">0.822</font></td>
<td width="57" align="center"><font size="3" face="Calibri">328</font></td>
</tr>
</tbody>
</table>
<p>Here are the graphs of the above data for easier visualization:</p>
<p><a href="http://deserialized.com/wp-content/uploads/2009/09/varnishsquidbenchmarkreqpersecond2.gif"><img style="border-bottom: 0px; border-left: 0px; display: inline; border-top: 0px; border-right: 0px" title="" border="0" alt="" src="http://deserialized.com/wp-content/uploads/2009/09/varnishsquidbenchmarkreqpersecond_thumb2.gif" width="200" height="244" /></a>&#160;&#160;&#160; <a href="http://deserialized.com/wp-content/uploads/2009/09/varnishsquidbenchmarkavgrequesttime2.gif"><img style="border-bottom: 0px; border-left: 0px; display: inline; border-top: 0px; border-right: 0px" title="" border="0" alt="" src="http://deserialized.com/wp-content/uploads/2009/09/varnishsquidbenchmarkavgrequesttime_thumb2.gif" width="200" height="244" /></a> </p>
<p>&#160;</p>
<h2>Something is wrong here</h2>
<p>These are simply benchmarks and are not meant to represent real world scenarios for a few reasons.&#160; Most importantly, this test takes place on a local network that goes through one router.&#160; Running this test on a local network does not take into consideration the typical network latency you would find across the internet.</p>
<p>Secondly, this test only illustrates the raw speed of serving up cached content which isn’t a typical real world scenario.&#160; To really test the overall performance of both of these, we need to simulate the three major steps of a reverse proxy: </p>
<ol>
<li>Forwarding a request to a backend server</li>
<li>Physically caching it (memory or disk)</li>
<li>Serving the cached data</li>
</ol>
<p>Testing any of these three steps is good, and shows the raw performance of that function but it doesn’t give us a general overview of the overall performance.</p>
<p>&#160;</p>
<h2>Next Steps</h2>
<p>I need to come up with a way to generate load on the server such that it represents the typical flow of requests that we would normally see on a server.&#160; I am running this on a test server, not against production data, so if anyone has an idea of how I can do this, please do let me know.&#160; The results of this test will be Part 2 of this post.</p>
<p>Additionally, please let me know if you spot inefficiencies in my testing methodology. I don’t claim to be a load testing expert so any advice you can offer is appreciated.</p>
]]></content:encoded>
			<wfw:commentRss>http://deserialized.com/caching/reverse-proxy-performance-varnish-vs-squid-part-1/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
	</channel>
</rss>

