1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403
|
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<HTML VERSION="2.0">
<HEAD>
<!-- $Id: FAQ-webstone.html 80826 2008-03-04 14:51:23Z wotte $ -->
<!-- WEBMAGIC VERSION NUMBER="2.0.1" -->
<!-- WEBMAGIC TRANSLATION NAME="ServerRoot" SRC="/var/www/htdocs/" DST="/" -->
<!-- WEBMAGIC TRANSLATION NAME="ProjectRoot" SRC="./" DST="" -->
<TITLE>WebStone FAQ</TITLE>
</HEAD>
<BODY>
<P><!-- Changed by: Michael Blakeley, 9-Nov-1995 --></P>
<H1><IMG SRC="webstone.gif" WIDTH="534" HEIGHT="174" SGI_SETWIDTH SGI_SETHEIGHT SGI_FULLPATH="/disk6/WebStone-2.0/doc/webstone.gif"></H1>
<CENTER><H1 ALIGN="CENTER">WebStone</H1>
</CENTER><CENTER><H2 ALIGN="CENTER">Frequently Asked Questions, with Answers</H2>
</CENTER><CENTER><ADDRESS ALIGN="CENTER"><A HREF="mailto:schan@engr.sgi.com">Stephen Chan, schan@engr.sgi.com</A></ADDRESS>
</CENTER><CENTER><ADDRESS ALIGN="CENTER"><A HREF="http://www.sgi.com/Products/WebFORCE/">WebFORCE</A> Technical Marketing, <A HREF="http://www.sgi.com">Silicon Graphics</A></ADDRESS>
</CENTER><CENTER><ADDRESS ALIGN="CENTER">Last revised: 9 November 1995</ADDRESS>
</CENTER><HR>
<P><STRONG>This document answers frequently-asked questions about WebStone.</STRONG> </P>
<UL>
<LI><A HREF="#meta-FAQ">Meta-FAQ</A>: What is this document? Where can I get a copy?
<LI><A HREF="#diff">What is the difference between WebStone 1.1 and WebStone 2.0?</A>
<LI><A HREF="#compare1.1&2">Can I compare WebStone 1.1 and WebStone 2.0 numbers against each other?</A>
<LI><A HREF="#what-is">What is WebStone?</A>
<LI><A HREF="#webperf">What about Webperf?</A>
<LI><A HREF="#what-does">What does WebStone do?</A>
<LI><STRONG><A HREF="#_wmh2_815967937">Feature Enhancements in WebStone 2.0</STRONG></A>
<LI><A HREF="#does-not">What doesn't WebStone do?</A>
<LI><A HREF="#obtaining">Where can I get WebStone?</A>
<LI><A HREF="#running">How do I run WebStone?</A>
<UL>
<LI>Experimental GUI
</UL>
<LI><A HREF="#common-problems">Common problems when running WebStone</A>
<UL>
<LI><A HREF="#swap-space">Out of swap space</A>
<LI><A HREF="#timing-info">Error reading timing info</A>
</UL>
<LI><A HREF="#interpreting">What do the results mean?</A>
<LI><A HREF="#majordomo">I'm still having problems. Where can I get help?</A>
<LI><A HREF="#legal">Legal issues</A>
</UL>
<P>If you have comments about this document, please forward them to the <A HREF="mailto:mblakele@engr.sgi.com">author</A>. </P>
<HR>
<H2><A NAME="meta-FAQ">Meta-FAQ: What is this document? Where can I get a copy?</A></H2>
<P>This is a list of answers to Frequently Asked Questions (FAQ) about WebStone.
The latest copy is always available at <A HREF="http://www.sgi.com/Products/WebFORCE/WebStone">http://www.sgi.com/Products/WebFORCE/WebStone/</A> and via the WebStone mailing list. The FAQ is periodically posted to the <A HREF="#majordomo">WebStone mailing list</A>, and to the USENET newsgroup <A HREF="news:comp.benchmarks">comp.benchmarks</A>. </P>
<HR>
<H2><A NAME="diff">What is the difference between WebStone 1.1 and WebStone 2.0?</A></H2>
<P>WebStone 2.0 is a rewrite of the WebStone 1.1 code. Significant changes
have been made both in the code and in the fileset and run rules. Many bugs
were eliminated, support for other platforms has been included and many
new features have been added. The WebStone 1.1 and WebStone 2.0 numbers
cannot be compared, since so much has changed. In general, WebStone 1.1
will give higher connections/second values, but lower throughput numbers
than WebStone 2.0.</P>
<HR>
<H2><A NAME="compare1.1&2">Can I compare WebStone 1.1 and WebStone 2.0 numbers against each other?</A></H2>
<P>Absolutely NOT! WebStone 1.1 numbers are based on a different fileset, as
well as an older version of the benchmarking software. The WebStone 1.1
fileset was based on a fileset with a smaller average filesize, so that
the number of connections per second will tend to be higher (all things
being equal). The WebStone 2.0 fileset is based on observations of several
real world sites, and the distribution of the filesizes found there. This
fileset is also similar to the fileset chosen by the SPEC committee for
their benchmark.</P>
<P>While it is possible to convert the 1.1 fileset to a 2.0 format and then
test it, the resulting numbers will not be the same, because the underlying
software used to perform the testing has changed. WebStone 1.1 was also
heavily abused because of the lack of run rules, and reporting rules. It
is recommended that everyone move to WebStone 2.0.</P>
<HR>
<P></P>
<H2><A NAME="what-is">What is WebStone?</A></H2>
<P>WebStone is a highly-configurable client-server benchmark for HTTP servers. </P>
<P>The original WebStone benchmark was released in March, 1995. The original
white paper describing this benchmark is available from <A HREF="http://www.sgi.com/Products/WebFORCE/WebStone">http://www.sgi.com/Products/WebFORCE/WebStone/.</A> </P>
<P>WebStone is not a proprietary benchmark - it is an open benchmark. The source
code is freely available, and anyone can examine it. By design, WebStone
does not unfairly favor SGI, Netscape, or any other company - it is simply
a performance measurement tool. </P>
<HR>
<H2><A NAME="webperf">What about Webperf?</A></H2>
<P>A SPEC SFS working group is presently adapting SPEC SFS to Web server benchmarking.
SGI's WebStone team is part of this working group, and we support fully
the effort. WebStone is available to fulfill the immediate Web benchmarking
needs - not to confuse the public.</P>
<P>Basically, if you like WebStone, use it. When SPEC releases Webperf, check
it out.</P>
<HR>
<H2><A NAME="what-does">What does WebStone do?</A></H2>
<P>WebStone makes a user-configurable number of HTTP 1.0 GET requests for specific
pages on a Web server. Any Web server can be tested, and any HTML content
can be used. </P>
<P>WebStone measures the throughput and latency of each HTTP transfer. By default,
only statistical data are returned, but the user may optionally request
data for each and every transaction. WebStone also reports transaction failures,
which translate into those little "Connection Refused" alerts in the real
world.</P>
<HR>
<H2><A NAME="_wmh2_815967937">Feature Enhancements in WebStone 2.0</A></H2>
<P>WebStone 2.0 includes support for testing proxy servers, as well as more
flexible handling of URL's that enable WebStone to test a wide variety of
content types. The code has also been significantly rewritten so that it
is more robust and portable.</P>
<HR>
<H2><A NAME="does-not">What doesn't WebStone do?</A></H2>
<P>WebStone does not yet do any of the following (listed roughly in order of
planned implementation): </P>
<UL>
<LI>POST transactions, widely used for CGI-bin scripts
</UL>
<P>If you have additional requests for WebStone functionality, contact the <A HREF="#majordomo">WebStone mailing list</A>. </P>
<HR>
<H2><A NAME="obtaining">Where can I get WebStone?</A></H2>
<P>The latest copy of WebStone, and of this FAQ, is available at <A HREF="http://www.sgi.com/Products/WebFORCE/WebStone">http://www.sgi.com/Products/WebFORCE/WebStone</A> </P>
<HR>
<H2><A NAME="running">How do I run WebStone?</A></H2>
<P>WebStone includes a README file which may answer some of your questions.
However, here's a brief overview. </P>
<OL>
<LI><A HREF="#test-bed">Set up your test-bed</A>
<LI><A HREF="#loading-webstone">Load WebStone onto your webmaster </A>
<LI><A HREF="#edit-runbench">Edit <CODE>testbed</CODE></A>
<LI><A HREF="#file-list">Write a file list</A>
<LI><A HREF="#start-benchmark">Start the benchmark</A>
<LI><A HREF="#collect-results">Collect the results</A>
</OL>
<H3>WebStone now has an experimental GUI!</H3>
<P>To try the GUI, make sure you have a Web browser, and run <CODE>./webstone -gui</CODE> from the WebStone base directory. You don't need to hand-edit the <CODE>testbed</CODE> file anymore, but you still need to edit <CODE>filelist</CODE> if you want to change the workload. This may not be necessary, since we've
distributed two real-world workload models with WebStone. </P>
<P>These are the stepts to follow to run the GUI </P>
<OL>
<LI><A HREF="#test-bed">Set up your test-bed</A>
<LI><A HREF="#loading-webstone">Load WebStone onto your webmaster </A>
<LI><CODE>./configure</CODE>
<LI><CODE>./webstone -gui</CODE>
</OL>
<P>If the GUI appears to hang, you can kill stray WebStone processes with <CODE>./webstone -kill</CODE> </P>
<H3><A NAME="test-bed">Setting up your test bed</A></H3>
<P>Your test bed should include, at minimum, two machines and a network. The
first machine is your Web server - it can be any HTTP 1.0-compliant server.
As far as WebStone is concerned, it's a black box. </P>
<P>You'll also need a webmaster and one or more webclients. These should be
Unix hosts, since WebStone hasn't been tested on any non-Unix operating
systems (feel free to port it, if you like). The webmaster and the webclient
may be the same machine, if desired: we've run up to 120 webclients and
the webmaster on a single 32MB Indy. </P>
<P>You must establish a trust relationship between your webmaster and webclients.
Each webclient must be set up so that the webmaster can use <CODE>rexec</CODE> to execute the WebStone on the client. This can be done with a guest account.
It's also helpful if root can <CODE>rexec</CODE> and <CODE>rcp</CODE> to the webclients, and even to the web server. This requires editing the <CODE>/.rhosts</CODE> and <CODE>/etc/host.equiv</CODE> files. Here's an example: </P>
<P><CODE>/.rhosts</CODE> (on each webclient) </P>
<PRE>
webmaster root
</PRE>
<P><CODE>/etc/hosts/equiv</CODE> (on each webclient) </P>
<PRE>
webmaster
</PRE>
<P>To make best use of WebStone, your webmaster should be equipped with a C
compiler, Perl, awk, and a Web browser. A data analysis program such as
GnuPlot may also come in handy. </P>
<P>Connect the webclients, the webmaster, and the web server to a common network.
To check your setup, load a browser on one of the webclients, and make sure
it can connect to the Web server. </P>
<H3><A NAME="loading-webstone">Loading WebStone</A></H3>
<P>Copy the WebStone distribution onto your webmaster. If your webmaster isn't
an SGI IRIX 5.3 machine, you'll have to make the binaries. Type <KBD>make</KBD> from the WebStone directory - this creates the following binaries: </P>
<PRE>
webmaster
webclient
</PRE>
<P>Common porting errors </P>
<UL>
<LI>If you want to use gcc instead of cc, change the CC variable in <CODE>src/Makefile</CODE>.
<LI>Many System V-based Unix implementations (such as Solaris 2.x) will need<CODE> LIBS = -lsocket -lnsl</CODE> in <CODE>src/Makefile</CODE>.
<LI>Some users may also need to comment out the definition of <CODE>rexec</CODE> in <CODE>webmaster.c</CODE>
</UL>
<P>If you encounter other errors, please contact the <A HREF="#majordomo">WebStone mailing list</A>. </P>
<P>Type <CODE>make install</CODE> to put the binaries in the <CODE>bin</CODE> directory. </P>
<P>When you run WebStone, the <CODE>distribute</CODE> script automatically copies the <CODE>webclient</CODE> binary to the other client systems. If you're running diverse clients (e.g.,
a couple Suns, a couple BSD hosts), you'll want to comment the <CODE>distribute</CODE> script out of <CODE>bin/runbench</CODE>, and distribute host-specific versions of <CODE>webclient</CODE> by hand. </P>
<H3><A NAME="edit-runbench">Edit <CODE></A>testbed</CODE></H3>
<P>If you use the <CODE>webstone</CODE> script to automate WebStone, you'll want to edit the <CODE>conf/testbed</CODE> script. The <CODE>testbed</CODE> script contains several configurable parameters that WebStone relies on.
Here is an example: </P>
<PRE>
### BENCHMARK PARAMETERS -- EDIT THESE AS REQUIRED
ITERATIONS="3"
MINCLIENTS="8"
MAXCLIENTS="128"
CLIENTINCR="8"
TIMEPERRUN="30"
### SERVER PARAMETERS -- EDIT AS REQUIRED
#PROXY=
SERVER="www"
PORTNO=80
SERVERINFO=hinv
OSTUNINGFILES="/var/sysgen/master.d/bsd"
WEBSERVERDIR="/usr/ns-home"
WEBDOCDIR="$WEBSERVERDIR/docs"
WEBSERVERTUNINGFILES="$WEBSERVERDIR/httpd-80/config/magnus.conf $WEBSERVERDIR/httpd-80/config/obj.conf"
# WE NEED AN ACCOUNT WITH A FIXED PASSWORD, SO WE CAN REXEC
# THE WEBSTONE CLIENTS
CLIENTS="webstone1 webstone2 webstone3 webstone4 webstone5"
CLIENTACCOUNT=guest
CLIENTPASSWORD=guest
CLIENTINFO=hinv
TMPDIR=/tmp
</PRE>
<P>Briefly, the first set of parameters means that the WebStone benchmark will
run from 8 clients to 128 clients, in increments of 8. Each increment will
run for 30 minutes, and the whole test will be repeated three times. This
test suite would take roughly 24 hours to complete. </P>
<P>Why multiple iterations? The WebStone benchmark is a stochastic process
so there will be variation from run to run, especially if your test file
sets have large files or if you approach overloading the server. 3 iterations
is about the minimum you should run just to see if there is variation and
to gauge the amount of variation. the <TT>TIMEPERRUN</TT> needs to be long enough to establish a steady state and allow it to dominate
the run. 30 minutes seems to be enough if the sizes of the files are small.
You may want to run the benchmark longer per run to minimize variation if
the files are large. </P>
<P>The second set of parameters means that we will test a server called "www"
at port 80 (note that the port number may be changed to accomodate proxy
servers or multiple servers on the same host). We will use four clients.
Also, we specify the location of a system tuning file (on Sun Solaris, one
could use /etc/system), and web server tuning files (specified for Netscape).
These files will be copied into the <CODE>runs</CODE> subdirectories for later reference. </P>
<P>Finally, we specify the WebStone account on the clients. Here, we use the
guest account, with a fixed password: guest. </P>
<H3><A NAME="file-list">Write a file list</A></H3>
<P>The basic WebStone tests expect a set of files to reside on the server to
be retrieved by the <TT>webstone</TT> client programs. The file list tells WebStone which files to retrieve. </P>
<P>It's possible to use an arbitrary set of fixed-length files for WebStone.
Although these files have the <TT>.html</TT> extension, they are used to represent files of many types. Basically we
treat "bits-as-bits". You can use the programs in the <TT>genfileset</TT> subdirectory to create the needed set of files, and copy them onto your
server: </P>
<PRE>
./webstone -genfiles
</PRE>
<P>The sample file list shipped with WebStone uses the files created by genfiles: </P>
<P># Sample filelist, abstracted from access logs<BR>
/file500.html 350 #500<BR>
/file5k.html 500 #5125<BR>
/file50k.html 140 #51250<BR>
/file500k.html 9 #512500<BR>
/file5m.html 1 #5248000<BR>
</P>
<P>This filelist consists of 5 different files. The number following the filename
is the weight of this file in the distribution. All the weights are summed
together and the frequency of each file is the weight of that file over
the total weights.</P>
<P>For example, in this fileset the weights add up to 1000. So the the file500k.html
page will occur 350 out of 1000 times, and the file5m.html will occur once
every 1000 pages. </P>
<P>Note that the URI should be changed to a full URI when testing proxy servers,
for example, if the proxy server is called proxy, but the actual server
which stores the file is called seltzer1, you could use the following filelist:</P>
<P> #Sample filelist, abstracted from access logs<BR>
http://seltzer1.sgi.com/file500.html 350 #500<BR>
http://seltzer1.sgi.com/file5k.html 500 #5125<BR>
http://seltzer1.sgi.com/file50k.html 140 #51250<BR>
http://seltzer1.sgi.com/file500k.html 9 #512500<BR>
http://seltzer1.sgi.com/file5m.html 1 #5248000</P>
<P>This URI is the one which is passed to the proxy server, which in turn uses
it to fetch the file from seltzer1.sgi.com. Notice that the particular files
and the distribution are identical to the previous filelist. The other change
which would need to be made for testing proxy servers is to have an entry
"PROXY=proxy" in the testbed file and to specify the port where the proxy
server listens for requests.</P>
<P>Wherever possible, use the same pages for WebStone that you will use in
the real world. This means that you'll have a harder time comparing your
results with published results, but your results will more accurately reflect <STRONG>your</STRONG> situation. </P>
<H3><A NAME="start-benchmark">Start the benchmark</A></H3>
<P>type <CODE>./webstone</CODE> </P>
<P>The results of each run will be saved in a directory called <TT>runs</TT>. Note that the runbench script attempts to collect configuration information
about your client and server configurations such as netstat results. You
may see some error messages if your clients don't have netstat or other
utilities. </P>
<H3><A NAME="collect-results">Collect the results</A></H3>
<P>The WebStone summary statistics generated by <TT>webmaster</TT> are saved by <TT>runbench</TT> in a date stamped subdirectory of the <TT>runs</TT> directory in the current directory similar to: </P>
<PRE>
runs/950804_2304/run
</PRE>
<P>The script wscollect is provided as a tool for collected the results of
all of the runs and generating a tab delimited file with all of the results.
This file can be read into a spreadsheet or read by other analysis programs. </P>
<PRE>
wscollect runs > runs.tabs
</PRE>
<P>An additional script called <TT>tabs2html</TT> will take a tab delimited file and produce an HTML 3.0 style table of the
results: </P>
<PRE>
tabs2html runs.tabs > runs.html
</PRE>
<HR>
<H2><A NAME="common-problems">Common problems when running WebStone</A></H2>
<H3><A NAME="swap-space">Out of swap space</A></H3>
<P>It's fairly common for the Web server under test to run out of swap space.
As a rule of thumb, make sure that you have swap space equal to the number
of server processes times the size of the largest test file. </P>
<P>For instance, if you're testing a 10MB file on a Netscape server with 64
processes, you'll need to have at least 640MB of swap space. <CITE>N.B.</CITE>: On SGI IRIX 5.x, you can substitute large amounts of <EM>virtual swap space</EM>, since Netscape doesn't actually use all the space it asks for. </P>
<P>See your operating system-specific administration guide for details on adding
and configuring swap space. </P>
<H3><A NAME="timing-info">Error reading timing info</A></H3>
<P><STRONG>Question</STRONG>: </P>
<P>Running: </P>
<PRE>
webmaster -w webmaster -p 9990 -u flist -f config
</PRE>
<P>on jan.near.net </P>
<P>outputs: </P>
<PRE>
Waiting for READY from 6 clients
All READYs received
Sending GO to all clients
All clients started at Tue Aug 8 11:57:30 1995
Waiting for clients completion
Reading results
.Error second reading timing info from one of the clients:
Interrupted system call
web child 1 did not respond. 3456 bytes read
.Error second reading timing info from one of the clients:
Interrupted system call
web child 0 did not respond. 3456 bytes read
</PRE>
<P>What does the second reading timing info contain? What might cause the second
read to fail while the first passes? </P>
<P><STRONG>Answer</STRONG>: </P>
<P>It's most likely that one of the WebStone clients died before it could report
results to the webmaster. We've squashed many circumstances in which this
happens, but bugs continue to appear, especially on systems we haven't tested. </P>
<P>We can't do much for this kind of problem without debugging traces. Edit <CODE>testbed</CODE>, and set the <CODE>DEBUG</CODE> parameter to <CODE>DEBUG=-d</CODE>, so that debugging info will be written to files named /tmp/webstone-debug.<PID>. </P>
<P>If you can replicate this problem with debugging turned on, please let us
know. We'd love to examine the traces. </P>
<P>Another possible source of problems with reading timing info is when a page
in the filelist did not get read by a client, but the webmaster was expecting
to find it. This can happen when the test time, number of clients and filelist
distribution are set up so that a file which gets read infrequently does
not get read _yet_ before the test period ends.This will get ironed out
in a later release of WebStone.</P>
<HR>
<H2><A NAME="interpreting">What do the results mean?</A></H2>
<P>WebStone primarily measures throughput (bytes/second) and latency (time
to complete a request). WebStone also reports pages/minute, connection rate
averages, and other numbers. Some of these may help you to sanity-check
the throughput measurements. </P>
<P>Two types of throughput are measured: aggregate and per-client. Both are
averaged over the entire test time and the entire client base. Aggregate
throughput is simply total bytes (body + header) transferred throughout
the test, divided by the total test time. Per-client throughput divides
aggregate throughput by the number of clients. </P>
<P>Two types of latency are reported: connection latency and request latency.
For each metric, the mean time is provided, as well as the standard deviation
of all data, plus the minimum and maximum times. Connection latency reflects
the time taken to establish a connection, while request latency reflects
the time to complete the data transfer once the connection has been established. </P>
<P>User-perceived latency will include the sum of connection and request latencies,
plus any network latency due to WAN connections, routers, modems, etc. </P>
<P>WebStone also reports a metric called <EM>Little's Ls</EM>. <EM>Ls</EM> is derived from Little's Law, and reflects how much time is spent by the
server on request processing, rather than overhead and errors. Ls. is also an indirect indicator of the average number of connections which
the web server has open at any particular instant. This number should stay
very close to the number of clients, or else some clients are being denied
access to the server at any given time.</P>
<P>If you load your Web servers high enough, you'll begin to see errors in
the results. That's fine (at least as far as WebStone is concerned). It
just means that your server is heavily loaded, and some clients aren't being
serviced before they time out. In fact, the number of errors at a given
load can be an excellent indicator of how your server will perform under
extremely heavy loads. </P>
<HR>
<H2><A NAME="majordomo">I'm still having problems. Where can I get help?</A></H2>
<P>Subscribe to the WebStone mailing list! Send a message to <A HREF="mailto:majordomo@engr.sgi.com">majordomo@engr.sgi.com</A> - the subject doesn't matter, but the content should be: </P>
<PRE>
subscribe webstone
</PRE>
<P>You should receive a message shortly, confirming that you've been added
to the mailing list. You can send to the whole list at <A HREF="mailto:webstone@engr.sgi.com">webstone@engr.sgi.com</A> - the authors of WebStone read the list, and they'll do their best to help.
Other list members may also be able to help. </P>
<P>If you have access to USENET News, you can also read and post to <A HREF="news:comp.benchmarks">comp.benchmarks</A>. As with any newsgroup, read the FAQ before posting! </P>
<P>There's also a mailing list devoted to the performance limits of the HTTP
protocol. You can subscribe by sending e-mail to <A HREF="mailto:www-speed-request@tipper.oit.unc.edu">www-speed-request@tipper.oit.unc.edu</A> with the text </P>
<PRE>
subscribe <your-email-address>
</PRE>
<HR>
<H2><A NAME="legal">Legal Stuff</A></H2>
<P>This file and all files contained in the WebStone distribution are copyright
© 1995, 1996 Silicon Graphics, Inc. </P>
<P>This software is provided without support and without any obligation on
the part of Silicon Graphics, Inc. to assist in its use, correction, modification
or enhancement. There is no guarantee that this software will be included
in future software releases, and it probably will not be included. </P>
<P>THIS SOFTWARE IS PROVIDED "AS IS" WITH NO WARRANTIES OF ANY KIND INCLUDING
THE WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE,
OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. </P>
<P>In no event will Silicon Graphics, Inc. be liable for any lost revenue or
profits or other special, indirect and consequential damages, even if Silicon
Graphics, Inc. has been advised of the possibility of such damages. </P>
</BODY>
</HTML>
|