mirror of
https://github.com/torproject/webwml.git
synced 2025-01-19 08:27:54 +00:00
4594 lines
172 KiB
Plaintext
4594 lines
172 KiB
Plaintext
## translation metadata
|
||
# Revision: $Revision$
|
||
# Translation-Priority: 2-medium
|
||
|
||
#include "head.wmi" TITLE="Tor Project: FAQ" CHARSET="UTF-8"
|
||
<div id="content" class="clearfix">
|
||
<div id="breadcrumbs">
|
||
<a href="<page index>">Home » </a>
|
||
<a href="<page docs/documentation>">Documentation » </a>
|
||
<a href="<page docs/faq>">FAQ</a>
|
||
</div>
|
||
<div id="maincol">
|
||
<!-- PUT CONTENT AFTER THIS TAG -->
|
||
<h1>Tor FAQ</h1>
|
||
<hr>
|
||
|
||
<p>General questions:</p>
|
||
<ul>
|
||
<li><a href="#WhatIsTor">What is Tor?</a></li>
|
||
<li><a href="#Torisdifferent">How is Tor different from other
|
||
proxies?</a></li>
|
||
<li><a href="#CompatibleApplications">What programs can I use with
|
||
Tor?</a></li>
|
||
<li><a href="#WhyCalledTor">Why is it called Tor?</a></li>
|
||
<li><a href="#Backdoor">Is there a backdoor in Tor?</a></li>
|
||
<li><a href="#DistributingTor">Can I distribute Tor?</a></li>
|
||
<li><a href="#SupportMail">How can I get support?</a></li>
|
||
<li><a href="#Forum">Is there a Tor forum?</a></li>
|
||
<li><a href="#WhySlow">Why is Tor so slow?</a></li>
|
||
<li><a href="#FileSharing">How can I share files anonymously through Tor?
|
||
</a></li>
|
||
<li><a href="#OutboundPorts">Do I have to open all these outbound ports
|
||
on my firewall?</a></li>
|
||
<li><a href="#Funding">What would The Tor Project do with more
|
||
funding?</a></li>
|
||
<li><a href="#IsItWorking">How can I tell if Tor is working, and that my
|
||
connections really are anonymized?</a></li>
|
||
<li><a href="#FTP">How do I use my browser for ftp with Tor?</a></li>
|
||
<li><a href="#Metrics">How many people use Tor? How many relays or
|
||
exit nodes are there?</a></li>
|
||
<li><a href="#SSLcertfingerprint">What are your SSL certificate
|
||
fingerprints?</a></li>
|
||
</ul>
|
||
|
||
<p>Compilation and Installation:</p>
|
||
<ul>
|
||
<li><a href="#HowUninstallTor">How do I uninstall Tor?</a></li>
|
||
<li><a href="#PGPSigs">What are these "sig" files on the download
|
||
page?</a></li>
|
||
<li><a href="#GetTor">Your website is blocked in my country. How
|
||
do I download Tor?</a></li>
|
||
<li><a href="#CompileTorWindows">How do I compile Tor under
|
||
Windows?</a></li>
|
||
<li><a href="#VirusFalsePositives">Why does my Tor executable appear
|
||
to
|
||
have a virus or spyware?</a></li>
|
||
<li><a href="#LiveCD">Is there a LiveCD or other bundle that
|
||
includes Tor?</a></li>
|
||
</ul>
|
||
|
||
<p>Tor Browser Bundle:</p>
|
||
<ul>
|
||
|
||
<li><a href="#TBBFlash">Why can't I view videos on YouTube and other
|
||
Flash-based sites?</a></li>
|
||
<li><a href="#Ubuntu">I'm using Ubuntu and I can't start Tor Browser
|
||
</a></li>
|
||
<li><a href="#TBBSocksPort">I want to
|
||
run another application through the Tor launched by Tor Browser
|
||
Bundle.</a></li>
|
||
<li><a href="#TBBPolipo">I need an HTTP proxy. Where did Polipo
|
||
go?</a></li>
|
||
<li><a href="#TBBOtherExtensions">Can I install other Firefox
|
||
extensions? Which extensions should I avoid using?</a></li>
|
||
<li><a href="#TBBJavaScriptEnabled">Why is NoScript configured to
|
||
allow JavaScript by default in the Tor Browser Bundle? Isn't that
|
||
unsafe?</a></li>
|
||
<li><a href="#TBBOtherBrowser">I want to use Chrome/IE/Opera/etc
|
||
with Tor.</a></li>
|
||
<li><a href="#TorbuttonOtherBrowser">Will Torbutton be available for other browsers?</a></li>
|
||
<li><a href="#TBBCloseBrowser">I want to leave Tor Browser Bundle
|
||
running but close the browser.</a></li>
|
||
|
||
<li><a href="#GoogleCAPTCHA">Google makes me solve a CAPTCHA or
|
||
tells
|
||
me I have spyware installed.</a></li>
|
||
<li><a href="#ForeignLanguages">Why does Google show up in foreign
|
||
languages?</a></li>
|
||
<li><a href="#GmailWarning">Gmail warns me that my account may have
|
||
been compromised.</a></li>
|
||
<li><a href="#NeedToUseAProxy">My internet connection requires an HTTP
|
||
or SOCKS Proxy</a></li>
|
||
<li><a href="#CantSetProxy">What should I do if I can't set a proxy
|
||
with my application?</a></li>
|
||
<li><a href="#WarningsAboutSOCKSandDNSInformationLeaks">I keep seeing
|
||
these warnings about SOCKS and DNS information leaks. Should I
|
||
worry?</a></li>
|
||
<li><a href="#WhereDidVidaliaGo">Where did the world map (Vidalia)
|
||
go?</a></li>
|
||
<li><a href="#DisableJS">How do I disable JavaScript?</a></li>
|
||
<li><a href="#VerifyDownload">How do I verify the download
|
||
(sha256sums.txt)?</a></li>
|
||
<li><a href="#NewIdentityClosingTabs">Why does "New Identity" close
|
||
all my open tabs?</a></li>
|
||
<li><a href="#ConfigureRelayOrBridge">How do I configure Tor as a relay
|
||
or bridge?</a></li>
|
||
<li><a href="#Timestamps">Why are the file timestamps from 2000?</a></li>
|
||
<li><a href="#SourceCode">Where is the source code for the bundle? How do
|
||
I verify a build?</a></li>
|
||
</ul>
|
||
|
||
<p>Advanced Tor usage:</p>
|
||
<ul>
|
||
<li><a href="#torrc">I'm supposed to "edit my torrc". What does
|
||
that mean?</a></li>
|
||
<li><a href="#Logs">How do I set up logging, or see Tor's
|
||
logs?</a></li>
|
||
<li><a href="#LogLevel">What log level should I use?</a></li>
|
||
<li><a href="#DoesntWork">Tor is running, but it's not working
|
||
correctly.</a></li>
|
||
<li><a href="#TorCrash">My Tor keeps crashing.</a></li>
|
||
<li><a href="#VidaliaPassword">Tor/Vidalia prompts for a password at
|
||
start.</a></li>
|
||
<li><a href="#ChooseEntryExit">Can I control which nodes (or
|
||
country)
|
||
are used for entry/exit?</a></li>
|
||
<li><a href="#FirewallPorts">My firewall only allows a few outgoing
|
||
ports.</a></li>
|
||
<li><a href="#DefaultExitPorts">Is there a list of default exit ports?</a></li>
|
||
<li><a href="#SocksAndDNS">How do I check if my application that uses
|
||
SOCKS is leaking DNS requests?</a></li>
|
||
<li><a href="#DifferentComputer">I want to run my Tor client on a
|
||
different computer than my applications.</a></li>
|
||
<li><a href="#ServerClient">Can I install Tor on a central server, and
|
||
have my clients connect to it?</a></li>
|
||
<li><a href="#JoinTheNetwork">So I can just configure a nickname and
|
||
ORPort and join the network?</a></li>
|
||
</ul>
|
||
|
||
<p>Running a Tor relay:</p>
|
||
<ul>
|
||
|
||
<li><a href="#HowDoIDecide">How do I decide if I should run a relay?
|
||
</a></li>
|
||
<li><a href="#WhyIsntMyRelayBeingUsedMore">Why isn't my relay being
|
||
used more?</a></li>
|
||
<li><a href="#IDontHaveAStaticIP">I don't have a static IP.</a></li>
|
||
<li><a href="#ModemKeepsCrashing">My cable/dsl modem keeps crashing.
|
||
What's going on?</a></li>
|
||
<li><a href="#PortscannedMore">Why do I get portscanned more often
|
||
when I run a Tor relay?</a></li>
|
||
<li><a href="#MoreThanOneCPU">I have more than one CPU. Does this
|
||
help?</a></li>
|
||
<li><a href="#HighCapacityConnection">How can I get Tor to fully
|
||
make use of my high capacity connection?</a></li>
|
||
<li><a href="#RelayFlexible">How stable does my relay need to
|
||
be?</a></li>
|
||
<li><a href="#BandwidthShaping">What bandwidth shaping options are
|
||
available to Tor relays?</a></li>
|
||
<li><a href="#LimitTotalBandwidth">How can I limit the total amount
|
||
of bandwidth used by my Tor relay?</a></li>
|
||
<li><a href="#ExitPolicies">I'd run a relay, but I don't want to deal
|
||
with abuse issues.</a></li>
|
||
<li><a href="#RelayOrBridge">Should I be a normal relay or bridge
|
||
relay?</a></li>
|
||
<li><a href="#UpgradeOrMove">I want to upgrade/move my relay. How do I
|
||
keep the same key?</a></li>
|
||
<li><a href="#MultipleRelays">I want to run more than one
|
||
relay.</a></li>
|
||
<li><a href="#NTService">How do I run my Tor relay as an NT service?
|
||
</a></li>
|
||
<li><a href="#VirtualServer">Can I run a Tor relay from my virtual server
|
||
account?</a></li>
|
||
<li><a href="#WrongIP">My relay is picking the wrong IP address.</a></li>
|
||
<li><a href="#BehindANAT">I'm behind a NAT/Firewall</a></li>
|
||
<li><a href="#RelayMemory">Why is my Tor relay using so much memory?
|
||
</a></li>
|
||
<li><a href="#BetterAnonymity">Do I get better anonymity if I run a relay?
|
||
</a></li>
|
||
<li><a href="#RelayDonations">Can I donate for a relay rather than
|
||
run my own?</a></li>
|
||
</ul>
|
||
|
||
<p>Tor hidden services:</p>
|
||
<ul>
|
||
<li><a href="#AccessHiddenServices">How do I access hidden services?</a></li>
|
||
<li><a href="#ProvideAHiddenService">How do I provide a hidden service</a></li>
|
||
</ul>
|
||
|
||
<p>Development</p>
|
||
<ul>
|
||
<li><a href="#WhoIsResponsible">Who is responsible for Tor?</a></li>
|
||
<li><a href="#VersionNumbers">What do these weird version numbers
|
||
mean?</a></li>
|
||
<li><a href="#PrivateTorNetwork">How do I set up my own private
|
||
Tor network?</a></li>
|
||
<li><a href="#UseTorWithJava">How can I make my Java program use the
|
||
Tor network?</a></li>
|
||
<li><a href="#WhatIsLibevent">What is Libevent?</a></li>
|
||
<li><a href="#MyNewFeature">What do I need to do to get a new feature
|
||
into Tor?</a></li>
|
||
</ul>
|
||
|
||
<p>Anonymity and Security:</p>
|
||
<ul>
|
||
<li><a href="#WhatProtectionsDoesTorProvide">What protections does Tor
|
||
provide?</a></li>
|
||
<li><a href="#CanExitNodesEavesdrop">Can exit nodes eavesdrop on
|
||
communications? Isn't that bad? </a></li>
|
||
<li><a href="#AmITotallyAnonymous">So I'm totally anonymous if I use
|
||
Tor?</a></li>
|
||
<li><a href="#ExitEnclaving">What is Exit Enclaving?</a></li>
|
||
<li><a href="#KeyManagement">Tell me about all the keys Tor
|
||
uses.</a></li>
|
||
<li><a href="#EntryGuards">What are Entry Guards?</a></li>
|
||
<li><a href="#ChangePaths">How often does Tor change its paths?</a></li>
|
||
<li><a href="#CellSize">Tor uses hundreds of bytes for every IRC line. I
|
||
can't afford that!</a></li>
|
||
<li><a href="#OutboundConnections">Why does netstat show these outbound
|
||
connections?</a></li>
|
||
<li><a href="#PowerfulBlockers">What about powerful blocking mechanisms
|
||
</a></li>
|
||
<li><a href="#RemotePhysicalDeviceFingerprinting">Does Tor resist
|
||
"remote physical device fingerprinting"?</a></li>
|
||
<li><a href="#VPN">What's safer, Tor or a VPN?</a></li>
|
||
<li><a href="#Proxychains">Aren't 10 proxies (proxychains) better than
|
||
Tor with only 3 hops?</a></li>
|
||
<li><a href="#AttacksOnOnionRouting">What attacks remain against onion
|
||
routing?</a></li>
|
||
</ul>
|
||
|
||
<p>Alternate designs that we don't do (yet):</p>
|
||
<ul>
|
||
<li><a href="#EverybodyARelay">You should make every Tor user be a
|
||
relay.</a></li>
|
||
<li><a href="#TransportIPnotTCP">You should transport all IP
|
||
packets,
|
||
not just TCP packets.</a></li>
|
||
<li><a href="#HideExits">You should hide the list of Tor relays,
|
||
so people can't block the exits.</a></li>
|
||
<li><a href="#ChoosePathLength">You should let people choose their path
|
||
length.</a></li>
|
||
<li><a href="#SplitEachConnection">You should split each connection over
|
||
many paths.</a></li>
|
||
<li><a href="#UnallocatedNetBlocks">Your default exit policy should block
|
||
unallocated net blocks too.</a></li>
|
||
<li><a href="#BlockWebsites">Exit policies should be able to block
|
||
websites, not just IP addresses.</a></li>
|
||
<li><a href="#BlockContent">You should change Tor to prevent users from
|
||
posting certain content.</a></li>
|
||
<li><a href="#SendPadding">You should send padding so it's more secure.
|
||
</a></li>
|
||
<li><a href="#Steganography">You should use steganography to hide Tor
|
||
traffic.</a></li>
|
||
<li><a href="#IPv6">Tor should support IPv6.</a></li>
|
||
</ul>
|
||
|
||
<p>Abuse:</p>
|
||
<ul>
|
||
<li><a href="#Criminals">Doesn't Tor enable criminals to do bad
|
||
things?</a></li>
|
||
<li><a href="#RespondISP">How do I respond to my ISP about my exit
|
||
relay?</a></li>
|
||
<li><a href="#HelpPoliceOrLawyers">I have questions about
|
||
a Tor IP address for a legal case.</a></li>
|
||
</ul>
|
||
|
||
<p>For other questions not yet on this version of the FAQ, see the
|
||
<a
|
||
href="<wikifaq>">wiki FAQ</a> for now.</p>
|
||
|
||
<hr>
|
||
|
||
<a id="General"></a>
|
||
|
||
<a id="WhatIsTor"></a>
|
||
<h3><a class="anchor" href="#WhatIsTor">What is Tor?</a></h3>
|
||
|
||
<p>
|
||
The name "Tor" can refer to several different components.
|
||
</p>
|
||
|
||
<p>
|
||
The Tor software is a program you can run on your computer that
|
||
helps keep
|
||
you safe on the Internet. Tor protects you by bouncing your
|
||
communications
|
||
around a distributed network of relays run by volunteers all around
|
||
the world: it prevents somebody watching your Internet connection
|
||
from
|
||
learning what sites you visit, and it prevents the sites you visit
|
||
from learning your physical location. This set of volunteer relays
|
||
is
|
||
called the Tor network. You can read more about how Tor works on the
|
||
<a
|
||
href="<page about/overview>">overview page</a>.
|
||
</p>
|
||
|
||
<p>
|
||
The Tor Project is a non-profit (charity) organization that
|
||
maintains
|
||
and develops the Tor software.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Torisdifferent"></a>
|
||
<h3><a class="anchor" href="#Torisdifferent">How is Tor different
|
||
from other proxies?</a></h3>
|
||
<p>
|
||
A typical proxy provider sets up a server somewhere on the Internet
|
||
and
|
||
allows you to use it to relay your traffic. This creates a simple, easy
|
||
to
|
||
maintain architecture. The users all enter and leave through the same
|
||
server.
|
||
The provider may charge for use of the proxy, or fund their costs
|
||
through
|
||
advertisements on the server. In the simplest configuration, you don't
|
||
have to
|
||
install anything. You just have to point your browser at their proxy
|
||
server.
|
||
Simple proxy providers are fine solutions if you do not want protections
|
||
for
|
||
your privacy and anonymity online and you trust the provider from doing
|
||
bad
|
||
things. Some simple proxy providers use SSL to secure your connection
|
||
to them.
|
||
This may protect you against local eavesdroppers, such as those at a
|
||
cafe with
|
||
free wifi Internet.
|
||
</p>
|
||
<p>
|
||
Simple proxy providers also create a single point of failure. The
|
||
provider
|
||
knows who you are and where you browse on the Internet. They can see
|
||
your
|
||
traffic as it passes through their server. In some cases, they can even
|
||
see
|
||
inside your
|
||
encrypted traffic as they relay it to your banking site or to ecommerce
|
||
stores.
|
||
You have to trust the provider isn't doing any number of things, such as
|
||
watching your traffic, injecting their own advertisements into your
|
||
traffic
|
||
stream, and recording your personal details.
|
||
</p>
|
||
<p>
|
||
Tor passes your traffic through at least 3 different servers before
|
||
sending
|
||
it on to the destination. Because there's a separate layer of encryption
|
||
for
|
||
each of the three relays, Tor does not modify, or even know, what you
|
||
are
|
||
sending into it. It merely relays your traffic, completely encrypted
|
||
through
|
||
the Tor network and has it pop out somewhere else in the world,
|
||
completely
|
||
intact. The Tor client is required because we assume you trust your
|
||
local
|
||
computer. The Tor client manages the encryption and the path chosen
|
||
through
|
||
the network. The relays located all over the world merely pass
|
||
encrypted
|
||
packets between themselves.</p>
|
||
<p>
|
||
<dl>
|
||
<dt>Doesn't the first server see who I am?</dt><dd>Possibly. A bad
|
||
first of
|
||
three servers can see encrypted Tor traffic coming from your computer.
|
||
It
|
||
still doesn't know who you are and what you are doing over Tor. It
|
||
merely sees
|
||
"This IP address is using Tor". Tor is not illegal anywhere in the
|
||
world, so
|
||
using Tor by itself is fine. You are still protected from this node
|
||
figuring
|
||
out who you are and where you are going on the Internet.</dd>
|
||
<dt>Can't the third server see my traffic?</dt><dd>Possibly. A bad
|
||
third
|
||
of three servers can see the traffic you sent into Tor. It won't know
|
||
who sent
|
||
this traffic. If you're using encryption, such as visiting a bank or
|
||
e-commerce website, or encrypted mail connections, etc, it will only
|
||
know the
|
||
destination. It won't be able to see the data inside the traffic
|
||
stream. You
|
||
are still protected from this node figuring out who you are and if using
|
||
encryption, what data you're sending to the destination.</dd>
|
||
</dl>
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="CompatibleApplications"></a>
|
||
<h3><a class="anchor" href="#CompatibleApplications">What programs
|
||
can I use with Tor?</a></h3>
|
||
|
||
<p>
|
||
If you want to use Tor with a web browser, we provide the Tor Browser
|
||
Bundle, which includes everything you need to browse the web safely using
|
||
Tor. If you want to use another web browser with Tor, see <a
|
||
href="#TBBOtherBrowser">Other web browsers</a>.
|
||
</p>
|
||
<p>
|
||
There are plenty of other programs you can use with Tor,
|
||
but we haven't researched the application-level anonymity
|
||
issues on all of them well enough to be able to recommend a safe
|
||
configuration. Our wiki has a list of instructions for <a
|
||
href="<wiki>doc/TorifyHOWTO">Torifying
|
||
specific applications</a>.
|
||
Please add to these lists and help us keep them accurate!
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhyCalledTor"></a>
|
||
<h3><a class="anchor" href="#WhyCalledTor">Why is it called
|
||
Tor?</a></h3>
|
||
|
||
<p>
|
||
Because Tor is the onion routing network. When we were starting the
|
||
new next-generation design and implementation of onion routing in
|
||
2001-2002, we would tell people we were working on onion routing,
|
||
and they would say "Neat. Which one?" Even if onion routing has
|
||
become a standard household term, Tor was born out of the actual <a
|
||
href="http://www.onion-router.net/">onion routing project</a> run by
|
||
the Naval Research Lab.
|
||
</p>
|
||
|
||
<p>
|
||
(It's also got a fine translation from German and Turkish.)
|
||
</p>
|
||
|
||
<p>
|
||
Note: even though it originally came from an acronym, Tor is not
|
||
spelled
|
||
"TOR". Only the first letter is capitalized. In fact, we can usually
|
||
spot people who haven't read any of our website (and have instead
|
||
learned
|
||
everything they know about Tor from news articles) by the fact that
|
||
they
|
||
spell it wrong.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Backdoor"></a>
|
||
<h3><a class="anchor" href="#Backdoor">Is there a backdoor in
|
||
Tor?</a></h3>
|
||
|
||
<p>
|
||
There is absolutely no backdoor in Tor. Nobody has asked us to put
|
||
one
|
||
in, and we know some smart lawyers who say that it's unlikely that
|
||
anybody
|
||
will try to make us add one in our jurisdiction (U.S.). If they do
|
||
ask us, we will fight them, and (the lawyers say) probably win.
|
||
</p>
|
||
|
||
<p>
|
||
We think that putting a backdoor in Tor would be tremendously
|
||
irresponsible to our users, and a bad precedent for security
|
||
software
|
||
in general. If we ever put a deliberate backdoor in our security
|
||
software, it would ruin our professional reputations. Nobody would
|
||
trust our software ever again — for excellent reason!
|
||
</p>
|
||
|
||
<p>
|
||
But that said, there are still plenty of subtle attacks
|
||
people might try. Somebody might impersonate us, or break into our
|
||
computers, or something like that. Tor is open source, and you
|
||
should
|
||
always check the source (or at least the diffs since the last
|
||
release)
|
||
for suspicious things. If we (or the distributors) don't give you
|
||
source, that's a sure sign something funny might be going on. You
|
||
should also check the <a href="<page docs/verifying-signatures>">PGP
|
||
signatures</a> on the releases, to make sure nobody messed with the
|
||
distribution sites.
|
||
</p>
|
||
|
||
<p>
|
||
Also, there might be accidental bugs in Tor that could affect your
|
||
anonymity. We periodically find and fix anonymity-related bugs, so
|
||
make
|
||
sure you keep your Tor versions up-to-date.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="DistributingTor"></a>
|
||
<h3><a class="anchor" href="#DistributingTor">Can I distribute
|
||
Tor?</a></h3>
|
||
|
||
<p>
|
||
Yes.
|
||
</p>
|
||
|
||
<p>
|
||
The Tor software is <a href="https://www.fsf.org/">free
|
||
software</a>. This
|
||
means we give you the rights to redistribute the Tor software,
|
||
either
|
||
modified or unmodified, either for a fee or gratis. You don't have
|
||
to
|
||
ask us for specific permission.
|
||
</p>
|
||
|
||
<p>
|
||
However, if you want to redistribute the Tor software you must
|
||
follow our
|
||
<a href="<gitblob>LICENSE">LICENSE</a>.
|
||
Essentially this means that you need to include our LICENSE file
|
||
along
|
||
with whatever part of the Tor software you're distributing.
|
||
</p>
|
||
|
||
<p>
|
||
Most people who ask us this question don't want to distribute just
|
||
the
|
||
Tor software, though. They want to distribute the <a
|
||
href="<page projects/torbrowser>">Tor Browser</a>. This includes <a
|
||
href="https://www.mozilla.org/en-US/firefox/all-aurora.html">Mozilla
|
||
Aurora</a> and <a href="<page projects/vidalia>">Vidalia</a>.
|
||
You will need to follow the licenses for those programs
|
||
as well. Both of them are distributed under the <a
|
||
href="https://www.fsf.org/licensing/licenses/gpl.html">GNU General
|
||
Public License</a>. The simplest way to obey their licenses is
|
||
to include the source code for these programs everywhere you
|
||
include the bundles themselves. Look for "source" packages on
|
||
the <a href="<page projects/vidalia>">Vidalia page</a> and <a
|
||
href="https://www.mozilla.org/en-US/firefox/all-aurora.html">Mozilla
|
||
Aurora</a> pages.
|
||
</p>
|
||
|
||
<p>
|
||
Also, you should make sure not to confuse your readers about what
|
||
Tor is,
|
||
who makes it, and what properties it provides (and doesn't provide).
|
||
See
|
||
our <a href="<page docs/trademark-faq>">trademark FAQ</a> for
|
||
details.
|
||
</p>
|
||
|
||
<p>
|
||
Lastly, you should realize that we release new versions of the
|
||
Tor software frequently, and sometimes we make backward incompatible
|
||
changes. So if you distribute a particular version of the Tor
|
||
software, it
|
||
may not be supported — or even work — six months later.
|
||
This
|
||
is a fact of life for all security software under heavy development.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="SupportMail"></a>
|
||
<h3><a class="anchor" href="#SupportMail">How can I get
|
||
support?</a></h3>
|
||
|
||
<p>Your best bet is to first try the following:</p>
|
||
<ol>
|
||
<li>Read through this <a href="<page docs/faq>">FAQ</a>.</li>
|
||
<li>Read through the <a href="<page
|
||
docs/documentation>">documentation</a>.</li>
|
||
<li>Read through the <a
|
||
|
||
href="https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-talk">
|
||
tor-talk
|
||
archives</a> and see if your question is already answered.</li>
|
||
<li>Join our <a href="ircs://irc.torproject.org#tor">irc channel</a>
|
||
and
|
||
state the issue and wait for help.</li>
|
||
<li>Send an email to <a
|
||
|
||
href="mailto:help@rt.torproject.org">help@rt.torproject.org</a>.</li>
|
||
<li>If all else fails, try <a href="<page about/contact>">contacting
|
||
us</a> directly.</li>
|
||
</ol>
|
||
|
||
<p>If you find your answer, please stick around on the IRC channel
|
||
or the
|
||
mailing list to help others who were once in your position.</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Forum"></a>
|
||
<h3><a class="anchor" href="#Forum">Is there a Tor forum?</a></h3>
|
||
|
||
<p>We have a <a href="https://tor.stackexchange.com/">StackExchange
|
||
page</a> that is currently in public beta.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhySlow"></a>
|
||
<h3><a class="anchor" href="#WhySlow">Why is Tor so slow?</a></h3>
|
||
|
||
<p>
|
||
There are many reasons why the Tor network is currently slow.
|
||
</p>
|
||
|
||
<p>
|
||
Before we answer, though, you should realize that Tor is never going
|
||
to
|
||
be blazing fast. Your traffic is bouncing through volunteers'
|
||
computers
|
||
in various parts of the world, and some bottlenecks and network
|
||
latency
|
||
will always be present. You shouldn't expect to see university-style
|
||
bandwidth through Tor.
|
||
</p>
|
||
|
||
<p>
|
||
But that doesn't mean that it can't be improved. The current Tor
|
||
network
|
||
is quite small compared to the number of people trying to use it,
|
||
and
|
||
many of these users don't understand or care that Tor can't
|
||
currently
|
||
handle file-sharing traffic load.
|
||
</p>
|
||
|
||
<p>
|
||
For the much more in-depth answer, see <a
|
||
href="<blog>why-tor-is-slow">Roger's blog
|
||
post on the topic</a>, which includes both a detailed PDF and a
|
||
video
|
||
to go with it.
|
||
</p>
|
||
|
||
<p>
|
||
What can you do to help?
|
||
</p>
|
||
|
||
<ul>
|
||
|
||
<li>
|
||
<a href="<page docs/tor-doc-relay>">Configure your Tor to relay
|
||
traffic
|
||
for others</a>. Help make the Tor network large enough that we can
|
||
handle
|
||
all the users who want privacy and security on the Internet.
|
||
</li>
|
||
|
||
<li>
|
||
<a href="<page projects/vidalia>">Help us make Tor more usable</a>.
|
||
We
|
||
especially need people to help make it easier to configure your Tor
|
||
as a relay. Also, we need help with clear simple documentation to
|
||
walk people through setting it up.
|
||
</li>
|
||
|
||
<li>
|
||
There are some bottlenecks in the current Tor network. Help us
|
||
design
|
||
experiments to track down and demonstrate where the problems are,
|
||
and
|
||
then we can focus better on fixing them.
|
||
</li>
|
||
|
||
<li>
|
||
Tor needs some architectural changes too. One important change is to
|
||
start providing <a href="#EverybodyARelay">better service to people
|
||
who
|
||
relay traffic</a>. We're working on this, and we'll finish faster if
|
||
we
|
||
get to spend more time on it.
|
||
</li>
|
||
|
||
<li>
|
||
Help do other things so we can do the hard stuff. Please take a
|
||
moment
|
||
to figure out what your skills and interests are, and then <a
|
||
href="<page
|
||
getinvolved/volunteer>">look at our volunteer page</a>.
|
||
</li>
|
||
|
||
<li>
|
||
Help find sponsors for Tor. Do you work at a company or government
|
||
agency
|
||
that uses Tor or has a use for Internet privacy, e.g. to browse the
|
||
competition's websites discreetly, or to connect back to the home
|
||
servers
|
||
when on the road without revealing affiliations? If your
|
||
organization has
|
||
an interest in keeping the Tor network working, please contact them
|
||
about
|
||
supporting Tor. Without sponsors, Tor is going to become even
|
||
slower.
|
||
</li>
|
||
|
||
<li>
|
||
If you can't help out with any of the above, you can still help out
|
||
individually by <a href="<page donate/donate>">donating a bit of
|
||
money to the
|
||
cause</a>. It adds up!
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
<hr>
|
||
|
||
<a id="FileSharing"></a>
|
||
<h3><a class="anchor" href="#FileSharing">How can I share files
|
||
anonymously through Tor?</a></h3>
|
||
|
||
<p>
|
||
File sharing (peer-to-peer/P2P) is widely unwanted in the Tor network,
|
||
and exit nodes are configured to block file sharing traffic by default.
|
||
Tor is not really designed for it, and file sharing through Tor slows
|
||
down everyone's browsing. Also, Bittorrent over Tor <a
|
||
href="https://blog.torproject.org/blog/bittorrent-over-tor-isnt-good-idea">
|
||
is not anonymous</a>!
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Funding"></a>
|
||
<h3><a class="anchor" href="#Funding">What would The Tor Project do
|
||
with more funding?</a></h3>
|
||
|
||
<p>
|
||
The Tor network's <a
|
||
|
||
href="https://metrics.torproject.org/network.html#networksize">several
|
||
thousand</a> relays push <a
|
||
href="https://metrics.torproject.org/network.html#bandwidth">over
|
||
1GB per second on average</a>. We have <a
|
||
|
||
href="https://metrics.torproject.org/users.html#direct-users">several
|
||
hundred thousand daily users</a>. But the Tor network is not yet
|
||
self-sustaining.
|
||
</p>
|
||
|
||
<p>
|
||
There are six main development/maintenance pushes that need
|
||
attention:
|
||
</p>
|
||
|
||
<ul>
|
||
|
||
<li>
|
||
Scalability: We need to keep scaling and decentralizing the Tor
|
||
architecture so it can handle thousands of relays and millions of
|
||
users. The upcoming stable release is a major improvement, but
|
||
there's
|
||
lots more to be done next in terms of keeping Tor fast and stable.
|
||
</li>
|
||
|
||
<li>
|
||
User support: With this many users, a lot of people are asking
|
||
questions
|
||
all the time, offering to help out with things, and so on. We need
|
||
good
|
||
clean docs, and we need to spend some effort coordinating
|
||
volunteers.
|
||
</li>
|
||
|
||
<li>
|
||
Relay support: the Tor network is run by volunteers, but they still
|
||
need
|
||
attention with prompt bug fixes, explanations when things go wrong,
|
||
reminders to upgrade, and so on. The network itself is a commons,
|
||
and
|
||
somebody needs to spend some energy making sure the relay operators
|
||
stay
|
||
happy. We also need to work on stability on some platforms —
|
||
e.g.,
|
||
Tor relays have problems on Win XP currently.
|
||
</li>
|
||
|
||
<li>
|
||
Usability: Beyond documentation, we also need to work on usability
|
||
of the
|
||
software itself. This includes installers, clean GUIs, easy
|
||
configuration
|
||
to interface with other applications, and generally automating all
|
||
of
|
||
the difficult and confusing steps inside Tor. We've got a start on
|
||
this
|
||
with the <a href="<page projects/vidalia>">Vidalia GUI</a>, but much
|
||
more work
|
||
remains — usability for privacy software has never been easy.
|
||
</li>
|
||
|
||
<li>
|
||
Incentives: We need to work on ways to encourage people to configure
|
||
their Tors as relays and exit nodes rather than just clients.
|
||
<a href="#EverybodyARelay">We need to make it easy to become a
|
||
relay,
|
||
and we need to give people incentives to do it.</a>
|
||
</li>
|
||
|
||
<li>
|
||
Research: The anonymous communications field is full
|
||
of surprises and gotchas. In our copious free time, we
|
||
also help run top anonymity and privacy conferences like <a
|
||
href="http://petsymposium.org/">PETS</a>. We've identified a set of
|
||
critical <a href="<page getinvolved/volunteer>#Research">Tor
|
||
research questions</a>
|
||
that will help us figure out how to make Tor secure against the
|
||
variety of
|
||
attacks out there. Of course, there are more research questions
|
||
waiting
|
||
behind these.
|
||
</li>
|
||
|
||
</ul>
|
||
|
||
<p>
|
||
We're continuing to move forward on all of these, but at this rate
|
||
<a href="#WhySlow">the Tor network is growing faster than the
|
||
developers
|
||
can keep up</a>.
|
||
Now would be an excellent time to add a few more developers to the
|
||
effort
|
||
so we can continue to grow the network.
|
||
</p>
|
||
|
||
<p>
|
||
We are also excited about tackling related problems, such as
|
||
censorship-resistance.
|
||
</p>
|
||
|
||
<p>
|
||
We are proud to have <a href="<page about/sponsors>">sponsorship and
|
||
support</a>
|
||
from the Omidyar Network, the International Broadcasting Bureau,
|
||
Bell
|
||
Security Solutions, the Electronic Frontier Foundation, several
|
||
government
|
||
agencies and research groups, and hundreds of private contributors.
|
||
</p>
|
||
|
||
<p>
|
||
However, this support is not enough to keep Tor abreast of changes
|
||
in the
|
||
Internet privacy landscape. Please <a href="<page
|
||
donate/donate>">donate</a>
|
||
to the project, or <a href="<page about/contact>">contact</a> our
|
||
executive
|
||
director for information on making grants or major donations.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="OutboundPorts"></a>
|
||
<h3><a class="anchor" href="#OutboundPorts">Do I have to open all these
|
||
outbound ports on my firewall?</a></h3>
|
||
|
||
<p>
|
||
Tor may attempt to connect to any port that is advertised in the
|
||
directory as an ORPort (for making Tor connections) or a DirPort (for
|
||
fetching updates to the directory). There are a variety of these ports,
|
||
but many of them are running on 80, 443, 9001, and 9030.
|
||
</p>
|
||
<p>
|
||
So as a client, you could probably get away with opening only those four
|
||
ports. Since Tor does all its connections in the background, it will retry
|
||
ones that fail, and hopefully you'll never have to know that it failed, as
|
||
long as it finds a working one often enough. However, to get the most
|
||
diversity in your entry nodes -- and thus the most security -- as well as
|
||
the most robustness in your connectivity, you'll want to let it connect
|
||
to all of them.
|
||
</p>
|
||
<p>
|
||
If you really need to connect to only a small set of ports, see the FAQ
|
||
entry on <a href="#FirewallPorts">firewalled ports</a>.
|
||
</p>
|
||
<p>
|
||
Note that if you're running Tor as a relay, you must allow outgoing
|
||
connections to every other relay and to anywhere your exit policy
|
||
advertises that you allow. The cleanest way to do that is simply to allow
|
||
all outgoing connections at your firewall. If you don't, clients will try
|
||
to use these connections and things won't work.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="IsItWorking"></a>
|
||
<h3><a class="anchor" href="#IsItWorking">How can I tell if Tor is
|
||
working, and that my connections really are anonymized?</a></h3>
|
||
|
||
<p>
|
||
There are sites you can visit that will tell you if you appear to be
|
||
coming through the Tor network. Try the <a href="https://check.torproject.org">
|
||
Tor Check</a> site and see whether it thinks you are using Tor or not.
|
||
</p>
|
||
<p>
|
||
If that site is down, you can still test, but it will involve more effort.
|
||
Sites like <a href="http://ipid.shat.net">http://ipid.shat.net</a> and
|
||
<a href="http://www.showmyip.com/">http://www.showmyip.com/</a> will tell
|
||
you what your IP address appears to be, but you'll need to know your
|
||
current IP address so you can compare and decide whether you're using Tor
|
||
correctly.
|
||
</p>
|
||
<p>
|
||
To learn your IP address on OS X, Linux, BSD, etc, run "ifconfig". On
|
||
Windows, go to the Start menu, click Run and enter "cmd". At the command
|
||
prompt, enter "ipconfig /a".
|
||
</p>
|
||
<p>
|
||
If you are behind a NAT or firewall, though, your IP address will be
|
||
within the range of 10.XXX.XXX.XXX, 192.168.XXX.XXX, or 172.16.XXX.XXX -
|
||
172.31.XXX.XXX, which is not your public IP address. In this case, you
|
||
should check your IP address with one of the sites above without using
|
||
Tor, and then check again using Tor to see whether your IP address has
|
||
changed.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="FTP"></a>
|
||
<h3><a class="anchor" href="#FTP">How do I use my browser for ftp with Tor?
|
||
</a></h3>
|
||
|
||
<p>
|
||
Use the <a href="https://torproject.org/projects/torbrowser.html">Tor
|
||
Browser Bundle</a>. If you want a separate application for an
|
||
ftp client, we've heard good things about FileZilla for Windows. You can
|
||
configure it to point to Tor as a "socks4a" proxy on "localhost" port
|
||
"9050".
|
||
</p>
|
||
<hr>
|
||
|
||
<a id="Metrics"></a>
|
||
<h3><a class="anchor" href="#Metrics">How many people use Tor? How
|
||
many relays or exit nodes are there?</a></h3>
|
||
|
||
<p>
|
||
All this and more about measuring Tor can be found at the <a
|
||
href="https://metrics.torproject.org/">Tor Metrics Portal</a>.</p>
|
||
<hr>
|
||
|
||
<a id="SSLcertfingerprint"></a>
|
||
<h3><a class="anchor" href="#SSLcertfingerprint">What are the SSL
|
||
certificate fingerprints for Tor's various websites?</a></h3>
|
||
<p>
|
||
<pre>
|
||
*.torproject.org SSL certificate from Digicert:
|
||
The serial number is:
|
||
06:DE:97:E5:1D:C3:9D:C2:64:8D:AC:72:DD:41:01:FC
|
||
The SHA-1 fingerprint is: 1f9d306e8bfccfcb03981a71a27a9f5d1e0876ce
|
||
The SHA-256 fingerprint is:
|
||
3613d2b22a750094760c41ad19db52a4f05bdea80172e2578761ad967f7ed9aa
|
||
|
||
blog.torproject.org SSL certificate from RapidSSL:
|
||
The serial number is: 00:EF:A3
|
||
The SHA-1 fingerprint is: 50af43db8438e67f305a3257d8ef198e8c42f13f
|
||
</pre>
|
||
</p>
|
||
<hr>
|
||
|
||
<a id="HowUninstallTor"></a>
|
||
<h3><a class="anchor" href="#HowUninstallTor">How do I uninstall
|
||
Tor?</a></h3>
|
||
|
||
<p>
|
||
Tor Browser does not install itself in the classic sense of
|
||
applications. You just simply delete the folder or directory named "Tor
|
||
Browser" and it is removed from your system.
|
||
</p>
|
||
|
||
<p>
|
||
If this is not related to Tor Browser, uninstallation depends
|
||
entirely on how you installed it and which operating system you
|
||
have. If you installed a package, then hopefully your package has a
|
||
way to
|
||
uninstall itself. The Windows packages include uninstallers.
|
||
</p>
|
||
|
||
<p>
|
||
For Mac OS X, follow the <a
|
||
href="<page docs/tor-doc-osx>#uninstall">uninstall directions</a>.
|
||
</p>
|
||
|
||
<p>
|
||
If you installed by source, I'm afraid there is no easy uninstall
|
||
method. But
|
||
on the bright side, by default it only installs into /usr/local/ and
|
||
it should
|
||
be pretty easy to notice things there.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="PGPSigs"></a>
|
||
<h3><a class="anchor" href="#PGPSigs">What are these "sig" files on
|
||
the download page?</a></h3>
|
||
|
||
<p>
|
||
These are PGP signatures, so you can verify that the file you've
|
||
downloaded is
|
||
exactly the one that we intended you to get.
|
||
</p>
|
||
|
||
<p>
|
||
Please read the <a
|
||
href="<page docs/verifying-signatures>">verifying signatures</a>
|
||
page for details.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="GetTor"></a>
|
||
<h3><a class="anchor" href="#GetTor">Your website is blocked in my
|
||
country. How do I download Tor?</a></h3>
|
||
|
||
<p>
|
||
Some government or corporate firewalls censor connections to Tor's
|
||
website. In those cases, you have three options. First, get it from
|
||
a friend — the <a href="<page projects/torbrowser>">Tor Browser
|
||
Bundle</a> fits nicely on a USB key. Second, find the <a
|
||
href="https://encrypted.google.com/search?q=tor+mirrors">google
|
||
cache</a>
|
||
for the <a href="<page getinvolved/mirrors>">Tor mirrors</a> page
|
||
and see if any of those copies of our website work for you. Third,
|
||
you can download Tor via email: log in to your Gmail account and mail
|
||
'<tt>gettor@gettor.torproject.org</tt>'. If you include the word 'help'
|
||
in the body of the email, it will reply with instructions. Note that
|
||
only a few webmail providers are supported, since they need to be able
|
||
to receive very large attachments.
|
||
</p>
|
||
|
||
<p>
|
||
Be sure to <a href="<page docs/verifying-signatures>">verify the
|
||
signature</a>
|
||
of any package you download, especially when you get it from somewhere
|
||
other than our official HTTPS website.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="CompileTorWindows"></a>
|
||
<h3><a class="anchor" href="#CompileTorWindows">How do I compile Tor
|
||
under Windows?</a></h3>
|
||
|
||
<p>
|
||
Try following the steps at <a
|
||
href="<gitblob>doc/tor-win32-mingw-creation.txt">
|
||
tor-win32-mingw-creation.txt</a>.
|
||
</p>
|
||
|
||
<p>
|
||
(Note that you don't need to compile Tor yourself in order to use
|
||
it. Most people just use the packages available on the <a
|
||
href="<page
|
||
download/download>">download page</a>.)
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="VirusFalsePositives"></a>
|
||
<h3><a class="anchor" href="#VirusFalsePositives">Why does my Tor
|
||
executable appear to have a virus or spyware?</a></h3>
|
||
|
||
<p>
|
||
Sometimes, overzealous Windows virus and spyware detectors trigger
|
||
on some
|
||
parts of the Tor Windows binary. Our best guess is that these are
|
||
false
|
||
positives — after all, the anti-virus and anti-spyware
|
||
business is just a
|
||
guessing game anyway. You should contact your vendor and explain
|
||
that you have
|
||
a program that seems to be triggering false positives. Or pick a
|
||
better vendor.
|
||
</p>
|
||
|
||
<p>
|
||
In the meantime, we encourage you to not just take our word for
|
||
it. Our job is to provide the source; if you're concerned, please do
|
||
<a
|
||
href="#CompileTorWindows">recompile it yourself</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="LiveCD"></a>
|
||
<h3><a class="anchor" href="#LiveCD">Is there a LiveCD or other
|
||
bundle that includes Tor?</a></h3>
|
||
|
||
<p>
|
||
Yes. Use <a href="https://tails.boum.org/">The Amnesic Incognito
|
||
Live System</a> or <a href="<page projects/torbrowser>">the Tor
|
||
Browser
|
||
Bundle</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBFlash"></a>
|
||
<h3><a class="anchor" href="#TBBFlash">Why can't I view videos on
|
||
YouTube
|
||
and other Flash-based sites?</a></h3>
|
||
|
||
<p>
|
||
YouTube and similar sites require third party browser plugins such as Flash.
|
||
Plugins operate independently from Firefox and can perform
|
||
activity on your computer that ruins your anonymity. This includes
|
||
but is not limited to: <a href="http://decloak.net">completely disregarding
|
||
proxy settings</a>, querying your <a
|
||
href="http://forums.sun.com/thread.jspa?threadID=5162138&messageID=9618376">
|
||
local IP address</a>, and <a
|
||
href="http://epic.org/privacy/cookies/flash.html">storing their own
|
||
cookies</a>. It is possible to use a LiveCD solution such as
|
||
or <a href="https://tails.boum.org/">The Amnesic Incognito Live System</a>
|
||
that creates a secure, transparent proxy to protect you from proxy bypass,
|
||
however issues with local IP address discovery and Flash cookies still remain.
|
||
</p>
|
||
|
||
<p>
|
||
<a href="https://www.youtube.com/html5">YouTube offers experimental HTML5 video
|
||
support</a> for many of their videos. You can use their Advanced Search to
|
||
find HTML5 videos.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Ubuntu"></a>
|
||
<h3><a class="anchor" href="#Ubuntu">
|
||
I'm using Ubuntu and I can't start Tor Browser</a></h3>
|
||
<p>
|
||
Ubuntu prevents its users from executing shell scripts by clicking them,
|
||
even when the file permissions are set correctly. For now you need to
|
||
start the Tor Browser from the command line by running </p>
|
||
<pre>
|
||
./start-tor-browser
|
||
</pre>
|
||
<p>
|
||
from inside the Tor Browser directory.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBSocksPort"></a>
|
||
<h3><a class="anchor" href="#TBBSocksPort">
|
||
I want to run another application through the Tor launched by Tor
|
||
Browser Bundle.</a></h3>
|
||
|
||
<p>
|
||
Typically Tor listens for Socks connections on port 9050. TBB listens
|
||
on port 9150.
|
||
The goal is to avoid conflicting with a "system" Tor install,
|
||
so you can run a system Tor and TBB at the same time. We're <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/3948">working on
|
||
a feature</a> where Tor will try the usual ports first and then back
|
||
off to a random choice if they're already in use.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBPolipo"></a>
|
||
<h3><a class="anchor" href="#TBBPolipo">I need an HTTP proxy. Where did
|
||
Polipo go?</a></h3>
|
||
|
||
<p>
|
||
In the past, Tor bundles included an HTTP proxy like Privoxy or Polipo,
|
||
solely to work around a bug in Firefox that was finally fixed in Firefox
|
||
6. Now you don't need a separate HTTP proxy to use Tor, and in fact
|
||
leaving it out makes you safer because Torbutton has better control over
|
||
Firefox's interaction with websites.
|
||
</p>
|
||
|
||
<p>
|
||
If you are trying to use some external application with Tor, step zero
|
||
should be to <a href="<page download/download>#warning">reread the set
|
||
of warnings</a> for ways you can screw up. Step one should be to try
|
||
to use a Socks proxy rather than an http proxy — Tor runs a Socks
|
||
proxy on port 9050 on Windows, or <a href="#TBBSocksPort">see above</a>
|
||
for OSX and Linux.
|
||
</p>
|
||
|
||
<p>
|
||
If that fails, feel free to install <a
|
||
href="http://www.privoxy.org/">privoxy</a>.
|
||
However, please realize that this approach is not recommended for novice
|
||
users. Privoxy has an <a
|
||
href="http://www.privoxy.org/faq/misc.html#TOR">example
|
||
configuration</a> of Tor and Privoxy.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBOtherExtensions"></a>
|
||
<h3><a class="anchor" href="#TBBOtherExtensions">Can I install other
|
||
Firefox extensions?</a></h3>
|
||
|
||
<p>
|
||
The Tor Browser is free software, so there is nothing preventing you from
|
||
modifying it any way you like. However, we do not recommend installing any
|
||
additional Firefox add-ons with the Tor Browser Bundle. Add-ons can break
|
||
your anonymity in a number of ways, including browser fingerprinting and
|
||
bypassing proxy settings.
|
||
</p>
|
||
<p>
|
||
Some people have suggested we include ad-blocking software or
|
||
anti-tracking software with the Tor Browser Bundle. Right now, we do not
|
||
think that's such a good idea. The Tor Browser Bundle aims to provide
|
||
sufficient privacy that additional add-ons to stop ads and trackers are
|
||
not necessary. Using add-ons like these may cause some sites to break, which
|
||
<a href="https://www.torproject.org/projects/torbrowser/design/#philosophy">
|
||
we don't want to do</a>. Additionally, maintaining a list of "bad" sites that
|
||
should be black-listed provides another opportunity to uniquely fingerprint
|
||
users.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBJavaScriptEnabled"></a>
|
||
<a id="TBBCanIBlockJS"></a>
|
||
<h3><a class="anchor" href="#TBBJavaScriptEnabled">Why is NoScript
|
||
configured to allow JavaScript by default in the Tor Browser Bundle?
|
||
Isn't that unsafe?</a></h3>
|
||
|
||
<p>
|
||
We configure NoScript to allow JavaScript by default in the Tor
|
||
Browser Bundle because many websites will not work with JavaScript
|
||
disabled. Most users would give up on Tor entirely if a website
|
||
they want to use requires JavaScript, because they would not know
|
||
how to allow a website to use JavaScript (or that enabling
|
||
JavaScript might make a website work).
|
||
</p>
|
||
|
||
<p>
|
||
There's a tradeoff here. On the one hand, we should leave
|
||
JavaScript enabled by default so websites work the way
|
||
users expect. On the other hand, we should disable JavaScript
|
||
by default to better protect against browser vulnerabilities (<a
|
||
href="https://blog.torproject.org/blog/tor-security-advisory-old-tor-browser-bundles-vulnerable">
|
||
not just a theoretical concern!</a>). But there's a third issue: websites
|
||
can easily determine whether you have allowed JavaScript for them,
|
||
and if you disable JavaScript by default but then allow a few websites
|
||
to run scripts (the way most people use NoScript), then your choice of
|
||
whitelisted websites acts as a sort of cookie that makes you recognizable
|
||
(and distinguishable), thus harming your anonymity.
|
||
</p>
|
||
|
||
<p>
|
||
Ultimately, we want the default Tor bundles to use
|
||
a combination of firewalls (like the iptables rules
|
||
in <a href="https://tails.boum.org/">Tails</a>) and <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/7680">sandboxes</a>
|
||
to make JavaScript not so scary. In
|
||
the shorter term, TBB 3.0 will hopefully <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/9387">allow users
|
||
to choose their JavaScript settings more easily</a> — but the
|
||
partitioning concern will remain.
|
||
</p>
|
||
|
||
<p>
|
||
Until we get there, feel free to leave JavaScript on or off depending
|
||
on your security, anonymity, and usability priorities.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBOtherBrowser"></a>
|
||
<h3><a class="anchor" href="#TBBOtherBrowser">I want to use
|
||
Chrome/IE/Opera/etc with Tor.</a></h3>
|
||
|
||
<p>
|
||
Unfortunately, Torbutton only works with Firefox right now, and without
|
||
<a href="https://www.torproject.org/torbutton/en/design/">Torbutton's
|
||
extensive privacy fixes</a> there are many ways for websites or other
|
||
attackers to recognize you, track you back to your IP address, and so
|
||
on.
|
||
In short, using any browser besides Tor Browser Bundle with Tor is a
|
||
really bad idea.
|
||
</p>
|
||
|
||
<p>
|
||
We're working with the Chrome team to <a
|
||
href="https://blog.torproject.org/blog/google-chrome-incognito-mode-tor-
|
||
and-fingerprinting">fix
|
||
some bugs and missing APIs in Chrome</a> so it will be possible to write
|
||
a
|
||
Torbutton for Chrome. No support for any other browser is on the
|
||
horizon.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TorbuttonOtherBrowser"></a>
|
||
<h3><a class="anchor" href="#TorbuttonOtherBrowser">
|
||
Will Torbutton be available for other browsers?</a></h3>
|
||
|
||
<p>
|
||
We don't support IE, Opera or Safari and never plan to. There are too many ways that your privacy can go wrong with those browsers, and because of their closed design it is really hard for us to do anything to change these privacy problems.
|
||
</p>
|
||
<p>
|
||
We are working with the Chrome people to modify Chrome's internals so that we can eventually support it. But for now, Firefox is the only safe choice.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TBBCloseBrowser"></a>
|
||
<h3><a class="anchor" href="#TBBCloseBrowser">I want to leave Tor
|
||
Browser
|
||
Bundle running but close the browser.</a></h3>
|
||
|
||
<p>
|
||
We're working on a way to make this possible on all platforms. Please
|
||
be patient.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="GoogleCAPTCHA"></a>
|
||
<h3><a class="anchor" href="#GoogleCAPTCHA">Google makes me solve a
|
||
CAPTCHA or tells me I have spyware installed.</a></h3>
|
||
|
||
<p>
|
||
This is a known and intermittent problem; it does not mean that Google
|
||
considers Tor to be spyware.
|
||
</p>
|
||
|
||
<p>
|
||
When you use Tor, you are sending queries through exit relays that are
|
||
also
|
||
shared by thousands of other users. Tor users typically see this message
|
||
when many Tor users are querying Google in a short period of time.
|
||
Google
|
||
interprets the high volume of traffic from a single IP address (the exit
|
||
relay you happened to pick) as somebody trying to "crawl" their website,
|
||
so it slows down traffic from that IP address for a short time.
|
||
</p>
|
||
<p>
|
||
An alternate explanation is that Google tries to detect certain
|
||
kinds of spyware or viruses that send distinctive queries to Google
|
||
Search. It notes the IP addresses from which those queries are received
|
||
(not realizing that they are Tor exit relays), and tries to warn any
|
||
connections coming from those IP addresses that recent queries indicate
|
||
an infection.
|
||
</p>
|
||
|
||
<p>
|
||
To our knowledge, Google is not doing anything intentionally
|
||
specifically
|
||
to deter or block Tor use. The error message about an infected machine
|
||
should clear up again after a short time.
|
||
</p>
|
||
|
||
<p>
|
||
Torbutton 1.2.5 (released in mid 2010) detects Google captchas and can
|
||
automatically redirect you to a more Tor-friendly search engine such as
|
||
DuckDuckGo, ixquick, or Bing.
|
||
</p>
|
||
|
||
<hr />
|
||
|
||
<a id="ForeignLanguages"></a>
|
||
<h3><a class="anchor" href="#ForeignLanguages">
|
||
Why does Google show up in foreign languages?</a></h3>
|
||
|
||
<p>
|
||
Google uses "geolocation" to determine where in the world you are, so it
|
||
can give you a personalized experience. This includes using the language
|
||
it thinks you prefer, and it also includes giving you different results
|
||
on your queries.
|
||
</p>
|
||
<p>
|
||
If you really want to see Google in English you can click the link that
|
||
provides that. But we consider this a feature with Tor, not a bug --- the
|
||
Internet is not flat, and it in fact does look different depending on
|
||
where you are. This feature reminds people of this fact. The easy way to
|
||
avoid this "feature" is to use
|
||
<a href="https://google.com/ncr">https://google.com/ncr</a>.
|
||
</p>
|
||
<p>
|
||
Note that Google search URLs take name/value pairs as arguments and one
|
||
of those names is "hl". If you set "hl" to "en" then Google will return
|
||
search results in English regardless of what Google server you have been
|
||
sent to. On a query this looks like:
|
||
</p>
|
||
<pre>https://encrypted.google.com/search?q=online%20anonymity&hl=en
|
||
</pre>
|
||
<p>
|
||
Another method is to simply use your country code for accessing Google.
|
||
This can be google.be, google.de, google.us and so on.
|
||
</p>
|
||
<hr />
|
||
<a id="GmailWarning"></a>
|
||
<h3><a class="anchor" href="#GmailWarning">Gmail warns me that my
|
||
account may have been compromised.</a></h3>
|
||
|
||
<p>
|
||
Sometimes, after you've used Gmail over Tor, Google presents a
|
||
pop-up notification that your account may have been compromised.
|
||
The notification window lists a series of IP addresses and locations
|
||
throughout the world recently used to access your account.
|
||
</p>
|
||
|
||
<p>
|
||
In general this is a false alarm: Google saw a bunch of logins from
|
||
different places, as a result of running the service via Tor, and
|
||
decided
|
||
it was a good idea to confirm the account was being accessed by it's
|
||
rightful owner.
|
||
</p>
|
||
|
||
<p>
|
||
Even though this may be a biproduct of using the service via tor,
|
||
that doesn't mean you can entirely ignore the warning. It is
|
||
<i>probably</i> a false positive, but it might not be since it is
|
||
possible for someone to hijack your Google cookie.
|
||
</p>
|
||
|
||
<p>
|
||
Cookie hijacking is possible by either physical access to your computer
|
||
or by watching your network traffic. In theory only physical access
|
||
should compromise your system because Gmail and similar services
|
||
should only send the cookie over an SSL link. In practice, alas, it's <a
|
||
href="http://fscked.org/blog/fully-automated-active-https-cookie-
|
||
hijacking">
|
||
way more complex than that</a>.
|
||
</p>
|
||
|
||
<p>
|
||
And if somebody <i>did</i> steal your google cookie, they might end
|
||
up logging in from unusual places (though of course they also might
|
||
not). So the summary is that since you're using Tor, this security
|
||
measure that Google uses isn't so useful for you, because it's full of
|
||
false positives. You'll have to use other approaches, like seeing if
|
||
anything looks weird on the account, or looking at the timestamps for
|
||
recent logins and wondering if you actually logged in at those times.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="NeedToUseAProxy"></a>
|
||
<h3><a class="anchor" href="#NeedToUseAProxy">My internet connection
|
||
requires an HTTP or SOCKS Proxy</a></h3>
|
||
|
||
<p>
|
||
You can set Proxy IP address, port, and authentication information in
|
||
Tor Browser's Network Settings. If you're using Tor another way, check
|
||
out the HTTPProxy and HTTPSProxy config options in the <a
|
||
href="https://www.torproject.org/docs/tor-manual.html.en">man page</a>,
|
||
and modify your torrc file accordingly. You will need an HTTP proxy for
|
||
doing GET requests to fetch the Tor directory, and you will need an
|
||
HTTPS proxy for doing CONNECT requests to get to Tor relays. (It's fine
|
||
if they're the same proxy.) Tor also recognizes the torrc options
|
||
Socks4Proxy and Socks5Proxy.
|
||
</p>
|
||
<p>
|
||
Also read up on the HTTPProxyAuthenticator and HTTPSProxyAuthenticator
|
||
options if your proxy requires auth. We only support basic auth currently,
|
||
but if you need NTLM authentication, you may find <a
|
||
href="http://archives.seul.org/or/talk/Jun-2005/msg00223.html">this post
|
||
in the archives</a> useful.
|
||
</p>
|
||
<p>
|
||
If your proxies only allow you to connect to certain ports, look at the
|
||
entry on <a href="#FirewallPorts">Firewalled clients</a> for how
|
||
to restrict what ports your Tor will try to access.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="CantSetProxy"></a>
|
||
<h3><a class="anchor" href="#CantSetProxy">What should I do if I can't
|
||
set a proxy with my application?</a></h3>
|
||
|
||
<p>
|
||
On Unix, we recommend you give <a
|
||
href="https://github.com/dgoulet/torsocks/">torsocks</a> a try.
|
||
Alternative proxifying tools like <a
|
||
href="http://www.dest-unreach.org/socat/">socat</a> and <a
|
||
href="http://proxychains.sourceforge.net/">proxychains</a> are also
|
||
available.</p>
|
||
<p>
|
||
The Windows way to force applications through Tor is less clear. <a
|
||
href="http://freecap.ru/eng/">Some</a> <a
|
||
href="http://www.freehaven.net/~aphex/torcap/">tools</a> have been <a
|
||
href="http://www.crowdstrike.com/community-tools/index.html#tool-79">proposed
|
||
</a>, but we'd also like to see further testing done here.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WarningsAboutSOCKSandDNSInformationLeaks"></a>
|
||
<h3><a class="anchor" href="#WarningsAboutSOCKSandDNSInformationLeaks">I
|
||
keep seeing these warnings about SOCKS and DNS information leaks.
|
||
Should I worry?</a></h3>
|
||
<p>
|
||
The warning is:
|
||
</p>
|
||
<p>
|
||
Your application (using socks5 on port %d) is giving Tor only an IP address. Applications that do DNS resolves themselves may leak information. Consider using Socks4A (e.g. via Polipo or socat) instead.
|
||
</p>
|
||
<p>
|
||
If you are running Tor to get anonymity, and you are worried about an attacker who is even slightly clever, then yes, you should worry. Here's why.
|
||
</p>
|
||
<p>
|
||
<b>The Problem.</b> When your applications connect to servers on the Internet, they need to resolve hostnames that you can read (like www.torproject.org) into IP addresses that the Internet can use (like 209.237.230.66). To do this, your application sends a request to a DNS server, telling it the hostname it wants to resolve. The DNS server replies by telling your application the IP address.
|
||
</p>
|
||
<p>
|
||
Clearly, this is a bad idea if you plan to connect to the remote host anonymously: when your application sends the request to the DNS server, the DNS server (and anybody else who might be watching) can see what hostname you are asking for. Even if your application then uses Tor to connect to the IP anonymously, it will be pretty obvious that the user making the anonymous connection is probably the same person who made the DNS request.
|
||
</p>
|
||
<p>
|
||
<b>Where SOCKS comes in.</b> Your application uses the SOCKS protocol to connect to your local Tor client. There are 3 versions of SOCKS you are likely to run into: SOCKS 4 (which only uses IP addresses), SOCKS 5 (which usually uses IP addresses in practice), and SOCKS 4a (which uses hostnames).
|
||
</p>
|
||
<p>
|
||
When your application uses SOCKS 4 or SOCKS 5 to give Tor an IP address, Tor guesses that it 'probably' got the IP address non-anonymously from a DNS server. That's why it gives you a warning message: you probably aren't as anonymous as you think.
|
||
</p>
|
||
<p>
|
||
<b>So what can I do?</b> We describe a few solutions below.
|
||
</p>
|
||
<ul>
|
||
<li>If your application speaks SOCKS 4a, use it. </li>
|
||
<li>If you only need one or two hosts, or you are good at programming, you may be able to get a socks-based port-forwarder like socat to work for you; see <a href="https://trac.torproject.org/projects/tor/wiki/doc/TorifyHOWTO">the Torify HOWTO</a> for examples. </li>
|
||
<li>Tor ships with a program called tor-resolve that can use the Tor network to look up hostnames remotely; if you resolve hostnames to IPs with tor-resolve, then pass the IPs to your applications, you'll be fine. (Tor will still give the warning, but now you know what it means.) </li>
|
||
<!-- I'm not sure if this project is still maintained or not
|
||
|
||
<li>You can use TorDNS as a local DNS server to rectify the DNS leakage. See the Torify HOWTO for info on how to run particular applications anonymously. </li>
|
||
!-->
|
||
</ul>
|
||
<p>
|
||
If you think that you applied one of the solutions properly but still experience DNS leaks please verify there is no third-party application using DNS independently of Tor. Please see <a href="#AmITotallyAnonymous">the FAQ entry on whether you're really absolutely anonymous using Tor</a> for some examples.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhereDidVidaliaGo"></a>
|
||
<h3><a class="anchor" href="#WhereDidVidaliaGo">Where did the world map
|
||
(Vidalia) go?</a></h3>
|
||
|
||
<p>Vidalia has been replaced with Tor Launcher, which is a Firefox
|
||
extension that provides similar functionality. Unfortunately, circuit
|
||
status reporting is still missing, but we are <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/8641">working
|
||
on providing it</a>. </p>
|
||
|
||
<p>In the meantime, we are providing standalone Vidalia packages for
|
||
people who still want the map. Windows and Linux versions are <a
|
||
href="https://people.torproject.org/~erinn/vidalia-standalone-bundles/">
|
||
available here</a>.</p>
|
||
|
||
<p>To use these packages, extract them, then run the startup script.
|
||
On Windows, this is "Start Vidalia.exe". On Linux, it is start-vidalia.
|
||
They can be placed in a different directory from TBB (and likely should
|
||
be). </p>
|
||
|
||
<p>This Vidalia package will only run properly if Tor Browser has already
|
||
been launched. You cannot start it before launching Tor Browser. </p>
|
||
|
||
<p>MacOS is still under development, but in the mean time you can modify
|
||
your TBB 2.x to be a standalone Vidalia (and then use it after starting
|
||
TBB 3.x) by opening your TBB 2.x vidalia.conf file in an editor and
|
||
replacing its contents with just these lines:</p>
|
||
|
||
<pre>
|
||
[General]
|
||
LanguageCode=en
|
||
|
||
[Tor]
|
||
ControlPort=9151
|
||
TorExecutable=.
|
||
Torrc=.
|
||
DataDirectory=.
|
||
AuthenticationMethod=cookie
|
||
</pre>
|
||
|
||
<hr>
|
||
|
||
<a id="DisableJS"></a>
|
||
<h3><a class="anchor" href="#DisableJS">How do I disable JavaScript?</a>
|
||
</h3>
|
||
|
||
<p>Alas, Mozilla decided to get rid of the config checkbox for JavaScript
|
||
from earlier Firefox versions. And since TBB 3.5 is based on Firefox 24
|
||
(FF17 is unmaintained), that means TBB 3.5 doesn't have the config
|
||
checkbox anymore either, which is unfortunate.</p>
|
||
|
||
<p>The simplest way to disable JavaScript in TBB 3.5 is to click on the
|
||
Noscript "S" (between the green onion and the address bar), and select
|
||
"Forbid scripts globally". Note that vanilla NoScript actually whitelists
|
||
several domains even when you try to disable scripts globally, whereas
|
||
Tor Browser's NoScript configuration disables all of them. </p>
|
||
|
||
<p>The more klunky way to disable JavaScript is to go to about:config,
|
||
find javascript.enabled, and set it to false.</p>
|
||
|
||
<p>There is also a very simple addon available at addons.mozilla.org
|
||
called QuickJS, which provides a toolbar toggle for the javascript.enabled
|
||
about:config control. There are no configuration options for the addon,
|
||
it just switches the javascript.enabled entry between true and false and
|
||
provides a button for it. </p>
|
||
|
||
<p>If you want to be extra safe, use both the about:config setting and
|
||
NoScript. </p>
|
||
|
||
<p>As for whether you should disable it or leave it enabled, that's <a
|
||
href="#TBBJavaScriptEnabled">a tradeoff we leave to you</a>.</p>
|
||
|
||
<hr>
|
||
|
||
<a id="VerifyDownload"></a>
|
||
<h3><a class="anchor" href="#VerifyDownload">How do I verify the download
|
||
(sha256sums.txt)?</a></h3>
|
||
|
||
<p>You can still verify your Tor Browser download by downloading the
|
||
signature file (.asc) along with your package and <a
|
||
href="https://www.torproject.org/docs/verifying-signatures.html.en">
|
||
checking the GPG signature</a> as before. We now have an additional
|
||
verification method that allows you to verify the build as well as
|
||
the download.</p>
|
||
|
||
<ul>
|
||
<li>Download the Tor Browser package, the sha256sums.txt file, and the
|
||
sha256sums signature files. They can all be found in the same directory
|
||
under <a href="https://www.torproject.org/dist/torbrowser/">
|
||
https://www.torproject.org/dist/torbrowser/</a>, for example in 3.5
|
||
for TBB 3.5.</li>
|
||
<li>Retrieve the signers' GPG keys. This can be done from the command
|
||
line by entering something like
|
||
<pre>gpg --keyserver keys.mozilla.org --recv-keys 0x29846B3C683686CC</pre>
|
||
(This will bring you developer Mike Perry's public key. Other
|
||
developers' key IDs can be found on
|
||
<a href="https://www.torproject.org/docs/signing-keys.html.en">this
|
||
page</a>.)</li>
|
||
<li>Verify the sha256sums.txt file by executing this command:
|
||
<pre>gpg --verify <NAME OF THE SIGNATURE FILE>.asc sha256sums.txt</pre></li>
|
||
<li>You should see a message like "Good signature from <DEVELOPER
|
||
NAME>". If you don't, there is a problem. Try these steps again.</li>
|
||
<li>Now you can take the sha256sum of the Tor Browser package. On
|
||
Windows you can use the <a href="http://md5deep.sourceforge.net/">
|
||
hashdeep utility</a> and run
|
||
<pre>C:\location\where\you\saved\hashdeep -c sha256sum <TOR BROWSER FILE NAME>.exe</pre>
|
||
On Mac or Linux you can run <pre>sha256sum <TOR BROWSER FILE NAME>.zip</pre> or <pre>sha256sum <TOR BROWSER FILE NAME>.tar.gz</pre> without having to download a utility.</li>
|
||
<li>You will see a string of letters and numbers.</li>
|
||
<li>Open sha256sums.txt in a text editor.</li>
|
||
<li>Locate the name of the Tor Browser file you downloaded.</li>
|
||
<li>Compare the string of letters and numbers to the left of your
|
||
filename with the string of letters and numbers that appeared
|
||
on your command line. If they match, you've successfully verified the
|
||
build.</li>
|
||
</ul>
|
||
|
||
<p><a href="https://github.com/isislovecruft/scripts/blob/master/verify-gitian-builder-signatures">
|
||
Scripts</a> to <a
|
||
href="http://tor.stackexchange.com/questions/648/how-to-verify-tor-browser-bundle-tbb-3-x">automate
|
||
</a> these steps have been written, but to use them you will need to
|
||
modify them yourself with the latest Tor Browser Bundle filename.</p>
|
||
|
||
<hr>
|
||
|
||
<a id="PluggableTransports"></a>
|
||
<h3><a class="anchor" href="#PluggableTransports">How do I use pluggable transports?</a></h3>
|
||
|
||
<p>
|
||
For now, the Pluggable Transports-capable TBB is still a separate
|
||
unofficial package. Download them <a
|
||
href="https://people.torproject.org/~dcf/pt-bundle/3.5-pt20131217/">
|
||
here</a>. We hope to have combined packages available in a beta soon.
|
||
</p>
|
||
|
||
<p>
|
||
The separate Pluggable Transports-capable TBB is different from the
|
||
Pluggable Transports bundles that have been released in the past.
|
||
They include the programs necessary to use obfsproxy and flash proxy,
|
||
but the pluggable transports are not enabled by default. You must
|
||
enable them manually by adding Bridge lines to the torrc file.
|
||
(Please see ticket <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/10418">#10418</a>
|
||
for how we hope to make it easier to do in the future.)
|
||
</p>
|
||
|
||
<p>
|
||
To enable <b>obfsproxy</b>, edit the file called Data/Tor/torrc inside the
|
||
bundle and add the lines:
|
||
</p>
|
||
|
||
<pre>
|
||
Bridge obfs3 83.212.101.2:42782 2ADFE7AA8D272C520D1FBFBF4E413F3A1B26313D
|
||
Bridge obfs3 83.212.101.2:443 2ADFE7AA8D272C520D1FBFBF4E413F3A1B26313D
|
||
Bridge obfs3 169.229.59.74:31493 AF9F66B7B04F8FF6F32D455F05135250A16543C9
|
||
Bridge obfs3 169.229.59.75:46328 AF9F66B7B04F8FF6F32D455F05135250A16543C9
|
||
Bridge obfs3 209.141.36.236:45496
|
||
Bridge obfs3 208.79.90.242:35658
|
||
Bridge obfs3 109.105.109.163:38980 9D7259A696F7DAB073043B28114112A46D36CFFD
|
||
Bridge obfs3 109.105.109.163:47779 844B1F53FFD548C998F8D3B01B7E19FA07C3396E
|
||
Bridge obfs2 83.212.100.216:47870 1F01A7BB60F49FC96E0850A6BAD6D076DFEFAF80
|
||
Bridge obfs2 83.212.96.182:46602 6F058CBEF888EB20D1DEB9886909F1E812245D41
|
||
Bridge obfs2 70.182.182.109:54542 94C9E691688FAFDEC701A0788BD15BE8AD34ED35
|
||
Bridge obfs2 128.31.0.34:1051 CA7434F14A898C7D3427B8295A7F83446BC7F496
|
||
Bridge obfs2 83.212.101.2:45235 2ADFE7AA8D272C520D1FBFBF4E413F3A1B26313D
|
||
</pre>
|
||
<p>
|
||
To enable <b>flash proxy</b>, edit the file called Data/Tor/torrc inside the
|
||
bundle and add the lines:
|
||
</p>
|
||
<pre>
|
||
LearnCircuitBuildTimeout 0
|
||
CircuitBuildTimeout 60
|
||
Bridge flashproxy 0.0.1.0:1
|
||
</pre>
|
||
|
||
<hr>
|
||
|
||
<a id="NewIdentityClosingTabs"></a>
|
||
<h3><a class="anchor" href="#NewIdentityClosingTabs">Why does "New
|
||
Identity" close all my open tabs?</a></h3>
|
||
|
||
<p>
|
||
That's actually a feature, since it's discarding your application-level
|
||
browser data too. But it sure is a surprising feature, for people who
|
||
are used to Vidalia's "new identity" behavior.
|
||
</p>
|
||
|
||
<p>
|
||
We're working on ways to make the behavior less surprising, e.g. a popup
|
||
warning or auto restoring tabs. See ticket <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/9906">#9906</a> and
|
||
ticket <a href="https://trac.torproject.org/projects/tor/ticket/10400">
|
||
#10400</a> to follow progress there.
|
||
</p>
|
||
|
||
<p>
|
||
In the mean time, you can get Vidalia's old "newnym" functionality by
|
||
attaching a Vidalia to your TBB3.x. See the instructions above.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ConfigureRelayOrBridge"></a>
|
||
<h3><a class="anchor" href="#ConfigureRelayOrBridge">How do I configure Tor as a relay or bridge?</a></h3>
|
||
|
||
<p>
|
||
You've got three options.
|
||
</p>
|
||
|
||
<p>
|
||
First (best option), if you're on Linux, you can install the system
|
||
Tor package (e.g. apt-get install tor) and then set it up to be a relay
|
||
(<a href="https://www.torproject.org/docs/tor-relay-debian">instructions</a>).
|
||
You can then use TBB independent of that.
|
||
</p>
|
||
|
||
<p>
|
||
Second (simpler option), if you're on Windows, you can fetch the separate
|
||
"Vidalia relay bundle" or "Vidalia bridge bundle" from the download page
|
||
and then use that (again you can use TBB independent of it).
|
||
</p>
|
||
|
||
<p>
|
||
Third (complex option), you can either hook your Vidalia up to TBB (as
|
||
described in the FAQ above) or edit your torrc file (in Data/Tor/torrc)
|
||
directly to add the following lines:
|
||
</p>
|
||
<pre>
|
||
ORPort 443
|
||
Exitpolicy reject *:*
|
||
BridgeRelay 1 # only add this line if you want to be a bridge
|
||
</pre>
|
||
<p>
|
||
If you've installed <a
|
||
href="https://www.torproject.org/projects/obfsproxy-debian-instructions.html.en#instructions">Obfsproxy</a>,
|
||
you'll need to add one more line:
|
||
</p>
|
||
<pre>
|
||
ServerTransportPlugin obfs3 exec /usr/bin/obfsproxy managed
|
||
</pre>
|
||
<p>
|
||
This third option is pretty klunky right now; see e.g. <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/10449">this bug</a>;
|
||
but we're hoping it will become an easy option in the future.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Timestamps"></a>
|
||
<h3><a class="anchor" href="#Timestamps">Why are the file timestamps
|
||
from 2000?</a></h3>
|
||
|
||
<p>One of the huge new features in TBB 3.x is the "deterministic build"
|
||
process, which allows many people to build the Tor Browser Bundle and
|
||
verify that they all make exactly the same package. See Mike's <a
|
||
href="https://blog.torproject.org/blog/deterministic-builds-part-one-cyberwar-and-global-compromise">first
|
||
blog</a> post for the motivation, and his <a
|
||
href="https://blog.torproject.org/blog/deterministic-builds-part-two-technical-details">second
|
||
blog post</a> for the technical details of how we do it.
|
||
</p>
|
||
|
||
<p>Part of creating identical builds is having everybody use the same
|
||
timestamp. Mike picked the beginning of 2000 for that time. The reason
|
||
you might see 7pm in 1999 is because of time zones. </p>
|
||
|
||
<hr>
|
||
|
||
<a id="SourceCode"></a>
|
||
<h3><a class="anchor" href="#SourceCode">Where is the source code for the bundle? How do I verify a build?</a></h3>
|
||
|
||
<p>
|
||
Start with <a href="https://gitweb.torproject.org/builders/tor-browser-bundle.git">https://gitweb.torproject.org/builders/tor-browser-bundle.git</a> and <a href="https://gitweb.torproject.org/builders/tor-browser-bundle.git/blob/HEAD:/gitian/README.build">https://gitweb.torproject.org/builders/tor-browser-bundle.git/blob/HEAD:/gitian/README.build</a>.
|
||
</p>
|
||
|
||
|
||
<hr>
|
||
|
||
<a id="torrc"></a>
|
||
<h3><a class="anchor" href="#torrc">I'm supposed to "edit my torrc".
|
||
What does that mean?</a></h3>
|
||
|
||
<p>
|
||
Tor installs a text file called torrc that contains configuration
|
||
instructions for how your Tor program should behave. The default
|
||
configuration should work fine for most Tor users.
|
||
</p>
|
||
<p>
|
||
If you installed Tor Browser Bundle, look for
|
||
<code>Data/Tor/torrc</code> inside your Tor Browser Bundle directory.
|
||
</p>
|
||
<p>
|
||
Core tor puts the torrc file in <code>/usr/local/etc/tor/torrc</code> if you compiled tor from source, and <code>/etc/tor/torrc</code> or <code>/etc/torrc</code> if you installed a pre-built package.</p>
|
||
|
||
<p>
|
||
Once you've changed your torrc, you will need to restart tor for the
|
||
changes to take effect. (For advanced users, note that
|
||
you actually only need to send Tor a HUP signal, not actually restart
|
||
it.)
|
||
</p>
|
||
|
||
<p>
|
||
For other configuration options you can use, see the <a href="<page
|
||
docs/tor-manual>">Tor manual page</a>. Have a look at <a
|
||
href="https://gitweb.torproject.org/tor.git/blob/HEAD:/src/config/torrc.sample.in">
|
||
the sample torrc file</a> for hints on common configurations. Remember, all
|
||
lines beginning with # in torrc are treated as comments and have no effect
|
||
on Tor's configuration.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Logs"></a>
|
||
<h3><a class="anchor" href="#Logs">How do I set up logging, or see Tor's
|
||
logs?</a></h3>
|
||
|
||
<p>
|
||
If you installed a Tor bundle that includes Vidalia, then Vidalia has a
|
||
window called "Message Log" that will show you Tor's log messages. Click
|
||
on "Advanced" to see more details. You can click on "Settings" to change
|
||
your log verbosity or save the messages to a file. You're all set.
|
||
</p>
|
||
|
||
<p>
|
||
If you're not using Vidalia, you'll have to go find the log files by
|
||
hand. Here are some likely places for your logs to be:
|
||
</p>
|
||
|
||
<ul>
|
||
<li>On OS X, Debian, Red Hat, etc, the logs are in /var/log/tor/
|
||
</li>
|
||
<li>On Windows, there are no default log files currently. If you enable
|
||
logs in your torrc file, they default to <code>\username\Application
|
||
Data\tor\log\</code> or <code>\Application Data\tor\log\</code>
|
||
</li>
|
||
<li>If you compiled Tor from source, by default your Tor logs to <a
|
||
href="http://en.wikipedia.org/wiki/Standard_streams">"stdout"</a>
|
||
at log-level notice. If you enable logs in your torrc file, they
|
||
default to <code>/usr/local/var/log/tor/</code>.
|
||
</li>
|
||
</ul>
|
||
|
||
<p>
|
||
To change your logging setup by hand, <a href="#torrc">edit your
|
||
torrc</a>
|
||
and find the section (near the top of the file) which contains the
|
||
following line:
|
||
</p>
|
||
|
||
<pre>
|
||
\## Logs go to stdout at level "notice" unless redirected by something
|
||
\## else, like one of the below lines.
|
||
</pre>
|
||
|
||
<p>
|
||
For example, if you want Tor to send complete debug, info, notice, warn,
|
||
and err level messages to a file, append the following line to the end
|
||
of the section:
|
||
</p>
|
||
|
||
<pre>
|
||
Log debug file c:/program files/tor/debug.log
|
||
</pre>
|
||
|
||
<p>
|
||
Replace <code>c:/program files/tor/debug.log</code> with a directory
|
||
and filename for your Tor log.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
|
||
<a id="LogLevel"></a>
|
||
<h3><a class="anchor" href="#LogLevel">What log level should I use?</a></h3>
|
||
|
||
<p>
|
||
There are five log levels (also called "log severities") you might see in
|
||
Tor's logs:
|
||
</p>
|
||
|
||
<ul>
|
||
<li>"err": something bad just happened, and we can't recover. Tor will
|
||
exit.</li>
|
||
<li>"warn": something bad happened, but we're still running. The bad
|
||
thing might be a bug in the code, some other Tor process doing something
|
||
unexpected, etc. The operator should examine the message and try to
|
||
correct the problem.</li>
|
||
<li>"notice": something the operator will want to know about.</li>
|
||
<li>"info": something happened (maybe bad, maybe ok), but there's
|
||
nothing you need to (or can) do about it.</li>
|
||
<li>"debug": for everything louder than info. It is quite loud indeed.</li>
|
||
</ul>
|
||
|
||
<p>
|
||
Alas, some of the warn messages are hard for ordinary users to correct -- the
|
||
developers are slowly making progress at making Tor automatically react
|
||
correctly for each situation.
|
||
</p>
|
||
|
||
<p>
|
||
We recommend running at the default, which is "notice". You will hear about
|
||
important things, and you won't hear about unimportant things.
|
||
</p>
|
||
|
||
<p>
|
||
Tor relays in particular should avoid logging at info or debug in normal
|
||
operation, since they might end up recording sensitive information in
|
||
their logs.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="DoesntWork"></a>
|
||
<h3><a class="anchor" href="#DoesntWork">I installed Tor but it's not
|
||
working.</a></h3>
|
||
|
||
<p>
|
||
Once you've got the Tor bundle up and running, the first question to
|
||
ask is whether your Tor client is able to establish a circuit.
|
||
</p>
|
||
|
||
<p>If Tor can establish a circuit, the onion icon in
|
||
Vidalia will turn green (and if you're running Tor Browser Bundle, it
|
||
will
|
||
automatically launch a browser for you). You can also check in the
|
||
Vidalia
|
||
Control Panel to make sure it says "Connected to the Tor
|
||
network!" under Status. For those not using Vidalia, check your <a
|
||
href="#Logs">Tor logs</a> for
|
||
a line saying that Tor "has successfully opened a circuit. Looks like
|
||
client functionality is working."
|
||
</p>
|
||
|
||
<p>
|
||
If Tor can't establish a circuit, here are some hints:
|
||
</p>
|
||
|
||
<ol>
|
||
<li>Are you sure Tor is running? If you're using Vidalia, you may have
|
||
to click on the onion and select "Start" to launch Tor.</li>
|
||
<li>Check your system clock. If it's more than a few hours off, Tor will
|
||
refuse to build circuits. For Microsoft Windows users, synchronize your
|
||
clock under the clock -> Internet time tab. In addition, correct the
|
||
day and date under the 'Date & Time' Tab. Also make sure your time
|
||
zone is correct.</li>
|
||
<li>Is your Internet connection <a href="#FirewallPorts">firewalled
|
||
by port</a>, or do you normally need to use a <a
|
||
href="<#NeedToUseAProxy">proxy</a>?
|
||
</li>
|
||
<li>Are you running programs like Norton Internet Security or SELinux
|
||
that
|
||
block certain connections, even though you don't realize they do? They
|
||
could be preventing Tor from making network connections.</li>
|
||
<li>Are you in China, or behind a restrictive corporate network firewall
|
||
that blocks the public Tor relays? If so, you should learn about <a
|
||
href="<page docs/bridges>">Tor bridges</a>.</li>
|
||
<li>Check your <a href="#Logs">Tor logs</a>. Do they give you any hints
|
||
about what's going wrong?</li>
|
||
</ol>
|
||
|
||
<hr />
|
||
|
||
<a id="TorCrash"></a>
|
||
<h3><a class="anchor" href="#TorCrash">My Tor keeps crashing.</a></h3>
|
||
<p>
|
||
We want to hear from you! There are supposed to be zero crash bugs in Tor.
|
||
This FAQ entry describes the best way for you to be helpful to us. But even
|
||
if you can't work out all the details, we still want to hear about it, so
|
||
we can help you track it down.
|
||
</p>
|
||
<p>
|
||
First, make sure you're using the latest version of Tor (either the latest
|
||
stable or the latest development version).
|
||
</p>
|
||
<p>
|
||
Second, make sure your version of libevent is new enough. We recommend at
|
||
least libevent 1.3a.
|
||
</p>
|
||
<p>
|
||
Third, see if there's already an entry for your bug in the <a
|
||
href="https://bugs.torproject.org/">Tor bugtracker</a>. If so,
|
||
check if there are any new details that you can add.
|
||
</p>
|
||
<p>
|
||
Fourth, is the crash repeatable? Can you cause the crash? Can
|
||
you isolate some of the circumstances or config options that
|
||
make it happen? How quickly or often does the bug show up?
|
||
Can you check if it happens with other versions of Tor, for
|
||
example the latest stable release?
|
||
</p>
|
||
<p>
|
||
Fifth, what sort of crash do you get?
|
||
</p>
|
||
<ul>
|
||
<li>
|
||
Does your Tor log include an "assert failure"? If so, please
|
||
tell us that line, since it helps us figure out what's going on.
|
||
Tell us the previous couple of log messages as well, especially
|
||
if they seem important.
|
||
</li>
|
||
<li>
|
||
If it says "Segmentation fault - core dumped" then you need to
|
||
do a bit more to track it down. Look for a file like "core" or
|
||
"tor.core" or "core.12345" in your current directory, or in your
|
||
Data Directory. If it's there, run "gdb tor core" and then "bt",
|
||
and include the output. If you can't find a core, run "ulimit -c
|
||
unlimited", restart Tor, and try to make it crash again. (This core
|
||
thing will only work on Unix -- alas, tracking down bugs on Windows
|
||
is harder. If you're on Windows, can you get somebody to duplicate
|
||
your bug on Unix?)
|
||
</li>
|
||
<li>
|
||
If Tor simply vanishes mysteriously, it probably is a segmentation
|
||
fault but you're running Tor in the background (as a daemon) so you
|
||
won't notice. Go look at the end of your log file, and look for a
|
||
core file as above. If you don't find any good hints, you should
|
||
consider running Tor in the foreground (from a shell) so you can
|
||
see how it dies. Warning: if you switch to running Tor in the foreground,
|
||
you might start using a different torrc file, with a different default
|
||
Data Directory; see the <a href="#UpgradeOrMove">relay-upgrade FAQ entry</a>
|
||
for details.
|
||
</li>
|
||
<li>
|
||
If it's still vanishing mysteriously, perhaps something else is killing it?
|
||
Do you have resource limits (ulimits) configured that kill off processes
|
||
sometimes? (This is especially common on OpenBSD.) On Linux, try running
|
||
"dmesg" to see if the out-of-memory killer removed your process. (Tor will
|
||
exit cleanly if it notices that it's run out of memory, but in some cases
|
||
it might not have time to notice.) In very rare circumstances, hardware
|
||
problems could also be the culprit.
|
||
</li>
|
||
</ul>
|
||
<p>
|
||
Sixth, if the above ideas don't point out the bug, consider increasing your
|
||
log level to "loglevel debug". You can look at the log-configuration FAQ
|
||
entry for instructions on what to put in your torrc file. If it usually
|
||
takes a long time for the crash to show up, you will want to reserve a whole
|
||
lot of disk space for the debug log. Alternatively, you could just send
|
||
debug-level logs to the screen (it's called "stdout" in the torrc), and then
|
||
when it crashes you'll see the last couple of log lines it had printed.
|
||
(Note that running with verbose logging like this will slow Tor down
|
||
considerably, and note also that it's generally not a good idea security-wise
|
||
to keep logs like this sitting around.)
|
||
</p>
|
||
|
||
<hr />
|
||
|
||
<a id="VidaliaPassword"></a>
|
||
<h3><a class="anchor" href="#VidaliaPassword">Tor/Vidalia prompts for a
|
||
password at start.</a></h3>
|
||
|
||
<p>
|
||
Vidalia interacts with the Tor software via Tor's "control port". The
|
||
control port lets Vidalia receive status updates from Tor, request a new
|
||
identity, configure Tor's settings, etc. Each time Vidalia starts Tor,
|
||
Vidalia sets a random password for Tor's control port to prevent other
|
||
applications from also connecting to the control port and potentially
|
||
compromising your anonymity.
|
||
</p>
|
||
|
||
<p>
|
||
Usually this process of generating and setting a random control password
|
||
happens in the background. There are three common situations, though,
|
||
where Vidalia may prompt you for a password:
|
||
</p>
|
||
|
||
<ol>
|
||
<li>You're already running Vidalia and Tor. For example, this situation
|
||
can happen if you installed the Vidalia bundle and now you're trying to
|
||
run the Tor Browser Bundle. In that case, you'll need to close the old
|
||
Vidalia and Tor before you can run this one.
|
||
</li>
|
||
<li>Vidalia crashed, but left Tor running with the last known random
|
||
password. After you restart Vidalia, it generates a new random password,
|
||
but Vidalia can't talk to Tor, because the random passwords are
|
||
different.
|
||
<br />
|
||
If the dialog that prompts you for a control password has a Reset
|
||
button,
|
||
you can click the button and Vidalia will restart Tor with a new random
|
||
control password.
|
||
<br />
|
||
If you do not see a Reset button, or if Vidalia is unable to restart
|
||
Tor for you, you can still fix the problem manually. Simply go into your
|
||
process or task manager, and terminate the Tor process. Then use Vidalia
|
||
to restart Tor and all will work again.
|
||
</li>
|
||
<li>You had previously set Tor to run as a Windows NT service. When Tor
|
||
is set to
|
||
run as a service, it starts up when the system boots. If you configured
|
||
Tor to start as a service through Vidalia, a random password was set
|
||
and saved in Tor. When you reboot, Tor starts up and uses the random
|
||
password it saved. You login and start up Vidalia. Vidalia attempts to
|
||
talk to the already running Tor. Vidalia generates a random password,
|
||
but it is different than the saved password in the Tor service.
|
||
<br />
|
||
You need to reconfigure Tor to not be a service. See the FAQ entry on
|
||
<a href="#NTservice">running Tor as a
|
||
Windows NT service</a>
|
||
for more information on how to remove the Tor service.
|
||
</li>
|
||
</ol>
|
||
|
||
<hr>
|
||
|
||
<a id="ChooseEntryExit"></a>
|
||
<h3><a class="anchor" href="#ChooseEntryExit">Can I control which
|
||
nodes (or country) are used for entry/exit?</a></h3>
|
||
|
||
<p>
|
||
Yes. You can set preferred entry and exit nodes as well as
|
||
inform Tor which nodes you do not want to use.
|
||
The following options can be added to your config file <a
|
||
href="#torrc">"torrc"</a> or specified on the command line:
|
||
</p>
|
||
<dl>
|
||
<dt><tt>EntryNodes $fingerprint,$fingerprint,...</tt></dt>
|
||
<dd>A list of preferred nodes to use for the first hop in the
|
||
circuit, if possible.
|
||
</dd>
|
||
<dt><tt>ExitNodes $fingerprint,$fingerprint,...</tt></dt>
|
||
<dd>A list of preferred nodes to use for the last hop in the
|
||
circuit, if possible.
|
||
</dd>
|
||
<dt><tt>ExcludeNodes $fingerprint,$fingerprint,...</tt></dt>
|
||
<dd>A list of nodes to never use when building a circuit.
|
||
</dd>
|
||
<dt><tt>ExcludeExitNodes $fingerprint,$fingerprint,...</tt></dt>
|
||
<dd>A list of nodes to never use when picking an exit.
|
||
Nodes listed in <tt>ExcludeNodes</tt> are automatically in
|
||
this list.
|
||
</dd>
|
||
</dl>
|
||
<p>
|
||
<em>We recommend you do not use these</em>
|
||
— they are intended for testing and may disappear in future
|
||
versions.
|
||
You get the best security that Tor can provide when you leave the
|
||
route selection to Tor; overriding the entry / exit nodes can mess
|
||
up your anonymity in ways we don't understand.
|
||
</p>
|
||
<p>
|
||
Note also that not every circuit is used to deliver traffic outside of
|
||
the Tor network. It is normal to see non-exit circuits (such as those
|
||
used to connect to hidden services, those that do directory fetches,
|
||
those used for relay reachability self-tests, and so on) that end at
|
||
a non-exit node. To keep a node from being used entirely, see
|
||
<tt>ExcludeNodes</tt> and <tt>StrictNodes</tt> in the
|
||
<a href="<page docs/tor-manual>">manual</a>.
|
||
</p>
|
||
<p>
|
||
Instead of <tt>$fingerprint</tt> you can also specify a <a
|
||
|
||
href="https://secure.wikimedia.org/wikipedia/en/wiki/ISO_3166-1_alpha-2"
|
||
>2
|
||
letter ISO3166 country code</a> in curly braces (for example <tt>{de}</tt>),
|
||
or an ip address pattern (for example 255.254.0.0/8), or a node
|
||
nickname. Make sure there are no spaces between the commas and the
|
||
list items.
|
||
</p>
|
||
<p>
|
||
If you want to access a service directly through Tor's Socks
|
||
interface
|
||
(eg. using ssh via connect.c), another option is to set up an
|
||
internal mapping in your configuration file using
|
||
<tt>MapAddress</tt>.
|
||
See the manual page for details.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="FirewallPorts"></a>
|
||
<h3><a class="anchor" href="#FirewallPorts">My firewall only allows a
|
||
few outgoing ports.</a></h3>
|
||
|
||
<p>
|
||
If your firewall works by blocking ports, then you can tell Tor to only
|
||
use the ports that your firewall permits by adding "FascistFirewall 1"
|
||
to
|
||
your <a href="<page docs/faq>#torrc">torrc
|
||
configuration file</a>, or by clicking "My firewall only lets me connect
|
||
to certain ports" in Vidalia's Network Settings window.
|
||
</p>
|
||
|
||
<p>
|
||
By default, when you set this Tor assumes that your firewall allows only
|
||
port 80 and port 443 (HTTP and HTTPS respectively). You can select a
|
||
different set of ports with the FirewallPorts torrc option.
|
||
</p>
|
||
|
||
<p>
|
||
If you want to be more fine-grained with your controls, you can also
|
||
use the ReachableAddresses config options, e.g.:
|
||
</p>
|
||
|
||
<pre>
|
||
ReachableDirAddresses *:80
|
||
ReachableORAddresses *:443
|
||
</pre>
|
||
|
||
<hr>
|
||
|
||
<a id="DefaultExitPorts"></a>
|
||
<h3><a class="anchor" href="#DefaultExitPorts">Is there a list of default exit
|
||
ports?</a></h3>
|
||
<p>
|
||
The default open ports are listed below but keep in mind that, any port or
|
||
ports can be opened by the relay operator by configuring it in torrc or
|
||
modifying the source code. But the default according to src/or/policies.c
|
||
from the source code release tor-0.2.4.16-rc is:
|
||
</p>
|
||
<pre>
|
||
reject 0.0.0.0/8
|
||
reject 169.254.0.0/16
|
||
reject 127.0.0.0/8
|
||
reject 192.168.0.0/16
|
||
reject 10.0.0.0/8
|
||
reject 172.16.0.0/12
|
||
reject *:25
|
||
reject *:119
|
||
reject *:135-139
|
||
reject *:445
|
||
reject *:563
|
||
reject *:1214
|
||
reject *:4661-4666
|
||
reject *:6346-6429
|
||
reject *:6699
|
||
reject *:6881-6999
|
||
accept *:*
|
||
</pre>
|
||
<p>
|
||
A relay will block access to its own IP address, as well local network
|
||
IP addresses. A relay always blocks itself by default. This prevents
|
||
Tor users from accidentally accessing any of the exit operator's local
|
||
services.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="SocksAndDNS"></a>
|
||
<h3><a class="anchor" href="#SocksAndDNS">How do I check if my application that uses
|
||
SOCKS is leaking DNS requests?</a></h3>
|
||
|
||
<p>
|
||
These are two steps you need to take here. The first is to make sure
|
||
that it's using the correct variant of the SOCKS protocol, and the
|
||
second is to make sure that there aren't other leaks.
|
||
</p>
|
||
|
||
<p>
|
||
Step one: add "TestSocks 1" to your torrc file, and then watch your
|
||
logs as you use your application. Tor will then log, for each SOCKS
|
||
connection, whether it was using a 'good' variant or a 'bad' one.
|
||
(If you want to automatically disable all 'bad' variants, set
|
||
"SafeSocks 1" in your <a href="#torrc">torrc</a> file.)
|
||
</p>
|
||
|
||
<p>
|
||
Step two: even if your application is using the correct variant of
|
||
the SOCKS protocol, there is still a risk that it could be leaking
|
||
DNS queries. This problem happens in Firefox extensions that resolve
|
||
the destination hostname themselves, for example to show you its IP
|
||
address, what country it's in, etc. These applications may use a safe
|
||
SOCKS variant when actually making connections, but they still do DNS
|
||
resolves locally. If you suspect your application might behave like
|
||
this, you should use a network sniffer like <a
|
||
href="https://www.wireshark.org/">Wireshark</a> and look for
|
||
suspicious outbound DNS requests. I'm afraid the details of how to look
|
||
for these problems are beyond the scope of a FAQ entry though -- find
|
||
a friend to help if you have problems.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="HowDoIDecide"></a>
|
||
<h3><a class="anchor" href="#HowDoIDecide">How do I decide if I should
|
||
run a relay?</a></h3>
|
||
<p>
|
||
We're looking for people with reasonably reliable Internet connections,
|
||
that have at least 20 kilobytes/second each way. If that's you, please
|
||
consider <a href="https://www.torproject.org/docs/tor-relay-debian">helping
|
||
out</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhyIsntMyRelayBeingUsedMore"></a>
|
||
<h3><a class="anchor" href="#WhyIsntMyRelayBeingUsedMore">Why isn't my
|
||
relay being used more?</a></h3>
|
||
<p>
|
||
If your relay is relatively new then give it time. Tor decides which
|
||
relays it uses heuristically based on reports from Bandwidth
|
||
Authorities. These authorities take measurements of your relay's
|
||
capacity and, over time, directs more traffic there until it reaches
|
||
an optimal load. The lifecycle of a new relay is explained in more
|
||
depth in <a href="https://blog.torproject.org/blog/lifecycle-of-a-new-relay">
|
||
this blog post</a>.
|
||
</p>
|
||
<p>
|
||
If you've been running a relay for a while and still having issues
|
||
then try asking on the <a href=
|
||
"https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-relays/">
|
||
tor-relays list</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="IDontHaveAStaticIP"></a>
|
||
<h3><a class="anchor" href="#IDontHaveAStaticIP">I don't have a static
|
||
IP.</a></h3>
|
||
|
||
<p>
|
||
Tor can handle relays with dynamic IP addresses just fine. Just leave
|
||
the "Address" line in your torrc blank, and Tor will guess.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ModemKeepsCrashing"></a>
|
||
<h3><a class="anchor" href="#ModemKeepsCrashing">My cable/DSL modem
|
||
keeps crashing. What's going on?</h3></a>
|
||
|
||
<p>
|
||
Tor relays hold many connections open at once. This is more intensive
|
||
use than your cable modem (or other home router) would ever get normally.
|
||
So if there are any bugs or instabilities, they might show up now.
|
||
</p>
|
||
<p>
|
||
If your router keeps crashing, you've got two options. First, you should
|
||
try to upgrade its firmware. If you need tips on how to do this, ask
|
||
Google or your cable/router provider, or try the Tor IRC channel.
|
||
</p>
|
||
|
||
<p>
|
||
Usually the firmware upgrade will fix it. If it doesn't, you will
|
||
probably want to get a new (better) router.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="PortscannedMore"></a>
|
||
<h3><a class="anchor" href="#PortscannedMore">Why do I get portscanned
|
||
more often when I run a Tor relay?</a></h3>
|
||
|
||
<p>
|
||
If you allow exit connections, some services that people connect to
|
||
from your relay will connect back to collect more information about you.
|
||
For example, some IRC servers connect back to your identd port to record
|
||
which user made the connection. (This doesn't really work for them,
|
||
because Tor doesn't know this information, but they try anyway.) Also,
|
||
users exiting from you might attract the attention of other users on the
|
||
IRC server, website, etc. who want to know more about the host they're
|
||
relaying through.
|
||
</p>
|
||
<p>
|
||
Another reason is that groups who scan for open proxies on the Internet
|
||
have learned that sometimes Tor relays expose their socks port to the
|
||
world. We recommend that you bind your socksport to local networks only.
|
||
</p>
|
||
<p>
|
||
In any case, you need to keep up to date with your security. See this <a
|
||
href="https://trac.torproject.org/projects/tor/wiki/doc/OperationalSecurity">article
|
||
on operational security for Tor relays</a> for more suggestions.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="MoreThanOneCPU"></a>
|
||
<h3><a class="anchor" href="#MoreThanOneCPU">I have more than one CPU.
|
||
Does this help?</a></h3>
|
||
|
||
<p>
|
||
Yes. You can set your NumCpus config option in torrc to the number of
|
||
CPUs you have, and Tor will spawn this many cpuworkers to deal with
|
||
public key operations in parallel.
|
||
</p>
|
||
|
||
<p>
|
||
This option has no effect for clients.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="HighCapacityConnection"></a>
|
||
<h3><a class="anchor" href="#HighCapacityConnection">How can I get Tor to fully
|
||
make use of my high capacity connection?</a></h3>
|
||
|
||
<p>
|
||
See <a href="http://archives.seul.org/or/relays/Aug-2010/msg00034.html">this
|
||
tor-relays thread</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="RelayFlexible"></a>
|
||
<h3><a class="anchor" href="#RelayFlexible">How stable does my relay
|
||
need to be?</a></h3>
|
||
|
||
<p>
|
||
We aim to make setting up a Tor relay easy and convenient:
|
||
</p>
|
||
|
||
<ul>
|
||
<li>Tor has built-in support for <a
|
||
href="<wikifaq>#WhatbandwidthshapingoptionsareavailabletoTorrelays">
|
||
rate limiting</a>. Further, if you have a fast
|
||
link but want to limit the number of bytes per
|
||
day (or week or month) that you donate, check out the <a
|
||
|
||
href="<wikifaq>#HowcanIlimitthetotalamountofbandwidthusedbymyTorrelay">
|
||
hibernation
|
||
feature</a>.
|
||
</li>
|
||
<li>Each Tor relay has an <a href="#ExitPolicies">exit policy</a>
|
||
that
|
||
specifies what sort of outbound connections are allowed or refused
|
||
from
|
||
that relay. If you are uncomfortable allowing people to exit from
|
||
your
|
||
relay, you can set it up to only allow connections to other Tor
|
||
relays.
|
||
</li>
|
||
<li>It's fine if the relay goes offline sometimes. The directories
|
||
notice this quickly and stop advertising the relay. Just try to make
|
||
sure it's not too often, since connections using the relay when it
|
||
disconnects will break.
|
||
</li>
|
||
<li>We can handle relays with dynamic IPs just fine — simply
|
||
leave the Address config option blank, and Tor will try to guess.
|
||
</li>
|
||
<li>If your relay is behind a NAT and it doesn't know its public
|
||
IP (e.g. it has an IP of 192.168.x.y), you'll need to set up port
|
||
forwarding. Forwarding TCP connections is system dependent but
|
||
<a href="#BehindANAT">this FAQ entry</a>
|
||
offers some examples on how to do this.
|
||
</li>
|
||
<li>Your relay will passively estimate and advertise its recent
|
||
bandwidth capacity, so high-bandwidth relays will attract more users
|
||
than
|
||
low-bandwidth ones. Therefore having low-bandwidth relays is useful
|
||
too.
|
||
</li>
|
||
</ul>
|
||
|
||
<hr>
|
||
|
||
<a id="BandwidthShaping"></a>
|
||
<h3><a class="anchor" href="#BandwidthShaping">What bandwidth shaping
|
||
options are available to Tor relays?</a></h3>
|
||
|
||
<p>
|
||
There are two options you can add to your torrc file:
|
||
</p>
|
||
<ul>
|
||
<li>
|
||
BandwidthRate is the maximum long-term bandwidth allowed (bytes per
|
||
second). For example, you might want to choose "BandwidthRate 2 MB"
|
||
for 2 megabytes per second (a fast connection), or "BandwidthRate 50
|
||
KB" for 50 kilobytes per second (a medium-speed cable connection).
|
||
The minimum BandwidthRate is 20 kilobytes per second.
|
||
</li>
|
||
<li>
|
||
BandwidthBurst is a pool of bytes used to fulfill requests during
|
||
short periods of traffic above BandwidthRate but still keeps the
|
||
average over a long period to BandwidthRate. A low Rate but a high
|
||
Burst enforces a long-term average while still allowing more traffic
|
||
during peak times if the average hasn't been reached lately. For example,
|
||
if you choose "BandwidthBurst 50 KB" and also use that for your
|
||
BandwidthRate, then you will never use more than 50 kilobytes per second;
|
||
but if you choose a higher BandwidthBurst (like 1 MB), it will allow
|
||
more bytes through until the pool is empty.
|
||
</li>
|
||
</ul>
|
||
<p>
|
||
If you have an asymmetric connection (upload less than download) such
|
||
as a cable modem, you should set BandwidthRate to less than your smaller
|
||
bandwidth (Usually that's the upload bandwidth). (Otherwise, you could
|
||
drop many packets during periods of maximum bandwidth usage -- you may
|
||
need to experiment with which values make your connection comfortable.)
|
||
Then set BandwidthBurst to the same as BandwidthRate.
|
||
</p>
|
||
<p>
|
||
Linux-based Tor nodes have another option at their disposal: they can
|
||
prioritize Tor traffic below other traffic on their machine, so that
|
||
their own personal traffic is not impacted by Tor load. A <a
|
||
href="https://gitweb.torproject.org/tor.git/blob/HEAD:/contrib/linux-tor-prio.sh">script
|
||
to do this</a> can be found in the Tor source distribution's contrib
|
||
directory.
|
||
</p>
|
||
<p>
|
||
Additionally, there are hibernation options where you can tell Tor to
|
||
only serve a certain amount of bandwidth per time period (such as 100
|
||
GB per month). These are covered in the <a
|
||
href="#LimitTotalBandwidth">hibernation entry</a> below.
|
||
</p>
|
||
<p>
|
||
Note that BandwidthRate and BandwidthBurst are in <b>Bytes,</b>not Bits.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="LimitTotalBandwidth"></a>
|
||
<h3><a class="anchor" href="#LimitTotalBandwidth">How can I limit the
|
||
total amount of bandwidth used by my Tor relay?</a></h3>
|
||
<p>
|
||
The accounting options in the torrc file allow you to specify the maximum
|
||
amount of bytes your relay uses for a time period.
|
||
</p>
|
||
<pre>
|
||
AccountingStart day week month [day] HH:MM
|
||
</pre>
|
||
<p>
|
||
This specifies when the accounting should reset. For instance, to setup
|
||
a total amount of bytes served for a week (that resets every Wednesday
|
||
at 10:00am), you would use:
|
||
</p>
|
||
<pre>
|
||
AccountingStart week 3 10:00
|
||
AccountingMax N bytes KB MB GB TB
|
||
</pre>
|
||
<p>
|
||
This specifies the maximum amount of data your relay will send during an
|
||
accounting period, and the maximum amount of data your relay will receive
|
||
during an account period. When the accounting period resets (from
|
||
AccountingStart), then the counters for AccountingMax are reset to 0.
|
||
</p>
|
||
<p>
|
||
Example. Let's say you want to allow 1 GB of traffic every day in each
|
||
direction and the accounting should reset at noon each day:
|
||
</p>
|
||
<pre>
|
||
AccountingStart day 12:00
|
||
AccountingMax 1 GB
|
||
</pre>
|
||
<p>
|
||
Note that your relay won't wake up exactly at the beginning of each
|
||
accounting period. It will keep track of how quickly it used its
|
||
quota in the last period, and choose a random point in the new interval
|
||
to wake up. This way we avoid having hundreds of relays working at the
|
||
beginning of each month but none still up by the end.
|
||
</p>
|
||
<p>
|
||
If you have only a small amount of bandwidth to donate compared to your
|
||
connection speed, we recommend you use daily accounting, so you don't
|
||
end up using your entire monthly quota in the first day. Just divide
|
||
your monthly amount by 30. You might also consider rate limiting to
|
||
spread your usefulness over more of the day: if you want to offer X GB
|
||
in each direction, you could set your BandwidthRate to 20*X. For example,
|
||
if you have 10 GB to offer each way, you might set your BandwidthRate to
|
||
200 KB: this way your relay will always be useful for at least half of
|
||
each day.
|
||
</p>
|
||
<hr>
|
||
|
||
<a id="ExitPolicies"></a>
|
||
<h3><a class="anchor" href="#ExitPolicies">I'd run a relay, but I
|
||
don't want to deal with abuse issues.</a></h3>
|
||
|
||
<p>
|
||
Great. That's exactly why we implemented exit policies.
|
||
</p>
|
||
|
||
<p>
|
||
Each Tor relay has an exit policy that specifies what sort of
|
||
outbound connections are allowed or refused from that relay. The
|
||
exit
|
||
policies are propagated to Tor clients via the directory, so clients
|
||
will automatically avoid picking exit relays that would refuse to
|
||
exit to their intended destination. This way each relay can decide
|
||
the services, hosts, and networks he wants to allow connections to,
|
||
based on abuse potential and his own situation. Read the FAQ entry
|
||
on
|
||
<a href="<page docs/faq-abuse>#TypicalAbuses">issues you might
|
||
encounter</a>
|
||
if you use the default exit policy, and then read Mike Perry's
|
||
<a href="<blog>tips-running-exit-node-minimal-harassment">tips
|
||
for running an exit node with minimal harassment</a>.
|
||
</p>
|
||
|
||
<p>
|
||
The default exit policy allows access to many popular services
|
||
(e.g. web browsing), but <a
|
||
href="#DefaultExitPorts">restricts</a>
|
||
some due to abuse potential (e.g. mail) and some since
|
||
the Tor network can't handle the load (e.g. default
|
||
file-sharing ports). You can change your exit policy
|
||
using Vidalia's "Sharing" tab, or by manually editing your
|
||
<a href="<page docs/faq>#torrc">torrc</a>
|
||
file. If you want to avoid most if not all abuse potential, set it
|
||
to
|
||
"reject *:*" (or un-check all the boxes in Vidalia). This setting
|
||
means
|
||
that your relay will be used for relaying traffic inside the Tor
|
||
network,
|
||
but not for connections to external websites or other services.
|
||
</p>
|
||
|
||
<p>
|
||
If you do allow any exit connections, make sure name resolution
|
||
works
|
||
(that is, your computer can resolve Internet addresses correctly).
|
||
If there are any resources that your computer can't reach (for
|
||
example,
|
||
you are behind a restrictive firewall or content filter), please
|
||
explicitly reject them in your exit policy — otherwise Tor
|
||
users
|
||
will be impacted too.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="DifferentComputer"></a>
|
||
<h3><a class="anchor" href="#DifferentComputer">I want to run my
|
||
Tor client on a different computer than my applications.</a></h3>
|
||
<p>
|
||
By default, your Tor client only listens for applications that
|
||
connect from localhost. Connections from other computers are
|
||
refused. If you want to torify applications on different computers
|
||
than the Tor client, you should edit your torrc to define
|
||
SocksListenAddress 0.0.0.0 g and then restart (or hup) Tor. If you
|
||
want to get more advanced, you can configure your Tor client on a
|
||
firewall to bind to your internal IP but not your external IP.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ServerClient"></a>
|
||
<h3><a class="anchor" href="#ServerClient">Can I install Tor on a
|
||
central server, and have my clients connect to it?</a></h3>
|
||
<p>
|
||
Yes. Tor can be configured as a client or a relay on another
|
||
machine, and allow other machines to be able to connect to it
|
||
for anonymity. This is most useful in an environment where many
|
||
computers want a gateway of anonymity to the rest of the world.
|
||
However, be forwarned that with this configuration, anyone within
|
||
your private network (existing between you and the Tor
|
||
client/relay) can see what traffic you are sending in clear text.
|
||
The anonymity doesn't start until you get to the Tor relay.
|
||
Because of this, if you are the controller of your domain and you
|
||
know everything's locked down, you will be OK, but this configuration
|
||
may not be suitable for large private networks where security is
|
||
key all around.
|
||
</p>
|
||
<p>
|
||
Configuration is simple, editing your torrc file's SocksListenAddress
|
||
according to the following examples:
|
||
</p>
|
||
<pre>
|
||
|
||
#This provides local interface access only,
|
||
#needs SocksPort to be greater than 0
|
||
SocksListenAddress 127.0.0.1
|
||
|
||
#This provides access to Tor on a specified interface
|
||
SocksListenAddress 192.168.x.x:9100
|
||
|
||
#Accept from all interfaces
|
||
SocksListenAddress 0.0.0.0:9100
|
||
</pre>
|
||
<p>
|
||
You can state multiple listen addresses, in the case that you are
|
||
part of several networks or subnets.
|
||
</p>
|
||
<pre>
|
||
SocksListenAddress 192.168.x.x:9100 #eth0
|
||
SocksListenAddress 10.x.x.x:9100 #eth1
|
||
</pre>
|
||
<p>
|
||
After this, your clients on their respective networks/subnets would specify
|
||
a socks proxy with the address and port you specified SocksListenAddress
|
||
to be.
|
||
</p>
|
||
<p>
|
||
Please note that the SocksPort configuration option gives the port ONLY for
|
||
localhost (127.0.0.1). When setting up your SocksListenAddress(es), you need
|
||
to give the port with the address, as shown above.
|
||
<p>
|
||
If you are interested in forcing all outgoing data through the central Tor
|
||
client/relay, instead of the server only being an optional proxy, you may find
|
||
the program iptables (for *nix) useful.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="JoinTheNetwork"></a>
|
||
<h3><a class="anchor" href="#JoinTheNetwork">So I can just configure a
|
||
nickname and ORPort and join the network?</a></h3>
|
||
|
||
<p>
|
||
Yes. You can join the network and be a useful relay just by configuring
|
||
your Tor to be a relay and making sure it's reachable from the outside.
|
||
</p>
|
||
<p>
|
||
30 Seconds to a Tor Relay:
|
||
</p>
|
||
<ul><li>
|
||
Configure a Nickname:
|
||
</li></ul>
|
||
<pre>
|
||
Nickname ididnteditheconfig
|
||
</pre>
|
||
<ul><li>
|
||
Configure ORPort:
|
||
</li></ul>
|
||
<pre>
|
||
ORPort 9001
|
||
</pre>
|
||
<ul><li>
|
||
Configure Contact Info:
|
||
</li></ul>
|
||
|
||
<pre>
|
||
ContactInfo human@…
|
||
</pre>
|
||
<ul><li>
|
||
Start Tor. Watch the log file for a log entry that states: "Self-testing
|
||
indicates your ORPort is reachable from the outside. Excellent. Publishing
|
||
server descriptor."
|
||
</li></ul>
|
||
|
||
<hr />
|
||
|
||
<a id="RelayOrBridge"></a>
|
||
<h3><a class="anchor" href="#RelayOrBridge">Should I be a normal
|
||
relay or bridge relay?</a></h3>
|
||
|
||
<p><a href="<page docs/bridges>">Bridge relays</a> (or "bridges" for
|
||
short)
|
||
are <a href="<page docs/tor-doc-relay>">Tor relays</a> that aren't
|
||
listed in the public Tor directory.
|
||
That means that ISPs or governments trying to block access to the
|
||
Tor network can't simply block all bridges.
|
||
</p>
|
||
|
||
<p>Being a normal relay vs being a bridge relay is almost the same
|
||
configuration: it's just a matter of whether your relay is listed
|
||
publicly or not.
|
||
</p>
|
||
|
||
<p>
|
||
So bridges are useful a) for Tor users in oppressive regimes,
|
||
and b) for people who want an extra layer of security
|
||
because they're worried somebody will recognize that it's a public
|
||
Tor relay IP address they're contacting.
|
||
</p>
|
||
|
||
<p>
|
||
Several countries, including China and Iran, have found ways to
|
||
detect and block connections to Tor bridges.
|
||
<a href="<page projects/obfsproxy>">Obfsproxy</a> bridges address
|
||
this by adding another layer of obfuscation.
|
||
</p>
|
||
|
||
<p>So should you run a normal relay or bridge relay? If you have
|
||
lots
|
||
of bandwidth, you should definitely run a normal relay.
|
||
If you're willing
|
||
to <a href="#ExitPolicies">be an exit</a>, you should definitely
|
||
run a normal relay, since we need more exits. If you can't be an
|
||
exit and only have a little bit of bandwidth, be a bridge. Thanks
|
||
for volunteering!
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="UpgradeOrMove"></a>
|
||
<h3><a class="anchor" href="#UpgradeOrMove">I want to upgrade/move my relay.
|
||
How do I keep the same key?</a></h3>
|
||
|
||
<p>
|
||
When upgrading your Tor relay, or running it on a different computer,
|
||
the important part is to keep the same nickname (defined in your torrc
|
||
file) and the same identity key (stored in "keys/secret_id_key" in
|
||
your DataDirectory).
|
||
</p>
|
||
<p>
|
||
This means that if you're upgrading your Tor relay and you keep the same
|
||
torrc and the same DataDirectory, then the upgrade should just work and
|
||
your relay will keep using the same key. If you need to pick a new
|
||
DataDirectory, be sure to copy your old keys/secret_id_key over.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="NTService"></a>
|
||
<h3><a class="anchor" href="#NTService">How do I run my Tor relay as an NT
|
||
service?</a></h3>
|
||
|
||
<p>
|
||
You can run Tor as a service on all versions of Windows except Windows
|
||
95/98/ME. This way you can run a Tor relay without needing to always have
|
||
Vidalia running.
|
||
</p>
|
||
<p>
|
||
If you've already configured your Tor to be a relay, please note that when
|
||
you enable Tor as a service, it will use a different DatagDirectory, and
|
||
thus will generate a different key. If you want to keep using the old key,
|
||
see the Upgrading your Tor relay FAQ entry for how to restore the old
|
||
identity key.
|
||
</p>
|
||
<p>
|
||
To install Tor as a service, you can simply run:
|
||
</p>
|
||
<pre>
|
||
tor --service install
|
||
</pre>
|
||
<p>
|
||
A service called Tor Win32 Service will be installed and started. This
|
||
service will also automatically start every time Windows boots, unless
|
||
you change the Start-up type. An easy way to check the status of Tor,
|
||
start or stop the service, and change the start-up type is by running
|
||
services.msc and finding the Tor service in the list of currently
|
||
installed services.
|
||
</p>
|
||
<p>
|
||
Optionally, you can specify additional options for the Tor service using
|
||
the -options argument. For example, if you want Tor to use C:\tor\torrc,
|
||
instead of the default torrc, and open a control port on port 9151, you
|
||
would run:
|
||
</p>
|
||
<pre>
|
||
tor --service install -options -f C:\tor\torrc ControlPort 9151
|
||
</pre>
|
||
<p>
|
||
You can also start or stop the Tor service from the command line by typing:
|
||
</p>
|
||
<pre>
|
||
tor --service start
|
||
</pre>
|
||
<p>
|
||
or
|
||
</p>
|
||
<pre>
|
||
tor --service stop
|
||
</pre>
|
||
<p>
|
||
To remove the Tor service, you can run the following command:
|
||
</p>
|
||
<pre>
|
||
tor --service remove
|
||
</pre>
|
||
<p>
|
||
If you are running Tor as a service and you want to uninstall Tor entirely,
|
||
be sure to run the service removal command (shown above) first before
|
||
running the uninstaller from "Add/Remove Programs". The uninstaller is
|
||
currently not capable of removing the active service.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="VirtualServer"></a>
|
||
<h3><a class="anchor" href="#VirtualServer">Can I run a Tor relay from my
|
||
virtual server account?</a></h3>
|
||
|
||
<p>
|
||
Some ISPs are selling "vserver" accounts that provide what they call a
|
||
virtual server -- you can't actually interact with the hardware, and
|
||
they can artificially limit certain resources such as the number of file
|
||
descriptors you can open at once. Competent vserver admins are able to
|
||
configure your server to not hit these limits. For example, in SWSoft's
|
||
Virtuozzo, investigate /proc/user_beancounters. Look for "failcnt" in
|
||
tcpsndbuf, tcprecvbuf, numothersock, and othersockbuf. Ask for these to
|
||
be increased accordingly. Some users have seen settings work well as follows:
|
||
<p>
|
||
<table border="1">
|
||
<tr>
|
||
<td>
|
||
<i>resource</i>
|
||
</td>
|
||
<td>
|
||
<i>held</i>
|
||
</td>
|
||
<td>
|
||
<i>maxheld</i>
|
||
</td>
|
||
<td>
|
||
<i>barrier</i>
|
||
</td>
|
||
<td>
|
||
<i>limit</i>
|
||
</td>
|
||
<td>
|
||
<i>failcnt</i>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
tcpsndbuf
|
||
</td>
|
||
<td>
|
||
46620
|
||
</td>
|
||
<td>
|
||
48840
|
||
</td>
|
||
<td>
|
||
3440640
|
||
</td>
|
||
<td>
|
||
5406720
|
||
</td>
|
||
<td>
|
||
0
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
tcprcvbuf
|
||
</td>
|
||
<td>
|
||
0
|
||
</td>
|
||
<td>
|
||
2220
|
||
</td>
|
||
<td>
|
||
3440640
|
||
</td>
|
||
<td>
|
||
5406720
|
||
</td>
|
||
<td>
|
||
0
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
othersockbuf
|
||
</td>
|
||
<td>
|
||
243516
|
||
</td>
|
||
<td>
|
||
260072
|
||
</td>
|
||
<td>
|
||
2252160
|
||
</td>
|
||
<td>
|
||
4194304
|
||
</td>
|
||
<td>
|
||
0
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
numothersock
|
||
</td>
|
||
<td>
|
||
151
|
||
</td>
|
||
<td>
|
||
153
|
||
</td>
|
||
<td>
|
||
720
|
||
</td>
|
||
<td>
|
||
720
|
||
</td>
|
||
<td>
|
||
0
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
<p>
|
||
Xen, Virtual Box and VMware virtual servers have no such limits normally.
|
||
</p>
|
||
<p>
|
||
If the vserver admin will not increase system limits another option is
|
||
to reduce the memory allocated to the send and receive buffers on TCP
|
||
connections Tor uses. An experimental feature to constrain socket buffers
|
||
has recently been added. If your version of Tor supports it, set
|
||
"ConstrainedSockets 1" in your configuration. See the tor man page for
|
||
additional details about this option.
|
||
</p>
|
||
<p>
|
||
Unfortunately, since Tor currently requires you to be able to connect to
|
||
all the other Tor relays, we need you to be able to use at least 1024 file
|
||
descriptors. This means we can't make use of Tor relays that are crippled
|
||
in this way.
|
||
</p>
|
||
<p>
|
||
We hope to fix this in the future, once we know how to build a Tor network
|
||
with restricted topologies -- that is, where each node connects to only a
|
||
few other nodes. But this is still a long way off.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="MultipleRelays"></a>
|
||
<h3><a class="anchor" href="#MultipleRelays">I want to run more than one
|
||
relay.</a></h3>
|
||
|
||
<p>
|
||
Great. If you want to run several relays to donate more to the network,
|
||
we're happy with that. But please don't run more than a few dozen on
|
||
the same network, since part of the goal of the Tor network is dispersal
|
||
and diversity.
|
||
</p>
|
||
|
||
<p>
|
||
If you do decide to run more than one relay, please set the "MyFamily"
|
||
config option in the <a href="#torrc">torrc</a> of each relay, listing
|
||
all the relays (comma-separated) that are under your control:
|
||
</p>
|
||
|
||
<pre>
|
||
MyFamily $fingerprint1,$fingerprint2,$fingerprint3
|
||
</pre>
|
||
|
||
<p>
|
||
where each fingerprint is the 40 character identity fingerprint (without
|
||
spaces). You can also list them by nickname, but fingerprint is safer.
|
||
Be
|
||
sure to prefix the digest strings with a dollar sign ('$') so that the
|
||
digest is not confused with a nickname in the config file.
|
||
</p>
|
||
|
||
<p>
|
||
That way clients will know to avoid using more than one of your relays
|
||
in a single circuit. You should set MyFamily if you have administrative
|
||
control of the computers or of their network, even if they're not all in
|
||
the same geographic location.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WrongIP"></a>
|
||
<h3><a class="anchor" href="#WrongIP">My relay is picking the wrong
|
||
IP address.</a></h3>
|
||
<p>
|
||
Tor guesses its IP address by asking the computer for its hostname, and
|
||
then resolving that hostname. Often people have old entries in their
|
||
/etc/hosts file that point to old IP addresses.
|
||
</p>
|
||
<p>
|
||
If that doesn't fix it, you should use the "Address" config option to
|
||
specify the IP you want it to pick. If your computer is behind a NAT and
|
||
it only has an internal IP address, see the following FAQ entry on <a
|
||
href="#RelayFlexible">dynamic IP addresses</a>.
|
||
</p>
|
||
<p>
|
||
Also, if you have many addresses, you might also want to set
|
||
"OutboundBindAddress" so external connections come from the IP you intend
|
||
to present to the world.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="BehindANAT"></a>
|
||
<h3><a class="anchor" href="#BehindANAT">I'm behind a NAT/Firewall.</a></h3>
|
||
|
||
<p>
|
||
See <a>http://portforward.com/</a> for directions on how to port forward with
|
||
your NAT/router device.
|
||
</p>
|
||
<p>
|
||
If your relay is running on a internal net you need to setup port forwarding.
|
||
Forwarding TCP connections is system dependent but the firewalled-clients FAQ
|
||
entry offers some examples on how to do this.
|
||
</p>
|
||
<p>
|
||
Also, here's an example of how you would do this on GNU/Linux if you're using
|
||
iptables:
|
||
</p>
|
||
<pre>
|
||
/sbin/iptables -A INPUT -i eth0 -p tcp --destination-port 9001 -j ACCEPT
|
||
</pre>
|
||
<p>
|
||
You may have to change "eth0" if you have a different external interface
|
||
(the one connected to the Internet). Chances are you have only one (except
|
||
the loopback) so it shouldn't be too hard to figure out.
|
||
</p>
|
||
<hr>
|
||
|
||
<a id="RelayMemory"></a>
|
||
<h3><a class="anchor" href="#RelayMemory">Why is my Tor relay using
|
||
so much memory?</a></h3>
|
||
|
||
<p>If your Tor relay is using more memory than you'd like, here are
|
||
some
|
||
tips for reducing its footprint:
|
||
</p>
|
||
|
||
<ol>
|
||
<li>If you're on Linux, you may be encountering memory fragmentation
|
||
bugs in glibc's malloc implementation. That is, when Tor releases
|
||
memory
|
||
back to the system, the pieces of memory are fragmented so they're
|
||
hard
|
||
to reuse. The Tor tarball ships with OpenBSD's malloc
|
||
implementation,
|
||
which doesn't have as many fragmentation bugs (but the tradeoff is
|
||
higher
|
||
CPU load). You can tell Tor to use this malloc implementation
|
||
instead:
|
||
<tt>./configure --enable-openbsd-malloc</tt></li>
|
||
|
||
<li>If you're running a fast relay, meaning you have many TLS
|
||
connections
|
||
open, you are probably losing a lot of memory to OpenSSL's internal
|
||
buffers (38KB+ per socket). We've patched OpenSSL to <a
|
||
|
||
href="https://lists.torproject.org/pipermail/tor-dev/2008-June/001519.
|
||
html">release
|
||
unused buffer memory more aggressively</a>. If you update to OpenSSL
|
||
1.0.0 or newer, Tor's build process will automatically recognize and
|
||
use
|
||
this feature.</li>
|
||
|
||
<!-- Nickm says he's not sure this is still accurate
|
||
|
||
<li>If you're running on Solaris, OpenBSD, NetBSD, or
|
||
old FreeBSD, Tor is probably forking separate processes
|
||
rather than using threads. Consider switching to a <a
|
||
href="<wikifaq>#WhydoesntmyWindowsorotherOSTorrelayrunwell">better
|
||
operating system</a>.</li>
|
||
-->
|
||
<li>If you still can't handle the memory load, consider reducing the
|
||
amount of bandwidth your relay advertises. Advertising less
|
||
bandwidth
|
||
means you will attract fewer users, so your relay shouldn't grow
|
||
as large. See the <tt>MaxAdvertisedBandwidth</tt> option in the man
|
||
page.</li>
|
||
|
||
</ol>
|
||
|
||
<p>
|
||
All of this said, fast Tor relays do use a lot of ram. It is not
|
||
unusual
|
||
for a fast exit relay to use 500-1000 MB of memory.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="BetterAnonymity"></a>
|
||
<h3><a class="anchor" href="#BetterAnonymity">Do I get better anonymity
|
||
if I run a relay?</a></h3>
|
||
|
||
<p>
|
||
Yes, you do get better anonymity against some attacks.
|
||
</p>
|
||
<p>
|
||
The simplest example is an attacker who owns a small number of Tor relays.
|
||
He will see a connection from you, but he won't be able to know whether
|
||
the connection originated at your computer or was relayed from somebody else.
|
||
</p>
|
||
<p>
|
||
There are some cases where it doesn't seem to help: if an attacker can
|
||
watch all of your incoming and outgoing traffic, then it's easy for him
|
||
to learn which connections were relayed and which started at you. (In
|
||
this case he still doesn't know your destinations unless he is watching
|
||
them too, but you're no better off than if you were an ordinary client.)
|
||
</p>
|
||
<p>
|
||
There are also some downsides to running a Tor relay. First, while we
|
||
only have a few hundred relays, the fact that you're running one might
|
||
signal to an attacker that you place a high value on your anonymity.
|
||
Second, there are some more esoteric attacks that are not as
|
||
well-understood or well-tested that involve making use of the knowledge
|
||
that you're running a relay -- for example, an attacker may be able to
|
||
"observe" whether you're sending traffic even if he can't actually watch
|
||
your network, by relaying traffic through your Tor relay and noticing
|
||
changes in traffic timing.
|
||
</p>
|
||
<p>
|
||
It is an open research question whether the benefits outweigh the risks.
|
||
A lot of that depends on the attacks you are most worried about. For
|
||
most users, we think it's a smart move.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="RelayDonations"></a>
|
||
<h3><a class="anchor" href="#RelayDonations">Can I donate for a
|
||
relay rather than run my own?</a></h3>
|
||
|
||
<p>
|
||
Sure! We recommend these non-profit charities that are happy to turn
|
||
your donations into better speed and anonymity for the Tor network:
|
||
</p>
|
||
<ul>
|
||
<li><a href="https://www.torservers.net/">torservers.net</a>
|
||
is a German charitable non-profit that runs a wide variety of
|
||
exit relays worldwide. They also like donations of bandwidth from
|
||
ISPs.</li>
|
||
<li><a
|
||
href="https://www.noisebridge.net/wiki/Noisebridge_Tor">Noisebridge</a>
|
||
is a US-based 501(c)(3) non-profit that collects donations and turns
|
||
them into more US-based exit relay capacity.</li>
|
||
<li><a href="https://nos-oignons.net/">Nos Oignons</a> is a French
|
||
charitable non-profit that runs fast exit relays in France.</li>
|
||
</ul>
|
||
|
||
<p>
|
||
These organizations are not the same as <a href="<page
|
||
donate/donate>">The Tor Project, Inc</a>, but we consider that a
|
||
good thing. They're both run by nice people who are part of the
|
||
Tor community.
|
||
</p>
|
||
|
||
<p>
|
||
Note that there can be a tradeoff here between anonymity and
|
||
performance. The Tor network's anonymity comes in part from
|
||
diversity,
|
||
so if you are in a position to run your own relay, you will be
|
||
improving Tor's anonymity more than by donating. At the same time
|
||
though, economies
|
||
of scale for bandwidth mean that combining many small donations into
|
||
several larger relays is more efficient at improving network
|
||
performance. Improving anonymity and improving performance are both
|
||
worthwhile goals, so however you can help is great!
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="AccessHiddenServices"></a>
|
||
<h3><a class="anchor" href="#AccessHiddenServices">How do I access
|
||
hidden services?</a></h3>
|
||
|
||
<p>
|
||
Tor hidden services are named with a special top-level domain (TLD)
|
||
name in DNS: .onion. Since the .onion TLD is not recognized by the
|
||
official root DNS servers on the Internet, your application will not
|
||
get the response it needs to locate the service. Currently, the Tor
|
||
directory server provides this look-up service; and thus the look-up
|
||
request must get to the Tor network.
|
||
</p>
|
||
|
||
<p>
|
||
Therefore, your application <b>needs</b> to pass the .onion hostname to
|
||
Tor directly. You can't try to resolve it to an IP address, since there
|
||
<i>is</i> no corresponding IP address: the server is hidden, after all!
|
||
</p>
|
||
|
||
<p>
|
||
So, how do you make your application pass the hostname directly to Tor?
|
||
You can't use SOCKS 4, since SOCKS 4 proxies require an IP from the
|
||
client (a web browser is an example of a SOCKS client). Even though
|
||
SOCKS 5 can accept either an IP or a hostname, most applications
|
||
supporting SOCKS 5 try to resolve the name before passing it to the
|
||
SOCKS proxy. SOCKS 4a, however, always accepts a hostname: You'll need
|
||
to use SOCKS 4a.
|
||
</p>
|
||
|
||
<p>
|
||
Some applications, such as the browsers Mozilla Firefox and Apple's
|
||
Safari, support sending DNS queries to Tor's SOCKS 5 proxy. Most web
|
||
browsers don't support SOCKS 4a very well, though. The workaround is
|
||
to point your web browser at an HTTP proxy, and tell the HTTP proxy
|
||
to speak to Tor with SOCKS 4a. We recommend Polipo as your HTTP proxy.
|
||
</p>
|
||
|
||
<p>
|
||
For applications that do not support HTTP proxy, and so cannot use
|
||
Polipo, <a href="http://www.freecap.ru/eng/">FreeCap</a> is an
|
||
alternative. When using FreeCap set proxy protocol to SOCKS 5 and under
|
||
settings set DNS name resolving to remote. This
|
||
will allow you to use almost any program with Tor without leaking DNS
|
||
lookups and allow those same programs to access hidden services.
|
||
</p>
|
||
|
||
<p>
|
||
See also the <a href="#SocksAndDNS">question on DNS</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ProvideAHiddenService"></a>
|
||
<h3><a class="anchor" href="#ProvideAHiddenService">How do I provide a
|
||
hidden service?</a></h3>
|
||
|
||
<p>
|
||
See the <a href="https://www.torproject.org/docs/tor-hidden-service.html.en">
|
||
official hidden service configuration instructions</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhoIsResponsible"></a>
|
||
<h3><a class="anchor" href="#WhoIsResponsible">Who is responsible
|
||
for Tor?</a></h3>
|
||
|
||
<p>
|
||
<a href="http://www.freehaven.net/~arma/cv.html">Roger Dingledine</a> and
|
||
<a href="http://www.wangafu.net/~nickm/">Nick Mathewson</a> are the main
|
||
developers of Tor. You can read more at
|
||
<a href="https://www.torproject.org/about/corepeople">Tor's People
|
||
page</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="VersionNumbers"></a>
|
||
<h3><a class="anchor" href="#VersionNumbers">What do these weird
|
||
version numbers mean?</a></h3>
|
||
|
||
<p>
|
||
Versions of Tor before 0.1.0 used a strange and hard-to-explain version scheme. Let's forget about those.
|
||
</p>
|
||
<p>
|
||
Starting with 0.1.0, versions all look like this:
|
||
MAJOR.MINOR.MICRO(.PATCHLEVEL)(-TAG). The stuff in parenthesis is
|
||
optional. MAJOR, MINOR, MICRO, and PATCHLEVEL are all numbers. Only one
|
||
release is ever made with any given set of these version numbers. The
|
||
TAG lets you know how stable we think the release is: "alpha" is pretty
|
||
unstable; "rc" is a release candidate; and no tag at all means that we
|
||
have a final release. If the tag ends with "-cvs", you're looking at
|
||
a development snapshot that came after a given release.
|
||
</p>
|
||
<p>
|
||
So for example, we might start a development branch with (say)
|
||
0.1.1.1-alpha. The patchlevel increments consistently as the status
|
||
tag changes, for example, as in: 0.1.1.2-alpha, 0.1.1.3-alpha,
|
||
0.1.1.4-rc, 0.1.1.5-rc, etc. Eventually, we would release 0.1.1.6.
|
||
The next stable release would be 0.1.1.7.
|
||
</p>
|
||
<p>
|
||
Why do we do it like this? Because every release has a unique
|
||
version number, it is easy for tools like package manager to tell
|
||
which release is newer than another. The tag makes it easy for users
|
||
to tell how stable the release is likely to be.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="PrivateTorNetwork"></a>
|
||
<h3><a class="anchor" href="#PrivateTorNetwork">How do I set up my
|
||
own private Tor network?</a></h3>
|
||
|
||
<p>
|
||
If you want to experiment locally with your own network, or you're
|
||
cut off from the Internet and want to be able to mess with Tor still,
|
||
then you may want to set up your own separate Tor network.
|
||
</p>
|
||
<p>
|
||
To set up your own Tor network, you need to run your own authoritative
|
||
directory servers, and your clients and relays must be configured so
|
||
they know about your directory servers rather than the default public
|
||
ones.
|
||
</p>
|
||
<p>
|
||
Apart from the somewhat tedious method of manually configuring a couple
|
||
of directory authorities, relays and clients there are two separate
|
||
tools that could help. One is Chutney, the other is Shadow.
|
||
</p>
|
||
<p>
|
||
<a href="https://gitweb.torproject.org/chutney.git">Chutney</a> is a
|
||
tool for configuring, controlling and running tests on a
|
||
testing Tor network. It requires that you have Tor and Python (2.5 or
|
||
later) installed on your system. You can use Chutney to create a testing
|
||
network by generating Tor configuration files (torrc) and necssary keys
|
||
(for the directory authorities). Then you can let Chutney start your Tor
|
||
authorities, relays and clients and wait for the network to bootstrap.
|
||
Finally, you can have Chutney run tests on your network to see which
|
||
things work and which do not. Chutney is typically used for running a
|
||
testing network with about 10 instances of Tor. Every instance of Tor
|
||
binds to one or two ports on localhost (127.0.0.1) and all Tor
|
||
communication is done over the loopback interface. The <a
|
||
href="https://gitweb.torproject.org/chutney.git/blob/HEAD:/README">Chutney
|
||
README</a> is a good starting point for getting it up and running.
|
||
</p>
|
||
<p>
|
||
<a href="https://github.com/shadow/shadow">Shadow</a> is a network
|
||
simulator that can run Tor through its Scallion plug-in. Although
|
||
it's typically used for running load and performance tests on
|
||
substantially larger Tor test networks than what's feasible with
|
||
Chutney, it also makes for an excellent debugging tool since you can
|
||
run completely deterministic experiments. A large Shadow network is on
|
||
the size of thousands of instances of Tor, and you can run experiments
|
||
out of the box using one of Shadow's several included scallion experiment
|
||
configurations. Shadow can be run on any linux machine without root,
|
||
and can also run on EC2 using a pre-configured image. Also, Shadow
|
||
controls the time of the simulation with the effect that
|
||
time-consuming tests can be done more efficiently than in an
|
||
ordinary testing network. The <a
|
||
href="https://github.com/shadow/shadow/wiki">Shadow wiki</a> and
|
||
<a href="http://shadow.github.io/">Shadow website</a> are
|
||
good places to get started.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="UseTorWithJava"></a>
|
||
<h3><a class="anchor" href="#UseTorWithJava">How can I make my Java
|
||
program use the Tor Network?</a></h3>
|
||
|
||
<p>
|
||
The newest versions of Java now have SOCKS4/5 support built in.
|
||
Unfortunately, the SOCKS interface is not very well documented and
|
||
may still leak your DNS lookups. The safest way to use Tor is to
|
||
interface the SOCKS protocol directly or go through an application-level
|
||
proxy that speaks SOCKS4a. For an example and libraries that implement
|
||
the SOCKS4a connection, go to Joe Foley's TorLib in the <a
|
||
href="http://web.mit.edu/foley/www/TinFoil/">TinFoil Project</a>.
|
||
</p>
|
||
|
||
<p>
|
||
A fully Java implementation of the Tor client is now available as <a
|
||
href="http://www.subgraph.com/orchid.html">Orchid</a>. We still consider
|
||
Orchid to be experimental, so use with care.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
|
||
<a id="WhatIsLibevent"></a>
|
||
<h3><a class="anchor" href="#WhatIsLibevent">What is Libevent?</a></h3>
|
||
|
||
<p>
|
||
When you want to deal with a bunch of net connections at once, you
|
||
have a few options:
|
||
</p>
|
||
<p>
|
||
One is multithreading: you have a separate micro-program inside the
|
||
main program for each net connection that reads and writes to the
|
||
connection as needed.This, performance-wise, sucks.
|
||
</p>
|
||
<p>
|
||
Another is asynchronous network programming: you have a single main
|
||
program that finds out when various net connections are ready to
|
||
read/write, and acts accordingly.
|
||
</p>
|
||
<p>
|
||
The problem is that the oldest ways to find out when net connections
|
||
are ready to read/write, suck. And the newest ways are finally fast,
|
||
but are not available on all platforms.
|
||
</p>
|
||
<p>
|
||
This is where Libevent comes in and wraps all these ways to find
|
||
out whether net connections are ready to read/write, so that Tor
|
||
(and other programs) can use the fastest one that your platform
|
||
supports, but can still work on older platforms (these methods are
|
||
all different depending on the platorm) So Libevent presents a
|
||
consistent and fast interface to select, poll, kqueue, epoll,
|
||
/dev/poll, and windows select.
|
||
</p>
|
||
<p>
|
||
However, On the the Win32 platform (by Microsoft) the only good
|
||
way to do fast IO on windows with hundreds of sockets is using
|
||
overlapped IO, which is grossly unlike every other BSD sockets
|
||
interface.
|
||
</p>
|
||
<p>Libevent has <a href="http://www.monkey.org/~provos/libevent/">its
|
||
own website</a>.
|
||
</p>
|
||
<hr>
|
||
|
||
<a id="MyNewFeature"></a>
|
||
<h3><a class="anchor" href="#MyNewFeature">What do I need to do to get
|
||
a new feature into Tor?</a></h3>
|
||
|
||
<p>
|
||
For a new feature to go into Tor, it needs to be designed (explain what
|
||
you think Tor should do), argued to be secure (explain why it's better
|
||
or at least as good as what Tor does now), specified (explained at the
|
||
byte level at approximately the level of detail in tor-spec.txt), and
|
||
implemented (done in software).
|
||
</p>
|
||
|
||
<p>
|
||
You probably shouldn't count on other people doing all of these steps
|
||
for you: people who are skilled enough to do this stuff generally
|
||
have their own favorite feature requests.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="WhatProtectionsDoesTorProvide"></a>
|
||
<h3><a class="anchor" href="#WhatProtectionsDoesTorProvide">What
|
||
protections does Tor provide?</a></h3>
|
||
|
||
<p>
|
||
Internet communication is based on a store-and-forward model that
|
||
can be understood in analogy to postal mail: Data is transmitted in
|
||
blocks called IP datagrams or packets. Every packet includes a source
|
||
IP address (of the sender) and a destination IP address (of the
|
||
receiver), just as ordinary letters contain postal addresses of sender
|
||
and receiver. The way from sender to receiver involves multiple hops of
|
||
routers, where each router inspects the destination IP address and
|
||
forwards the packet closer to its destination. Thus, every router
|
||
between sender and receiver learns that the sender is communicating
|
||
with the receiver. In particular, your local ISP is in the position to
|
||
build a complete profile of your Internet usage. In addition, every
|
||
server in the Internet that can see any of the packets can profile your
|
||
behaviour.
|
||
</p>
|
||
|
||
<p>
|
||
The aim of Tor is to improve your privacy by sending your traffic through
|
||
a series of proxies. Your communication is encrypted in multiple layers
|
||
and routed via multiple hops through the Tor network to the final
|
||
receiver. More details on this process can be found in the <a
|
||
href="https://www.torproject.org/about/overview">Tor overview</a>.
|
||
Note that all your local ISP can observe now is that you are
|
||
communicating with Tor nodes. Similarly, servers in the Internet just
|
||
see that they are being contacted by Tor nodes.
|
||
</p>
|
||
|
||
<p>
|
||
Generally speaking, Tor aims to solve three privacy problems:
|
||
</p>
|
||
|
||
<p>
|
||
First, Tor prevents websites and other services from learning
|
||
your location, which they can use to build databases about your
|
||
habits and interests. With Tor, your Internet connections don't
|
||
give you away by default -- now you can have the ability to choose,
|
||
for each connection, how much information to reveal.
|
||
</p>
|
||
|
||
<p>
|
||
Second, Tor prevents people watching your traffic locally (such as
|
||
your ISP) from learning what information you're fetching and where
|
||
you're fetching it from. It also stops them from deciding what you're
|
||
allowed to learn and publish -- if you can get to any part of the Tor
|
||
network, you can reach any site on the Internet.
|
||
</p>
|
||
|
||
<p>
|
||
Third, Tor routes your connection through more than one Tor relay
|
||
so no single relay can learn what you're up to. Because these relays
|
||
are run by different individuals or organizations, distributing trust
|
||
provides more security than the old <a href="#Torisdifferent">one hop proxy
|
||
</a> approach.
|
||
</p>
|
||
|
||
<p>
|
||
Note, however, that there are situations where Tor fails to solve these
|
||
privacy problems entirely: see the entry below on <a
|
||
href="#AttacksOnOnionRouting">remaining attacks</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="CanExitNodesEavesdrop"></a>
|
||
<h3><a class="anchor" href="#CanExitNodesEavesdrop">Can exit nodes eavesdrop
|
||
on communications? Isn't that bad?</a></h3>
|
||
|
||
<p>
|
||
Yes, the guy running the exit node can read the bytes that come in and
|
||
out there. Tor anonymizes the origin of your traffic, and it makes sure
|
||
to encrypt everything inside the Tor network, but it does not magically
|
||
encrypt all traffic throughout the Internet.
|
||
</p>
|
||
|
||
<p>
|
||
This is why you should always use end-to-end encryption such as SSL for
|
||
sensitive Internet connections. (The corollary to this answer is that if
|
||
you are worried about somebody intercepting your traffic and you're
|
||
*not* using end-to-end encryption at the application layer, then something
|
||
has already gone wrong and you shouldn't be thinking that Tor is the problem.)
|
||
</p>
|
||
|
||
<p>
|
||
Tor does provide a partial solution in a very specific situation, though.
|
||
When you make a connection to a destination that also runs a Tor relay,
|
||
Tor will automatically extend your circuit so you exit from that circuit.
|
||
So for example if Indymedia ran a Tor relay on the same IP address as
|
||
their website, people using Tor to get to the Indymedia website would
|
||
automatically exit from their Tor relay, thus getting *better* encryption
|
||
and authentication properties than just browsing there the normal way.
|
||
</p>
|
||
|
||
<p>
|
||
We'd like to make it still work even if the service is nearby the Tor
|
||
relay but not on the same IP address. But there are a variety of
|
||
technical problems we need to overcome first (the main one being "how
|
||
does the Tor client learn which relays are associated with which
|
||
websites in a decentralized yet non-gamable way?").
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="AmITotallyAnonymous"></a>
|
||
<h3><a class="anchor" href="#AmITotallyAnonymous">So I'm totally anonymous
|
||
if I use Tor?</a></h3>
|
||
|
||
<p>
|
||
<b>No.</b>
|
||
</p>
|
||
<p>
|
||
First, Tor protects the network communications. It separates where you
|
||
are from where you are going on the Internet. What content and data you
|
||
transmit over Tor is controlled by you. If you login to Google or
|
||
Facebook via Tor, the local ISP or network provider doesn't know you
|
||
are visiting Google or Facebook. Google and Facebook don't know where
|
||
you are in the world. However, since you have logged into their sites,
|
||
they know who you are. If you don't want to share information, you are
|
||
in control.
|
||
</p>
|
||
|
||
<p>
|
||
Second, active content, such as Java, Javascript, Adobe Flash, Adobe
|
||
Shockwave, QuickTime, RealAudio, ActiveX controls, and VBScript, are
|
||
binary applications. These binary applications run as your user account
|
||
with your permissions in your operating system. This means these
|
||
applications can access anything that your user account can access. Some
|
||
of these technologies, such as Java and Adobe Flash for instance, run in
|
||
what is known as a virtual machine. This virtual machine may have the
|
||
ability to ignore your configured proxy settings, and therefore bypass
|
||
Tor and share information directly to other sites on the Internet. The
|
||
virtual machine may be able to store data, such as cookies, completely
|
||
separate from your browser or operating system data stores. Therefore,
|
||
these technologies must be disabled in your browser to use Tor safely.
|
||
</p>
|
||
<p>
|
||
That's where the <a
|
||
href="https://torproject.org/projects/torbrowser.html.en">Tor Browser
|
||
Bundle</a> comes in. We produce a web browser that is preconfigured to
|
||
help you control the risks to your privacy and anonymity while browsing
|
||
the Internet. Not only are the above technologies disabled to prevent
|
||
identity leaks, the Tor Browser also includes browser extensions like
|
||
NoScript and Torbutton, as well as patches to the Firefox source
|
||
code. The full design of the Tor Browser can be read <a
|
||
href="https://www.torproject.org/projects/torbrowser/design/">here</a>.
|
||
In designing a safe, secure solution for browsing the web with Tor,
|
||
we've discovered that configuring <a href="#TBBOtherBrowser">other
|
||
browsers</a> to use Tor is unsafe.
|
||
</p>
|
||
|
||
<p>
|
||
Alternatively, you may find a Live CD or USB operating system more to
|
||
your liking. The Tails team has created an <a
|
||
href="https://tails.boum.org/">entire bootable operating system</a>
|
||
configured for anonymity and privacy on the Internet.
|
||
</p>
|
||
|
||
<p>
|
||
Tor is a work in progress. There is still <a
|
||
href="https://www.torproject.org/getinvolved/volunteer">plenty of work
|
||
left to do</a> for a strong, secure, and complete solution.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ExitEnclaving"></a>
|
||
<h3><a class="anchor" href="#ExitEnclaving">What is Exit Enclaving?</a>
|
||
</h3>
|
||
|
||
<p>
|
||
When a machine that runs a Tor relay also runs a public service, such as
|
||
a webserver, you can configure Tor to offer Exit Enclaving to that
|
||
service. Running an Exit Enclave for all of your services you wish to
|
||
be accessible via Tor provides your users the assurance that they will
|
||
exit through your server, rather than exiting from a randomly selected
|
||
exit node that could be watched. Normally, a tor circuit would end at
|
||
an exit node and then that node would make a connection to your service.
|
||
Anyone watching that exit node could see the connection to your service,
|
||
and be able to snoop on the contents if it were an unencrypted
|
||
connection. If you run an Exit Enclave for your service, then the exit
|
||
from the Tor network happens on the machine that runs your service,
|
||
rather than on an untrusted random node. This works when Tor clients
|
||
wishing to connect to this public service extend their their circuit
|
||
to exit from the Tor relay running on that same host. For example, if
|
||
the server at 1.2.3.4 runs a web server on port 80 and also acts as a
|
||
Tor relay configured for Exit Enclaving, then Tor clients wishing to
|
||
connect to the webserver will extend their circuit a fourth hop to exit
|
||
to port 80 on the Tor relay running on 1.2.3.4.
|
||
</p>
|
||
<p>
|
||
Exit Enclaving is disabled by default to prevent attackers from
|
||
exploiting trust relationships with locally bound services. For
|
||
example, often 127.0.0.1 will run services that are not designed to
|
||
be shared with the entire world. Sometimes these services will also
|
||
be bound to the public IP address, but will only allow connections if
|
||
the source address is something trusted, such as 127.0.0.1.
|
||
</p>
|
||
<p>
|
||
As a result of possible trust issues, relay operators must configure
|
||
their exit policy to allow connections to themselves, but they should
|
||
do so only when they are certain that this is a feature that they would
|
||
like. Once certain, turning off the ExitPolicyRejectPrivate option will
|
||
enable Exit Enclaving. An example configuration would be as follows:
|
||
</p>
|
||
<pre>
|
||
ExitPolicy accept 1.2.3.4:80
|
||
ExitPolicy reject 127.0.0.1/8
|
||
ExitPolicyRejectPrivate 0
|
||
</pre>
|
||
<p>
|
||
This option should be used with care as it may expose internal network
|
||
blocks that are not meant to be accessible from the outside world or
|
||
the Tor network. Please tailor your ExitPolicy to reflect all netblocks
|
||
that you want to prohibit access.
|
||
</p>
|
||
<p>
|
||
This option should be used with care as it may expose internal network
|
||
blocks that are not meant to be accessible from the outside world or
|
||
the Tor network. Please tailor your ExitPolicy to reflect all netblocks
|
||
that you want to prohibit access.
|
||
</p>
|
||
<p>
|
||
While useful, this behavior may go away in the future because it is
|
||
imperfect. A great idea but not such a great implementation.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="KeyManagement"></a>
|
||
<h3><a class="anchor" href="#KeyManagement">Tell me about all the
|
||
keys Tor uses.</a></h3>
|
||
|
||
<p>
|
||
Tor uses a variety of different keys, with three goals in mind: 1)
|
||
encryption to ensure privacy of data within the Tor network, 2)
|
||
authentication so clients know they're
|
||
talking to the relays they meant to talk to, and 3) signatures to
|
||
make
|
||
sure all clients know the same set of relays.
|
||
</p>
|
||
|
||
<p>
|
||
<b>Encryption</b>: first, all connections in Tor use TLS link
|
||
encryption,
|
||
so observers can't look inside to see which circuit a given cell is
|
||
intended for. Further, the Tor client establishes an ephemeral
|
||
encryption
|
||
key with each relay in the circuit; these extra layers of encryption
|
||
mean that only the exit relay can read
|
||
the cells. Both sides discard the circuit key when the circuit ends,
|
||
so logging traffic and then breaking into the relay to discover the
|
||
key won't work.
|
||
</p>
|
||
|
||
<p>
|
||
<b>Authentication</b>:
|
||
Every Tor relay has a public decryption key called the "onion key".
|
||
Each relay rotates its onion key once a week.
|
||
When the Tor client establishes circuits, at each step it <a
|
||
|
||
href="<svnprojects>design-paper/tor-design.html#subsec:circuits">demands
|
||
that the Tor relay prove knowledge of its onion key</a>. That way
|
||
the first node in the path can't just spoof the rest of the path.
|
||
Because the Tor client chooses the path, it can make sure to get
|
||
Tor's "distributed trust" property: no single relay in the path can
|
||
know about both the client and what the client is doing.
|
||
</p>
|
||
|
||
<p>
|
||
<b>Coordination</b>:
|
||
How do clients know what the relays are, and how do they know that
|
||
they
|
||
have the right keys for them? Each relay has a long-term public
|
||
signing
|
||
key called the "identity key". Each directory authority additionally
|
||
has a
|
||
"directory signing key". The directory authorities <a
|
||
href="<specblob>dir-spec.txt">provide a signed list</a>
|
||
of all the known relays, and in that list are a set of certificates
|
||
from
|
||
each relay (self-signed by their identity key) specifying their
|
||
keys,
|
||
locations, exit policies, and so on. So unless the adversary can
|
||
control
|
||
a majority of the directory authorities (as of 2012 there are 8
|
||
directory authorities), he can't trick the Tor client into using
|
||
other Tor relays.
|
||
</p>
|
||
|
||
<p>
|
||
How do clients know what the directory authorities are? The Tor
|
||
software
|
||
comes with a built-in list of location and public key for each
|
||
directory
|
||
authority. So the only way to trick users into using a fake Tor
|
||
network
|
||
is to give them a specially modified version of the software.
|
||
</p>
|
||
|
||
<p>
|
||
How do users know they've got the right software? When we distribute
|
||
the source code or a package, we digitally sign it with <a
|
||
href="http://www.gnupg.org/">GNU Privacy Guard</a>. See the <a
|
||
href="<page docs/verifying-signatures>">instructions
|
||
on how to check Tor's signatures</a>.
|
||
</p>
|
||
|
||
<p>
|
||
In order to be certain that it's really signed by us, you need to
|
||
have
|
||
met us in person and gotten a copy of our GPG key fingerprint, or
|
||
you
|
||
need to know somebody who has. If you're concerned about an attack
|
||
on
|
||
this level, we recommend you get involved with the security
|
||
community
|
||
and start meeting people.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="EntryGuards"></a>
|
||
<h3><a class="anchor" href="#EntryGuards">What are Entry
|
||
Guards?</a></h3>
|
||
|
||
<p>
|
||
Tor (like all current practical low-latency anonymity designs) fails
|
||
when the attacker can see both ends of the communications channel. For
|
||
example, suppose the attacker controls or watches the Tor relay you
|
||
choose
|
||
to enter the network, and also controls or watches the website you
|
||
visit. In
|
||
this case, the research community knows no practical low-latency design
|
||
that can reliably stop the attacker from correlating volume and timing
|
||
information on the two sides.
|
||
</p>
|
||
|
||
<p>
|
||
So, what should we do? Suppose the attacker controls, or can observe,
|
||
<i>C</i> relays. Suppose there are <i>N</i> relays total. If you select
|
||
new entry and exit relays each time you use the network, the attacker
|
||
will be able to correlate all traffic you send with probability
|
||
<i>(c/n)<sup>2</sup></i>. But profiling is, for most users, as bad
|
||
as being traced all the time: they want to do something often without
|
||
an attacker noticing, and the attacker noticing once is as bad as the
|
||
attacker noticing more often. Thus, choosing many random entries and
|
||
exits
|
||
gives the user no chance of escaping profiling by this kind of attacker.
|
||
</p>
|
||
|
||
<p>
|
||
The solution is "entry guards": each Tor client selects a few relays at
|
||
random
|
||
to use as entry points, and uses only those relays for her first hop. If
|
||
those relays are not controlled or observed, the attacker can't win,
|
||
ever, and the user is secure. If those relays <i>are</i> observed or
|
||
controlled by the attacker, the attacker sees a larger <i>fraction</i>
|
||
of the user's traffic — but still the user is no more profiled
|
||
than
|
||
before. Thus, the user has some chance (on the order of <i>(n-c)/n</i>)
|
||
of avoiding profiling, whereas she had none before.
|
||
</p>
|
||
|
||
<p>
|
||
You can read more at <a href="http://freehaven.net/anonbib/#wright02">An
|
||
Analysis of the Degradation of Anonymous Protocols</a>, <a
|
||
href="http://freehaven.net/anonbib/#wright03">Defending Anonymous
|
||
Communication Against Passive Logging Attacks</a>, and especially
|
||
<a href="http://freehaven.net/anonbib/#hs-attack06">Locating Hidden
|
||
Servers</a>.
|
||
</p>
|
||
|
||
<p>
|
||
Restricting your entry nodes may also help against attackers who want
|
||
to run a few Tor nodes and easily enumerate all of the Tor user IP
|
||
addresses. (Even though they can't learn what destinations the users
|
||
are talking to, they still might be able to do bad things with just a
|
||
list of users.) However, that feature won't really become useful until
|
||
we move to a "directory guard" design as well.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="ChangePaths"></a>
|
||
<h3><a class="anchor" href="#ChangePaths">How often does Tor change its paths?</a></h3>
|
||
<p>
|
||
Tor will reuse the same circuit for new TCP streams for 10 minutes,
|
||
as long as the circuit is working fine. (If the circuit fails, Tor
|
||
will switch to a new circuit immediately.)
|
||
</p>
|
||
<p>
|
||
But note that a single TCP stream (e.g. a long IRC connection) will stay on
|
||
the same circuit forever -- we don't rotate individual streams from one
|
||
circuit to the next. Otherwise an adversary with a partial view of the
|
||
network would be given many chances over time to link you to your
|
||
destination, rather than just one chance.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="CellSize"></a>
|
||
<h3><a class="anchor" href="#CellSize">Tor uses hundreds of bytes for
|
||
every IRC line. I can't afford that!</a></h3>
|
||
<p>
|
||
Tor sends data in chunks of 512 bytes (called "cells"), to make it
|
||
harder for intermediaries to guess exactly how many bytes you're
|
||
communicating at each step. This is unlikely to change in the near
|
||
future -- if this increased bandwidth use is prohibitive for you, I'm
|
||
afraid Tor is not useful for you right now.
|
||
</p>
|
||
<p>
|
||
The actual content of these fixed size cells is
|
||
<a href="https://gitweb.torproject.org/torspec.git/blob/HEAD:/tor-spec.txt">
|
||
documented in the main Tor spec</a>, section 3.
|
||
</p>
|
||
<p>
|
||
We have been considering one day adding two classes of cells -- maybe a 64
|
||
byte cell and a 1024 byte cell. This would allow less overhead for
|
||
interactive streams while still allowing good throughput for bulk streams.
|
||
But since we want to do a lot of work on quality-of-service and better
|
||
queuing approaches first, you shouldn't expect this change anytime soon
|
||
(if ever). However if you are keen, there are a couple of
|
||
<a href="https://www.torproject.org/getinvolved/volunteer.html.en#Research">
|
||
research ideas</a> that may involve changing the cell size.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="OutboundConnections"></a>
|
||
<h3><a class="anchor" href="#OutboundConnections">Why does netstat show
|
||
these outbound connections?</a></h3>
|
||
<p>
|
||
Because that's how Tor works. It holds open a handful of connections
|
||
so there will be one available when you need one.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="PowerfulBlockers"></a>
|
||
<h3><a class="anchor" href="#PowerfulBlockers">What about powerful blocking
|
||
mechanisms?</a></h3>
|
||
<p>
|
||
An adversary with a great deal of manpower and money, and severe
|
||
real-world penalties to discourage people from trying to evade detection,
|
||
is a difficult test for an anonymity and anti-censorship system.
|
||
</p>
|
||
<p>
|
||
The original Tor design was easy to block if the attacker controls Alice's
|
||
connection to the Tor network --- by blocking the directory authorities, by
|
||
blocking all the relay IP addresses in the directory, or by filtering based
|
||
on the fingerprint of the Tor TLS handshake. After seeing these attacks and
|
||
others first-hand, more effort was put into researching new circumvention
|
||
techniques. Pluggable transports are protocols designed to allow users behind
|
||
government firewalls to access the Tor network.
|
||
</p>
|
||
<p>
|
||
We've made quite a bit of progress on this problem lately. You can read more
|
||
details on the <a href="https://www.torproject.org/docs/pluggable-transports.html.en">
|
||
pluggable transports page</a>. You may also be interested in
|
||
<a href="https://www.youtube.com/watch?v=GwMr8Xl7JMQ">Roger and Jake's talk at
|
||
28C3</a>, or <a href="https://www.youtube.com/watch?v=JZg1nqs793M">Runa's
|
||
talk at 44con</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="RemotePhysicalDeviceFingerprinting"></a>
|
||
<h3><a class="anchor" href="#RemotePhysicalDeviceFingerprinting">Does Tor
|
||
resist "remote physical device fingerprinting"?</a></h3>
|
||
<p>
|
||
Yes, we resist all of these attacks as far as we know.
|
||
</p>
|
||
<p>
|
||
These attacks come from examining characteristics of the IP headers or TCP
|
||
headers and looking for information leaks based on individual hardware
|
||
signatures. One example is the
|
||
<a href="http://www.caida.org/outreach/papers/2005/fingerprinting/">
|
||
Oakland 2005 paper</a> that lets you learn if two packet streams originated
|
||
from the same hardware, but only if you can see the original TCP timestamps.
|
||
</p>
|
||
<p>
|
||
Tor transports TCP streams, not IP packets, so we end up automatically
|
||
scrubbing a lot of the potential information leaks. Because Tor relays use
|
||
their own (new) IP and TCP headers at each hop, this information isn't
|
||
relayed from hop to hop. Of course, this also means that we're limited in
|
||
the protocols we can transport (only correctly-formed TCP, not all IP like
|
||
ZKS's Freedom network could) -- but maybe that's a good thing at this stage.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="VPN"></a>
|
||
<h3><a class="anchor" href="#VPN">What's safer, Tor or a VPN?</a></h3>
|
||
|
||
<p>
|
||
Some people use Virtual Private Networks (VPNs) as a privacy solution.
|
||
VPNs encrypt the traffic between the user and the VPN provider,
|
||
and they can act as a proxy between a user and an online destination.
|
||
However, VPNs have a single point of failure: the VPN provider.
|
||
A technically proficient attacker or a number of employees could
|
||
retrieve the full identity information associated with a VPN user.
|
||
It is also possible to use coercion or other means to convince a
|
||
VPN provider to reveal their users' identities. Identities can be
|
||
discovered by following a money trail (using Bitcoin does not solve
|
||
this problem because Bitcoin is not anonymous), or by persuading the
|
||
VPN provider to hand over logs. Even
|
||
if a VPN provider says they don't keep logs, users have to take their
|
||
word for it---and trust that the VPN provider won't buckle to outside
|
||
pressures that might want them to start keeping logs.
|
||
</p>
|
||
|
||
<p>
|
||
When you use a VPN, websites can still build up a persistent profile of
|
||
your usage over time. Even though sites you visit won't automatically
|
||
get your originating IP address, they still know how to profile you
|
||
based on your browsing history.
|
||
</p>
|
||
|
||
<p>
|
||
When you use Tor the IP address you connect to changes at most every 10
|
||
minutes, and often more frequently than that. This makes it extremely
|
||
dificult for websites to create any sort of persistent profile of Tor
|
||
users (assuming you did not <a
|
||
href="https://torproject.org/download/download.html.en#warning">identify
|
||
yourself in other ways</a>). No one Tor relay can know enough
|
||
information to compromise any Tor user because of Tor's <a
|
||
href="https://www.torproject.org/about/overview.html.en#thesolution">encrypted
|
||
three-hop circuit</a> design.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Proxychains"></a>
|
||
<h3><a class="anchor" href="#Proxychains">Aren't 10 proxies
|
||
(proxychains) better than Tor with only 3 hops?</a></h3>
|
||
|
||
<p>
|
||
Proxychains is a program that sends your traffic through a series of
|
||
open web proxies that you supply before sending it on to your final
|
||
destination. <a href="#KeyManagement">Unlike Tor</a>, proxychains
|
||
does not encrypt the connections between each proxy server. An open proxy
|
||
that wanted to monitor your connection could see all the other proxy
|
||
servers you wanted to use between itself and your final destination,
|
||
as well as the IP address that proxy hop received traffic from.
|
||
</p>
|
||
<p>
|
||
Because the <a
|
||
href="https://gitweb.torproject.org/torspec.git?a=blob_plain;hb=HEAD;f=tor-spec.txt">
|
||
Tor protocol</a> requires encrypted relay-to-relay connections, not
|
||
even a misbehaving relay can see the entire path of any Tor user.
|
||
</p>
|
||
<p>
|
||
While Tor relays are run by volunteers and checked periodically for
|
||
suspicious behavior, many open proxies that can be found with a search
|
||
engine are compromised machines, misconfigured private proxies
|
||
not intended for public use, or honeypots set up to exploit users.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
|
||
<a id="AttacksOnOnionRouting"></a>
|
||
<h3><a class="anchor" href="#AttacksOnOnionRouting">What attacks remain
|
||
against onion routing?</a></h3>
|
||
<p>
|
||
As mentioned above, it is possible for an observer who can view both you and
|
||
either the destination website or your Tor exit node to correlate timings of
|
||
your traffic as it enters the Tor network and also as it exits. Tor does not
|
||
defend against such a threat model.
|
||
</p>
|
||
<p>
|
||
In a more limited sense, note that if a censor or law enforcement agency has
|
||
the ability to obtain specific observation of parts of the network, it is
|
||
possible for them to verify a suspicion that you talk regularly to your friend
|
||
by observing traffic at both ends and correlating the timing of only that
|
||
traffic. Again, this is only useful to verify that parties already suspected
|
||
of communicating with one another are doing so. In most countries, the
|
||
suspicion required to obtain a warrant already carries more weight than
|
||
timing correlation would provide.
|
||
</p>
|
||
<p>
|
||
Furthermore, since Tor reuses circuits for multiple TCP connections, it is
|
||
possible to associate non anonymous and anonymous traffic at a given exit
|
||
node, so be careful about what applications you run concurrently over Tor.
|
||
Perhaps even run separate Tor clients for these applications.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="EverybodyARelay"></a>
|
||
<h3><a class="anchor" href="#EverybodyARelay">You should make every
|
||
Tor user be a relay.</a></h3>
|
||
|
||
<p>
|
||
Requiring every Tor user to be a relay would help with scaling the
|
||
network to handle all our users, and <a
|
||
href="#BetterAnonymity">running a Tor
|
||
relay may help your anonymity</a>. However, many Tor users cannot be
|
||
good
|
||
relays — for example, some Tor clients operate from behind
|
||
restrictive
|
||
firewalls, connect via modem, or otherwise aren't in a position
|
||
where they
|
||
can relay traffic. Providing service to these clients is a critical
|
||
part of providing effective anonymity for everyone, since many Tor
|
||
users
|
||
are subject to these or similar constraints and including these
|
||
clients
|
||
increases the size of the anonymity set.
|
||
</p>
|
||
|
||
<p>
|
||
That said, we do want to encourage Tor users to run relays, so what
|
||
we
|
||
really want to do is simplify the process of setting up and
|
||
maintaining
|
||
a relay. We've made a lot of progress with easy configuration in the
|
||
past
|
||
few years: Vidalia has an easy relay configuration interface, and
|
||
supports
|
||
uPnP too. Tor is good at automatically detecting whether it's
|
||
reachable and
|
||
how much bandwidth it can offer.
|
||
</p>
|
||
|
||
<p>
|
||
There are five steps we need to address before we can do this
|
||
though:
|
||
</p>
|
||
|
||
<p>
|
||
First, we need to make Tor stable as a relay on all common
|
||
operating systems. The main remaining platform is Windows,
|
||
and we're mostly there. See Section 4.1 of <a
|
||
href="https://www.torproject.org/press/2008-12-19-roadmap-press-release"
|
||
>our
|
||
development roadmap</a>.
|
||
</p>
|
||
|
||
<p>
|
||
Second, we still need to get better at automatically estimating
|
||
the right amount of bandwidth to allow. See item #7 on the
|
||
<a href="<page getinvolved/volunteer>#Research">research section of
|
||
the
|
||
volunteer page</a>: "Tor doesn't work very well when relays
|
||
have asymmetric bandwidth (e.g. cable or DSL)". It might be that <a
|
||
href="<page docs/faq>#TransportIPnotTCP">switching
|
||
to UDP transport</a> is the simplest answer here — which alas
|
||
is
|
||
not a very simple answer at all.
|
||
</p>
|
||
|
||
<p>
|
||
Third, we need to work on scalability, both of the network (how to
|
||
stop requiring that all Tor relays be able to connect to all Tor
|
||
relays) and of the directory (how to stop requiring that all Tor
|
||
users know about all Tor relays). Changes like this can have large
|
||
impact on potential and actual anonymity. See Section 5 of the <a
|
||
href="<svnprojects>design-paper/challenges.pdf">Challenges</a> paper
|
||
for details. Again, UDP transport would help here.
|
||
</p>
|
||
|
||
<p>
|
||
Fourth, we need to better understand the risks from
|
||
letting the attacker send traffic through your relay while
|
||
you're also initiating your own anonymized traffic. <a
|
||
href="http://freehaven.net/anonbib/#back01">Three</a> <a
|
||
href="http://freehaven.net/anonbib/#clog-the-queue">different</a>
|
||
<a href="http://freehaven.net/anonbib/#torta05">research</a> papers
|
||
describe ways to identify the relays in a circuit by running traffic
|
||
through candidate relays and looking for dips in the traffic while
|
||
the
|
||
circuit is active. These clogging attacks are not that scary in the
|
||
Tor
|
||
context so long as relays are never clients too. But if we're trying
|
||
to
|
||
encourage more clients to turn on relay functionality too (whether
|
||
as
|
||
<a href="<page docs/bridges>">bridge relays</a> or as normal
|
||
relays), then
|
||
we need to understand this threat better and learn how to mitigate
|
||
it.
|
||
</p>
|
||
|
||
<p>
|
||
Fifth, we might need some sort of incentive scheme to encourage
|
||
people
|
||
to relay traffic for others, and/or to become exit nodes. Here are
|
||
our
|
||
<a href="<blog>two-incentive-designs-tor">current
|
||
thoughts on Tor incentives</a>.
|
||
</p>
|
||
|
||
<p>
|
||
Please help on all of these!
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="TransportIPnotTCP"></a>
|
||
<h3><a class="anchor" href="#TransportIPnotTCP">You should transport all
|
||
IP packets, not just TCP packets.</a></h3>
|
||
|
||
<p>
|
||
This would be handy, because it would make Tor better able to handle
|
||
new protocols like VoIP, it could solve the whole need to socksify
|
||
applications, and it would solve the fact that exit relays need to
|
||
allocate a lot of file descriptors to hold open all the exit
|
||
connections.
|
||
</p>
|
||
|
||
<p>
|
||
We're heading in this direction: see <a
|
||
href="https://trac.torproject.org/projects/tor/ticket/1855">this trac
|
||
ticket</a> for directions we should investigate. Some of the hard
|
||
problems are:
|
||
</p>
|
||
|
||
<ol>
|
||
<li>IP packets reveal OS characteristics. We would still need to do
|
||
IP-level packet normalization, to stop things like TCP fingerprinting
|
||
attacks. Given the diversity and complexity of TCP stacks, along with <a
|
||
href="#RemotePhysicalDeviceFingerprinting">device
|
||
fingerprinting attacks</a>, it looks like our best bet is shipping our
|
||
own user-space TCP stack.
|
||
</li>
|
||
<li>Application-level streams still need scrubbing. We will still need
|
||
user-side applications like Torbutton. So it won't become just a matter
|
||
of capturing packets and anonymizing them at the IP layer.
|
||
</li>
|
||
<li>Certain protocols will still leak information. For example, we must
|
||
rewrite DNS requests so they are delivered to an unlinkable DNS server
|
||
rather than the DNS server at a user's ISP; thus, we must understand
|
||
the protocols we are transporting.
|
||
</li>
|
||
<li><a
|
||
href="http://crypto.stanford.edu/~nagendra/projects/dtls/dtls.html">DTLS
|
||
</a>
|
||
(datagram TLS) basically has no users, and IPsec sure is big. Once we've
|
||
picked a transport mechanism, we need to design a new end-to-end Tor
|
||
protocol for avoiding tagging attacks and other potential anonymity and
|
||
integrity issues now that we allow drops, resends, et cetera.
|
||
</li>
|
||
<li>Exit policies for arbitrary IP packets mean building a secure
|
||
IDS. Our node operators tell us that exit policies are one of the main
|
||
reasons they're willing to run Tor. Adding an Intrusion Detection System
|
||
to handle exit policies would increase the security complexity of Tor,
|
||
and would likely not work anyway, as evidenced by the entire field of
|
||
IDS
|
||
and counter-IDS papers. Many potential abuse issues are resolved by the
|
||
fact that Tor only transports valid TCP streams (as opposed to arbitrary
|
||
IP including malformed packets and IP floods), so exit policies become
|
||
even <i>more</i> important as we become able to transport IP packets. We
|
||
also need to compactly describe exit policies in the Tor directory,
|
||
so clients can predict which nodes will allow their packets to exit
|
||
—
|
||
and clients need to predict all the packets they will want to send in
|
||
a session before picking their exit node!
|
||
</li>
|
||
<li>The Tor-internal name spaces would need to be redesigned. We support
|
||
hidden service ".onion" addresses by intercepting the addresses when
|
||
they are passed to the Tor client. Doing so at the IP level will require
|
||
a more complex interface between Tor and the local DNS resolver.
|
||
</li>
|
||
</ol>
|
||
|
||
<hr>
|
||
|
||
<a id="HideExits"></a>
|
||
<h3><a class="anchor" href="#HideExits">You should hide the list of Tor
|
||
relays, so people can't block the exits.</a></h3>
|
||
|
||
<p>
|
||
There are a few reasons we don't:
|
||
</p>
|
||
|
||
<ol>
|
||
<li>We can't help but make the information available, since Tor clients
|
||
need to use it to pick their paths. So if the "blockers" want it, they
|
||
can get it anyway. Further, even if we didn't tell clients about the
|
||
list of relays directly, somebody could still make a lot of connections
|
||
through Tor to a test site and build a list of the addresses they see.
|
||
</li>
|
||
|
||
<li>If people want to block us, we believe that they should be allowed
|
||
to
|
||
do so. Obviously, we would prefer for everybody to allow Tor users to
|
||
connect to them, but people have the right to decide who their services
|
||
should allow connections from, and if they want to block anonymous
|
||
users,
|
||
they can.
|
||
</li>
|
||
|
||
<li>Being blockable also has tactical advantages: it may be a persuasive
|
||
response to website maintainers who feel threatened by Tor. Giving them
|
||
the option may inspire them to <a href="<page docs/faq-abuse>#Bans">stop
|
||
and think</a> about whether they really want to eliminate private access
|
||
to their system, and if not, what other options they might have. The
|
||
time they might otherwise have spent blocking Tor, they may instead
|
||
spend rethinking their overall approach to privacy and anonymity.
|
||
</li>
|
||
</ol>
|
||
|
||
<hr>
|
||
|
||
<a id="ChoosePathLength"></a>
|
||
<h3><a class="anchor" href="#ChoosePathLength">You should let people choose
|
||
their path length.</a></h3>
|
||
<p>
|
||
Right now the path length is hard-coded at 3 plus the number of nodes in
|
||
your path that are sensitive. That is, in normal cases it's 3, but for
|
||
example if you're accessing a hidden service or a ".exit" address it could be 4.
|
||
</p>
|
||
<p>
|
||
We don't want to encourage people to use paths longer than this -- it
|
||
increases load on the network without (as far as we can tell) providing
|
||
any more security. Remember that <a
|
||
href="https://svn.torproject.org/svn/tor/trunk/doc/design-paper/tor-design.html#subsec:threat-model">
|
||
the best way to attack Tor is to attack the endpoints and ignore the middle
|
||
of the path
|
||
</a>.
|
||
</p>
|
||
<p>
|
||
And we don't want to encourage people to use paths of length 1 either.
|
||
Currently there is no reason to suspect that investigating a single
|
||
relay will yield user-destination pairs, but if many people are using
|
||
only a single hop, we make it more likely that attackers will seize or
|
||
break into relays in hopes
|
||
of tracing users.
|
||
</p>
|
||
<p>
|
||
Now, there is a good argument for making the number of hops in a path
|
||
unpredictable. For example, somebody who happens to control the last
|
||
two hops in your path still doesn't know who you are, but they know
|
||
for sure which entry node you used. Choosing path length from, say,
|
||
a geometric distribution will turn this into a statistical attack,
|
||
which seems to be an improvement. On the other hand, a longer path
|
||
length is bad for usability. We're not sure of the right trade-offs
|
||
here. Please write a research paper that tells us what to do.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="SplitEachConnection"></a>
|
||
<h3><a class="anchor" href="#SplitEachConnection">You should split
|
||
each connection over many paths.</a></h3>
|
||
|
||
<p>
|
||
We don't currently think this is a good idea. You see, the attacks we're
|
||
worried about are at the endpoints: the adversary watches Alice (or the
|
||
first hop in the path) and Bob (or the last hop in the path) and learns
|
||
that they are communicating.
|
||
</p>
|
||
<p>
|
||
If we make the assumption that timing attacks work well on even a few packets
|
||
end-to-end, then having *more* possible ways for the adversary to observe the
|
||
connection seems to hurt anonymity, not help it.
|
||
</p>
|
||
<p>
|
||
Now, it's possible that we could make ourselves more resistant to end-to-end
|
||
attacks with a little bit of padding and by making each circuit send and
|
||
receive a fixed number of cells. This approach is more well-understood in
|
||
the context of high-latency systems. See e.g.
|
||
<a href="http://freehaven.net/anonbib/#pet05-serjantov">
|
||
Message Splitting Against the Partial Adversary by Andrei Serjantov and
|
||
Steven J. Murdoch</a>.
|
||
</p>
|
||
<p>
|
||
But since we don't currently understand what network and padding
|
||
parameters, if any, could provide increased end-to-end security, our
|
||
current strategy is to minimize the number of places that the adversary
|
||
could possibly see.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="UnallocatedNetBlocks"></a>
|
||
<h3><a class="anchor" href="#UnallocatedNetBlocks">Your default exit
|
||
policy should block unallocated net blocks too.</a></h3>
|
||
|
||
<p>
|
||
No, it shouldn't. The default exit policy blocks certain private net blocks,
|
||
like 10.0.0.0/8, because they might actively be in use by Tor relays and we
|
||
don't want to cause any surprises by bridging to internal networks. Some
|
||
overzealous firewall configs suggest that you also block all the parts of
|
||
the Internet that IANA has not currently allocated. First, this turns into
|
||
a problem for them when those addresses *are* allocated. Second, why should
|
||
we default-reject something that might one day be useful?
|
||
</p>
|
||
<p>
|
||
Tor's default exit policy is chosen to be flexible and useful in the future:
|
||
we allow everything except the specific addresses and ports that we
|
||
anticipate will lead to problems.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="BlockWebsites"></a>
|
||
<h3><a class="anchor" href="#BlockWebsites">Exit policies should be
|
||
able to block websites, not just IP addresses.</a></h3>
|
||
|
||
<p>
|
||
It would be nice to let relay operators say things like "reject
|
||
www.slashdot.org" in their exit policies, rather than requiring
|
||
them to learn all the IP address space that could be covered by the site
|
||
(and then also blocking other sites at those IP addresses).
|
||
</p>
|
||
<p>
|
||
There are two problems, though. First, users could still get around these
|
||
blocks. For example, they could request the IP address rather than the
|
||
hostname when they exit from the Tor network. This means operators would
|
||
still need to learn all the IP addresses for the destinations in question.
|
||
</p>
|
||
<p>
|
||
The second problem is that it would allow remote attackers to censor
|
||
arbitrary sites. For example, if a Tor operator blocks www1.slashdot.org,
|
||
and then some attacker poisons the Tor relay's DNS or otherwise changes
|
||
that hostname to resolve to the IP address for a major news site, then
|
||
suddenly that Tor relay is blocking the news site.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="BlockContent"></a>
|
||
<h3><a class="anchor" href="#BlockContent">You should change Tor to
|
||
prevent users from posting certain content.</a></h3>
|
||
|
||
<p> Tor only transports data, it does not inspect the contents of the
|
||
connections which are sent over it. In general it's a very hard problem
|
||
for a computer to determine what is objectionable content with good true
|
||
positive/false positive rates and we are not interested in addressing
|
||
this problem.
|
||
</p>
|
||
<p>
|
||
Further, and more importantly, which definition of "certain content" could we
|
||
use? Every choice would lead to a quagmire of conflicting personal morals. The
|
||
only solution is to have no opinion.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="SendPadding"></a>
|
||
<h3><a class="anchor" href="#SendPadding">You should send padding so it's
|
||
more secure.</a></h3>
|
||
|
||
<p>
|
||
Like all anonymous communication networks that are fast enough for web
|
||
browsing, Tor is vulnerable to statistical "traffic confirmation"
|
||
attacks, where the adversary watches traffic at both ends of a circuit
|
||
and confirms his guess that they're communicating. It would be really
|
||
nice if we could use cover traffic to confuse this attack. But there
|
||
are three problems here:
|
||
</p>
|
||
|
||
<ul>
|
||
<li>
|
||
Cover traffic is really expensive. And *every* user needs to be doing
|
||
it. This adds up to a lot of extra bandwidth cost for our volunteer
|
||
operators, and they're already pushed to the limit.
|
||
</li>
|
||
<li>
|
||
You'd need to always be sending traffic, meaning you'd need to always
|
||
be online. Otherwise, you'd need to be sending end-to-end cover
|
||
traffic -- not just to the first hop, but all the way to your final
|
||
destination -- to prevent the adversary from correlating presence of
|
||
traffic at the destination to times when you're online. What does it
|
||
mean to send cover traffic to -- and from -- a web server? That is not
|
||
supported in most protocols.
|
||
</li>
|
||
<li>
|
||
Even if you *could* send full end-to-end padding between all users and
|
||
all destinations all the time, you're *still* vulnerable to active
|
||
attacks that block the padding for a short time at one end and look for
|
||
patterns later in the path.
|
||
</li>
|
||
</ul>
|
||
|
||
<p>
|
||
In short, for a system like Tor that aims to be fast, we don't see any
|
||
use for padding, and it would definitely be a serious usability problem.
|
||
We hope that one day somebody will prove us wrong, but we are not
|
||
optimistic.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Steganography"></a>
|
||
<h3><a class="anchor" href="#Steganography">You should use steganography to hide Tor
|
||
traffic.</a></h3>
|
||
|
||
<p>
|
||
Many people suggest that we should use steganography to make it hard
|
||
to notice Tor connections on the Internet. There are a few problems
|
||
with this idea though:
|
||
</p>
|
||
|
||
<p>
|
||
First, in the current network topology, the Tor relays list <a
|
||
href="#HideExits">is public</a> and can be accessed by attackers.
|
||
An attacker who wants to detect or block anonymous users could
|
||
always just notice <b>any connection</b> to or from a Tor relay's
|
||
IP address.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="IPv6"></a>
|
||
<h3><a class="anchor" href="#IPv6">Tor should support IPv6.</a></h3>
|
||
|
||
<p>
|
||
That's a great idea! There are two aspects for IPv6 support that Tor needs.
|
||
First, Tor needs to support exit to hosts that only have IPv6 addresses.
|
||
Second, Tor needs to support Tor relays that only have IPv6 addresses.
|
||
</p>
|
||
<p>
|
||
The first is far easier: the protocol changes are relatively simple and
|
||
isolated. It would be like another kind of exit policy.
|
||
</p>
|
||
<p>
|
||
The second is a little harder: right now, we assume that (mostly) every
|
||
Tor relay can connect to every other. This has problems of its own, and
|
||
adding IPv6-address-only relays adds problems too: it means that only
|
||
relays with IPv6 abilities can connect to IPv6-address-only relays. This
|
||
makes it possible for the attacker to make some inferences about client
|
||
paths that it would not be able to make otherwise.
|
||
</p>
|
||
<p>
|
||
There is an <a
|
||
href="https://gitweb.torproject.org/tor.git/blob/HEAD:/doc/spec/proposals/117-ipv6-exits.txt">
|
||
IPv6 exit proposal</a> to address the first step for anonymous access to
|
||
IPv6 resources on the Internet.
|
||
</p>
|
||
<p>
|
||
Full IPv6 support is definitely on our "someday" list; it will come along
|
||
faster if somebody who wants it does some of the work.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="Criminals"></a>
|
||
<h3><a class="anchor" href="#Criminals">Doesn't Tor enable criminals
|
||
to do bad things?</a></h3>
|
||
|
||
<p>
|
||
For the answer to this question and others, please see our <a
|
||
href="<page docs/faq-abuse>">Tor Abuse FAQ</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="RespondISP"></a>
|
||
<h3><a class="anchor" href="#RespondISP">How do I respond to my ISP
|
||
about my exit relay?</a></h3>
|
||
|
||
<p>
|
||
A collection of templates for successfully responding to ISPs is <a
|
||
href="<wiki>doc/TorAbuseTemplates">collected
|
||
here</a>.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
<a id="HelpPoliceOrLawyers"></a>
|
||
<h3><a class="anchor" href="#HelpPoliceOrLawyers">I have questions about
|
||
a Tor IP address for a legal case.</a></h3>
|
||
|
||
<p>
|
||
Please read the <a
|
||
href="https://www.torproject.org/eff/tor-legal-faq">legal FAQ written
|
||
by EFF lawyers</a>. There's a growing <a
|
||
href="https://blog.torproject.org/blog/start-tor-legal-support-directory">legal
|
||
directory</a> of people who may be able to help you.
|
||
</p>
|
||
|
||
<p>
|
||
If you need to check if a certain IP address was acting as a Tor exit
|
||
node at a certain date and time, you can use the <a
|
||
href="https://exonerator.torproject.org/">ExoneraTor tool</a> to query the
|
||
historic Tor relay lists and get an answer.
|
||
</p>
|
||
|
||
<hr>
|
||
|
||
</div>
|
||
<!-- END MAINCOL -->
|
||
<div id = "sidecol">
|
||
#include "side.wmi"
|
||
#include "info.wmi"
|
||
</div>
|
||
<!-- END SIDECOL -->
|
||
</div>
|
||
<!-- END CONTENT -->
|
||
#include <foot.wmi>
|
||
|