2008-01-01 17:20:07 -07:00
|
|
|
<!DOCtype HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<title>Running Tahoe</title>
|
|
|
|
<link rev="made" class="mailto" href="mailto:zooko[at]zooko[dot]com">
|
|
|
|
<meta name="description" content="how to run Tahoe">
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
2008-01-03 21:11:59 -07:00
|
|
|
<meta name="keywords" content="tahoe secure decentralized filesystem operation">
|
2008-01-01 17:20:07 -07:00
|
|
|
</head>
|
|
|
|
|
|
|
|
<body>
|
2008-01-08 10:32:41 -07:00
|
|
|
<h1>How To Start Tahoe</h1>
|
2008-01-01 17:20:07 -07:00
|
|
|
|
2009-06-21 10:50:05 -07:00
|
|
|
<p>This is how to run a Tahoe client or a complete Tahoe grid. First you
|
|
|
|
have to install the Tahoe software, as documented in <a
|
2008-01-01 21:50:46 -07:00
|
|
|
href="install.html">install.html</a>.</p>
|
|
|
|
|
2009-08-09 13:14:16 -07:00
|
|
|
<p>The <cite>tahoe</cite> executable in the <code>bin</code> directory is
|
2009-06-21 10:50:05 -07:00
|
|
|
used to create, start, and stop nodes. Each node lives in a separate base
|
2009-08-09 13:14:16 -07:00
|
|
|
directory, in which there is a configuration file named <code>tahoe.cfg</code>. Nodes
|
|
|
|
read and write files within this base directory.</p>
|
2008-01-01 21:50:46 -07:00
|
|
|
|
2009-08-09 13:14:16 -07:00
|
|
|
<p>A grid consists of a set of <em>nodes</em>, computers running
|
|
|
|
the tahoe code, each of these nodes functions as in one of the
|
|
|
|
following roles:</p>
|
|
|
|
|
|
|
|
<dl>
|
|
|
|
<dt>Storage Nodes (or Server Nodes)</dt><dd>are the computers
|
|
|
|
that actually store the data in a grid.</dd>
|
|
|
|
<dt>Client Nodes</dt><dd>talk to the storage nodes to put files
|
|
|
|
onto the grid and get them back off again.</dd>
|
|
|
|
<dt>Introducer Node</dt><dd>is responsible for getting everybody
|
|
|
|
talking to each other.</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<p>If you're getting started we recommend you try connecting to
|
|
|
|
the <a href="http://allmydata.org/trac/tahoe/wiki/TestGrid">the
|
|
|
|
public test grid</a> as you only need to create a client node.
|
|
|
|
When you want to create your own grid you'll need to create the
|
|
|
|
introducer and an initial storage nodes.</p>
|
2009-06-21 10:50:05 -07:00
|
|
|
|
2009-08-09 13:14:16 -07:00
|
|
|
<p>To construct a client node, run
|
|
|
|
"<code><strong>path-to-the-tahoe-bin-directory</strong>/tahoe
|
|
|
|
create-client</code>", which will create <code>~/.tahoe</code> to be the
|
|
|
|
node's base directory. Acquire a copy of the <code>introducer.furl</code>
|
2009-06-21 10:50:05 -07:00
|
|
|
from the introducer and put it into this directory, then run
|
2009-08-09 13:14:16 -07:00
|
|
|
"<code><strong>path-to-the-tahoe-bin-directory</strong>/tahoe
|
|
|
|
start</code>". After that, the node should be off and running. The first
|
2009-06-21 10:50:05 -07:00
|
|
|
thing it will do is connect to the introducer and get itself connected to
|
2009-08-09 13:14:16 -07:00
|
|
|
all other nodes on the grid. By default, a node will serve as a storage
|
|
|
|
node, meaning that it offers its disk space to other nodes. To configure
|
2009-06-21 10:50:05 -07:00
|
|
|
other behavior, see <a href="configuration.txt">configuration.txt</a>.</p>
|
|
|
|
|
2009-08-09 13:14:16 -07:00
|
|
|
|
|
|
|
<p>To construct an introducer, create a new base directory for it (the name
|
|
|
|
of the directory is up to you), cd into it, and run
|
|
|
|
"<code><strong>path-to-the-tahoe-bin-directory</strong>/tahoe
|
|
|
|
create-introducer .</code>". Now start the introducer by running
|
|
|
|
"<code>tahoe start .</code>". After it starts, it will write a file named
|
|
|
|
<code>introducer.furl</code> in that base directory. This file contains the
|
|
|
|
URL the other nodes must use in order to connect to this introducer.</p>
|
2009-06-21 10:50:05 -07:00
|
|
|
|
|
|
|
<p>To stop a running node run
|
2009-08-09 13:14:16 -07:00
|
|
|
"<code><strong>path-to-the-tahoe-bin-directory</strong>/tahoe
|
|
|
|
stop</code>".</p>
|
|
|
|
|
|
|
|
|
|
|
|
<p>See <a href="configuration.txt">configuration.txt</a> for more
|
|
|
|
details about how to configure tahoe.</p>
|
|
|
|
|
|
|
|
|
|
|
|
<h2>A note about firewalls</h2>
|
|
|
|
|
|
|
|
<p>If your node is behind a firewall or NAT device and want other
|
|
|
|
clients to connect to it then you'll need to <em>open a port</em>
|
|
|
|
in your firewall. To do that you'll need to know which port tahoe
|
|
|
|
is listening on as, by default, it listens on an arbitrary port
|
|
|
|
number. To tell tahoe to listen to a fixed port, open the
|
|
|
|
<code>~/.tahoe/tahoe.cfg</code> file in your favourite text editor
|
|
|
|
and changing the <code>tub.port</code> line to something like the
|
|
|
|
following:</p>
|
|
|
|
|
|
|
|
<pre>tub.port = 8098</pre>
|
|
|
|
|
|
|
|
<p>This tells tahoe to always listen on port 8098 of your
|
|
|
|
computer. The next issue is that your computer may be behind a
|
|
|
|
NATing router and isn't directly connected to the internet but
|
|
|
|
goes through a router to get out. If that's the case then you'll
|
|
|
|
need to set the <code>tub.location</code> option so that tahoe
|
|
|
|
tells the introducer where you're really listening:</p>
|
|
|
|
|
|
|
|
<pre>tub.location = myserver.mydomain.org:8098</pre>
|
|
|
|
|
|
|
|
<p>or probably more likely</p>
|
|
|
|
|
|
|
|
<pre>tub.location = 123.456.789.012:8098</pre>
|
|
|
|
|
|
|
|
<p>The <a href="configuration.txt">configuration.txt</a> file contains more details</p>
|
2008-01-01 21:50:46 -07:00
|
|
|
|
2008-02-14 08:54:34 -07:00
|
|
|
<h2>Do Stuff With It</h2>
|
2008-01-08 10:32:41 -07:00
|
|
|
|
2009-06-21 10:50:05 -07:00
|
|
|
<p>Now you have a decentralized filesystem. See <a
|
|
|
|
href="using.html">using.html</a> for instructions about how to interact
|
|
|
|
with it.</p>
|
2008-01-01 21:50:46 -07:00
|
|
|
|
|
|
|
</body>
|
|
|
|
|
|
|
|
</html>
|