The Freenet Project

Freenet Frequently Asked Questions

Philosophical questions

  1. What is Freenet?
  2. Who is behind Freenet?
  3. If authors are anonymous how can you trust information?
  4. Do I have to donate disk space and bandwidth?
  5. I don't have to donate anything when using filesharing application X and I get to leech more.
  6. All my friends donate very little space and bandwidth. Why should I donate more?
  7. If I donate a lot will my experience improve significantly?
  8. Is Freenet legal?
  9. Can I get trouble if I run a node?
  10. What about copyright?
  11. What about child porn, offensive content or terrorism?
  12. I don't want my node to be used to harbor child porn, offensive content or terrorism. What can I do?
  13. How about encryption export restrictions?
  14. I have nothing to hide and don't need anonymity. Is there anything else Freenet can offer?

Technical questions

  1. How do I use this software? I downloaded it, but when I run it there's no GUI.
  2. Why is Freenet so slow?
  3. Is Freenet searchable?
  4. How do I get freenet working with a firewall/NAT?
  5. Do I need a permanent connection to run a node?
  6. Why does Freenet only download 1 or 2 files at a time?
  7. Why can't Freenet store data permanently?
  8. Why is Freenet implemented in Java?
  9. How do I allow connections to FProxy from other computers?
  10. What is FEC?
  11. What is healing?
  12. What is a Heisenbug?
  13. What's new? Is there a changelog?
  14. Why are there so many messages in my logfile with a backtrace attached?
  15. How can I change from stable to unstable?

Publisher questions

  1. If I publish something in Freenet, how will people find it? Don't they have to know the key I used?
  2. How do I publish a Content Hash Key (CHK)?
  3. Can Freenet documents be updated / deleted?

Contribution questions

  1. I have this great idea....
  2. Can I contribute to the Freenet Project?
  3. How can I access the code and website?
  4. What tools do I need to help develop?
  5. Is there a Help Site that goes deeper into the questions newbies may have about Freenet, and where people can contribute too?
  6. Where can I report bugs?

Security questions

  1. Won't attack X break Freenet's anonymity?
  2. Is Freenet vulnerable to flooding attacks?
  3. Why hash keys and encrypt data when a node operator could identify them (the data) anyway if he tried?
  4. What about hostile "cancer" nodes within the network?
  5. What about attack Y?

Misc. questions

  1. Where can I get a high quality copy of the rabbit icon?
  2. An other FAQ on our wiki server
  3. A page dedicated to the security of freenet 0.7 on our wiki server

Philosophical answers

What is Freenet?
Freenet is free software designed to ensure true freedom of communication over the Internet. It allows anybody to publish and read information with complete anonymity. Nobody controls Freenet, not even its creators, meaning that the system is not vulnerable to manipulation or shutdown. Freenet is also very efficient in how it deals with information, adaptively replicating content in response to demand. For more information, please read What Is Freenet.

Who is behind Freenet?
Freenet grew out of a design for an anonymous publication system created by Ian Clarke while a student at the University of Edinburgh, Scotland. Since then many other people have contributed towards making Ian's proposal a reality.

If authors are anonymous how can you trust information?
Cryptographic signing of information allows people to prove authorship, this technique is frequently used to authenticate authorship of emails. Moreover, you could actually sign information while remaining anonymous, thus having an anonymous persona. You could prove that you wrote different pieces of information on Freenet, without revealing your identity. In this way you could build up an anonymous reputation for reliability.


You aren't really donating in the sense that you lose the disk space and the bandwidth; but you aren't really sharing either (at least not the same way as with filesharing programs). It is more like pitching in to the common Freenet resource pool.

I don't have to donate anything when using filesharing application X and I get to leech more.
Do you get to do that anonymously? Freenet is designed with anonymity in mind, performance comes second.


If you are happy with what you are getting then no. But if you want more you should consider donating more and running your node as close to 24x7 as possible, and you should ask your friends to do the same.


Your experience will definitely get better, but for a really great improvement we need more people to start thinking like you. Bandwidth counts more than diskspace.

Is Freenet legal?
If by legal you mean not illegal, then yes it is. Of course, anything can be found to be illegal at some point in the future, and the law can be an ass sometimes, so we can make no guarantee about Freenet's future legality. You might be interested in the EFF's advice to peer to peer developers. There have been questions raised about Freenet's legality in France under the DADVSI, and its legality across the EU should IPRED2 pass. Also we have grounds to believe that Freenet 0.5 is blocked in China, although that doesn't necessarily make it illegal (the website of course has been blocked since forever). If you want legal advice, ask a lawyer.

Can I get trouble if I run a node?
This is related to the previous question. We have done everything we can to make it extremely difficult for any sane legal system to justify punishing someone for running a Freenet node, and there is little precedent for such action in today's developed countries. Many legal systems recognise the importance of freedom of speech, which is Freenet's core goal. Having said that, there is risk in doing anything that your government might not agree with; you should make an informed decision as to whether to take that risk.

What about copyright?
There are some excellent thoughts on this subject on the Philosophy page.

What about child porn, offensive content or terrorism?
While most people wish that child pornography and terrorism did not exist, humanity should not be deprived of their freedom to communicate just because of how a very small number of people might use that freedom.

I don't want my node to be used to harbor child porn, offensive content or terrorism. What can I do?
The true test of someone who claims to believe in Freedom of Speech is whether they tolerate speech which they disagree with, or even find disgusting. If this is not acceptable to you, you should not run a Freenet node. There is another thing you can do. Since content in Freenet is available as long as its popular, you can help limit the popularity of whatever information you do not like. For example, if you do not want a file to spread you should not request it and tell everyone you know not to request that specific key. However, keep in mind that freenet is not designed so as to only allow communication between people if a sufficient number of people agree with the communication. Freenet is designed to make communication possible even if there's just one publisher and one reader, and this is already reasonably feasible on the current freenet.

How about encryption export restrictions?
The Freenet Project has notified the US authorities (since the files are hosted on SourceForge, which is on US soil) that it will be exporting crypto. As long as your country doesn't prohibit the use of encryption you are fine.

I have nothing to hide and don't need anonymity. Is there anything else Freenet can offer?
Yes, in fact even without the anonymity feature Freenet is very useful because of its unique way it handles content distribution and information load. In simple terms that means you can publish a website without worrying about how big the site will be and without having to put someone elses ad banners on it. While it is unlikely that freenet sites will ever load faster than regular websites, it does adapt to sudden surges of visitors (which will often occur when relatively unknown sites get linked to from a big site) better, and high download speeds for big files are feasible too. Just don't expect very low latency.

Technical answers

How do I use this software? I downloaded it, but when I run it there's no GUI.
Fred (the Freenet REference Daemon) runs as a daemon, or service, in the background. You normally talk to it through a Freenet client. One built-in client is fproxy, which lets you talk to Freenet with a web browser. Freenet should have installed a Browse Freenet shortcut on the desktop and/or the start menu. This should launch a customised firefox profile optimised for browsing Freenet (with a black theme so you can see clearly that you're not browsing the web). Failing that, point your web browser to http://127.0.0.1:8888/ for the gateway page. Try clicking the various links in the "Bookmarks" panel to reach some of the popular Freenet index sites.

If you're looking for applications that run on top of Freenet and provide a different interface or functionality, please see the Tools page.

Why is Freenet so slow?
When you first install Freenet, it will be slow, and you may see Data Not Found or Route Not Found errors for freesites. This is normal, and Freenet will speed up significantly over time. For best performance you should try to run Freenet as close to 24 hours a day as possible. This is why we install Freenet as a service.

Please bear in mind that Freenet is inherently high latency: it can take a while to (for example) load a page for the first time, even if it is capable of reasonable speeds (as anonymous systems go!) for large popular files. The Browse Freenet icon/menu item should launch a customised version of Firefox which will use many connections to maximise performance especially when you open many freesites in tabs. If that doesn't work then see here. And of course, protecting your anonymity does cost a certain amount of performance.

Is Freenet searchable?
Yes, there are a few different search mechanisms. To search the freenet web, go to the plugins page, load the XMLLibrarian plugin if it isn't already there, and use that. Alternatively, Frost and Thaw also provide searching for messages and files. Note that searching on Freenet is a good deal more difficult than on other networks because of Freenet's different architecture and design goals.

How do I get freenet working with a Firewall/NAT?
Mostly, Freenet should just work with a NAT. However, you should forward the ports manually if you can. Click on the Friends or Strangers page. At the bottom you will see a list of ports used by the node. You should forward (for UDP) the Darknet FNP and Opennet FNP ports. You may need to look up your router's documentation to figure out how to do this. Freenet should have forwarded them itself through Universal Plug and Play, but this doesn't always work (and it never works if you don't have the UPnP plugin loaded, or have java before 1.5).

If you have a dyndns address or other domain name pointing to the computer you run your Freenet node on, tell the node about it. Go to the config page, and find the option "IP address override". Put your domain name in that box, and apply the settings.

Do I need a permanent connection to run a node?
No, but it is preferred. You can run the software and test it from a "transient" connection (such as provided by typical modem/ISP setups), but for the network as a whole to be most useful, we will need as many permanent nodes as possible (most cable modem or DSL setups are sufficiently "permanent" for this). A later version of Freenet may take better advantage of transient nodes.

Why does Freenet only download 1 or 2 files at a time?
Many browsers limit the number of simultaneous connections to something far too low for efficiently browsing Freenet (since Freenet pages often have much higher latency than web pages). This can usually be reconfigured. For example, for Mozilla Firefox, type about:config in the address field of the browser and replace the value of the following settings to the one stated. Filter on "connections" to get only the relevant settings:

network.http.max-connections 200
network.http.max-connections-per-server 200
network.http.max-persistent-connections-per-proxy 200
network.http.max-persistent-connections-per-server 200

Note that these settings will cause mozilla to use more connections for all your browsing, which may not be desirable from a network congestion point of view; volunteers to make mozilla allow this sort of settings to be set per host would be welcome...

Note also that if you have installed Freenet recently, it should have created a Firefox profile for browsing Freenet with similar settings, with a black theme, which you can access through the Browse Freenet icon.

Why can't Freenet store data permanently?
Because we can't find a way to do this without compromising Freenet's other goals. For example, people often suggest that someone's node could just never drop data they want to cache permanently. This, however, won't work because even if the data is still available on their node, there is no way to ensure that requests for that data will be routed to that node. We have considered many other ways that Freenet could store data permanently, but they either won't work, or compromise Freenet's core goals of anonymity, and scalability. However, if you simply reinsert your data regularly, or if it is regularly downloaded (not by the same person as it would be cached on their node and the path to their node), it should remain available indefinitely.

Why is Freenet implemented in Java?
Opinions differ about the choice of java for the reference implementation of freenet (even among the core developers). Ian Clarke and several other developers are java proponents and the choice for java was made. Even if everybody could be convinced to switch to a different language reimplementing the current freenet protocol would be quite a big task, and take up a significant amount of time, while there is only a limited amount of developer-time available. Flame wars on the development list about the language choice aren't welcome, people willing to implement freenet in other languages however are very much encouraged to try. Don't underestimate the amount of work however.

How do I allow connections to FProxy from other computers?
If you want everyone to be able to use your node you have the following options:

In both cases change the following parameters:

If you want everyone to be able to access your node:

fproxy.bindTo=0.0.0.0
fproxy.allowedHosts=0.0.0.0

Of course, this leaves your node wide open, unless you control access with a firewall of some sort. If you'd prefer to use access controls within Freenet, then you can use lines like this:

fproxy.bindTo=0.0.0.0
fproxy.allowedHosts=127.0.0.1,192.168.1.0/24

Or even (find your IP address from ipconfig/ifconfig/winipcfg and substitute it for 192.168.1.1):

fproxy.bindTo=127.0.0.1,192.168.1.1
fproxy.allowedHosts=127.0.0.1,192.168.1.0/24

And if you want to grant full access (i.e. change config settings, restart, etc) to the node (WARNING: Be very careful who you give full fproxy access to!): fproxy.allowedHostsFullAccess=127.0.0.1,192.168.1.0/24

What is FEC?
FEC stands for Forward Error Correction. When large files are inserted into Freenet, they are split into many small blocks -- this is called a splitfile. FEC adds redundant check blocks to a splitfile, so that if some of the blocks fall out of the network or can't be found, you might still be able to retrieve enough of the file to reconstruct it.

What is healing?
When you download a splitfile that uses FEC (see previous question), some of the blocks may have become unavailable. Healing lets you repair the file by recalculating the data for the missing blocks, and then reinserting them into Freenet.

What is a Heisenbug?
The name comes from the Heisenberg Uncertainty Principle of physics, which states that when measuring both the momentum and the position of a particle, the product of the uncertainties is a constant. In Freenet, the Heisenbug refers to a problem which plagued the developers for a long time and was extremely difficult to reproduce.

The current theory is that the Heisenbug is actually a bug in certain Java virtual machines, particularly IBM's, which causes certain calculations to return the wrong results; but these results match a certain pattern. Whenever your node sees this pattern, it reports that the Heisenbug may have occurred, and writes verbose information to the logs. Since this pattern can also occur under normal circumstances (about once in every 65,000 times), a few Heisenbug reports may be expected. But if you're getting lots of them, something's wrong.

Update: It's turned out that the heisenbug was actually a bug in the fred code, there was a bug in our implementation of Yarrow, a piece of code should have been synchronized (a java method of locking) but wasn't. If you're still seeing heisenbugs being reported in your logfile and are running a current version of freenet, please report them to the mailinglist.

What's new? Is there a changelog?
On every new build, a brief summary of all the main changes is posted to the support and devl lists and the freenet-announce board on Frost. Alternatively for a much more detailed view, check the SVN logs.

Why are there so many messages in my logfile with a backtrace attached?
Fred (and freenet in general) are still very much in development, and if something goes wrong it's worthwhile to know exactly what went wrong.

How can I change from stable to unstable?
There is no unstable network anymore.

Publisher answers

If I publish something in Freenet, how will people find it? Don't they have to know the key I used?
Yes, people will have to know what key you used to publish your information. This means you will have to announce your key in some way.

The most common way to do this is to send a message, containing your key and brief description of your information, to the author of one of the existing Freenet sites. Most of the "portal" sites which are linked from the Freenet web interface (fproxy) have a submission form which lets you send them messages anonymously. You could also send your key to people by using the Freenet mailing lists, in the IRC channel (irc.freenode.net #freenet), by private e-mail, or by advertising your Freenet site on your World Wide Web site. If you're feeling extravagant, you could even try skywriting it. (Graffiti is not recommended, for legal reasons.)

How do I publish a Content Hash Key (CHK)?
A Content Hash Key is based on the actual content contained within it - and as such, the key will only be known after it has been inserted into Freenet. To insert a CHK, simply insert it as "CHK@", Freenet will tell you what the actual CHK is once the insertion completes.

Can Freenet documents be updated / deleted?
Currently, a document posted to Freenet with the same name as one already present may actually serve to propagate the existing document. There is also currently no means of deleting a document from Freenet. Documents that are never requested are eventually removed through disuse.

However, you can use an Updatable Subspace Key (USK) to provide a form of updatable freesite: your node will automatically look for later editions of the site (after you visit it, or always if you bookmark it), and show you the latest version.

Contribution answers

I have this great idea....
Good! First step: read the mailing list archives. Odds are good that someone else had the same idea and discussed it with the group. Either a flaw was found in the idea, or perhaps it was decided to postpone implementing the idea until later. Some examples of ideas already discussed are storing information by content hash, key redirection, signed keys/data, use of UDP, server discovery, URLs, document versioning, and others. If you don't see the idea discussed in the archives, by all means bring it up in the appropriate mailing list.

Can I contribute to the Freenet Project?
Absolutely. Even if you don't have the time or skills to become a co-developer of the project, you can contribute in other ways:

If you are a developer, you can also help by designing and developing other applications to run on Freenet.

People that want to contribute to Freenet in any way, by contributing artwork, new ideas, or even correcting spelling/grammar mistakes or ideas for adding new pages/paragraphs on this site, are also welcome to email.

How can I access the code and website?
We are using a subversion server : Freenet's subversion repository.

What tools do I need to help develop?
To build and deploy the Freenet server, you will need Java tools compatible with Sun's JDK 1.4 or later. To retrieve and update the code at http://freenet.googlecode.com/svn/trunk/freenet/using subversion, (This is not necessary if you only want to download, compile, and run the server without contributing to its code). To do web development you will need SSH (or OpenSSH). Further instructions for building and deploying the server are included with the code itself. Generally speaking, joining our IRC channel is a good idea: #freenet on irc.freenode.net

Is there a Help Site that goes deeper into the questions newbies may have about Freenet, and where people can contribute too?
You could have a look at our wiki. There is also an older, largely unmaintained Freenet Help Site wiki. You can contribute to both, since they are wiki's so most pages are editable.

Where can I report bugs?
You can use our bug tracking system or send a mail to our development mailing list.

Security answers

Won't attack X break Freenet's anonymity?
Short answer: Probably yes.

Long answer:

Freenet does not offer true anonymity in the way that Tor and the Mixmaster cypherpunk remailers do. Most of the non-trivial attacks (advanced traffic analysis, compromising any given majority of the nodes, etc.) that these were designed to counter would probably be successful in identifying someone making requests on Freenet.

Your identity is always visible to the nodes you are actually connected to. They know what keys your node requests: your anonymity against them is a limited level of plausible deniability, that maybe you are forwarding these requests for some other node. Unfortunately, your peers can do correlation attacks to figure out which requests are from you and which requests are from your peers or somebody else. These attacks rely on the attacker knowing what the keys are for, and there being lots of them, so for example, a big splitfile, a big freesite inserted regularly, a Frost poster maybe who uploads files too.

At the moment, the most important thing you can do to protect yourself is to get lots of "Friends" aka darknet connections: these are permanent, fixed connections to people you actually know. Once you have enough, you can turn off opennet (aka insecure mode), and only connect to people you know. This makes it very much more expensive for an attacker, as he has to infiltrate the social network, rather than just harvesting the opennet and connecting to nodes (which is technically very easy). One significant advantage over Tor etc is that if enough users only connect to Friends, it is very difficult to block the entire network; blocking Mixmaster or the current Tor on the other hand is very easy.

The only way that we can offer true anonymity is if the client can directly control the routing of data, and thus encrypt it with a series of keys of the nodes it will pass through (a la Mixmaster). There are plans to implement "premix routing" during Freenet 0.8, which would function similarly to Mixmaster remailers, Tor, etc, for the first few hops, but this is still a long way off.

More information on the current practical state of Freenet security is available here.

Is Freenet vulnerable to flooding attacks?
Short answer: no.

Long answer:

We don't think so. Aside from protecting freedom of speech, Freenet is also designed to be an efficient dynamic caching system. If information is requested a lot from a limited number of nodes, the nodes that the requests pass through will cache the information, lowering the load on the network. If information is inserted on a limited set of nodes and then subsequently requested a lot from a separate set of nodes, with repetition, the sets will close in on one another in the network topology until they are "neighbors" and only the originally targeted nodes are suffering from the attack.

In other words, in order to harm Freenet with a flood you need to consistently change your point of entry into the network and continually insert and request new data, and you will still only increase the workload for the network that is linear to your own. Given an immense will and capacity greater than the total of the entire network, it is possible to cripple any public network (including the Internet itself) with floods, but it is our intention to always keep Freenet as resistant to this as theoretically possible.

Curiously enough, the above analysis only applies to Opennet. On Darknet, you might have a little more success, although it would be much harder to change your entry point in any significant way. Nonetheless, you have a reasonably low bandwidth multiplier (the total number of nodes visited, around 20 on average).

Why hash keys and encrypt data when a node operator could identify them (the data) anyway if he tried?
Hashing the key and encrypting the data is not meant a method to keep Freenet Node operators from being able to figure out what type of information is in their nodes if they really want to (after all, they can just find the key in the same way as someone who requests the information would) but rather to keep operators from having to know what information is in their nodes if they don't want to. This distinction is more a legal one than a technical one. It is not realistic to expect a node operator to try to continually collect and/ or guess possible keys and then check them against the information in his node (even if such an attack is viable from a security perspective), so a sane society is less likely to hold an operator liable for such information on the network.

What about hostile "cancer" nodes within the network?
The existence of malicious nodes within the network is the most difficult problem that a distributed network must face, and has been the bane of many previous ideas. Many systems (such as multiplayer gaming networks) try to avoid malicious nodes by keeping the protocol and code closed, but we have yet to see an example of that working in the long run. And anyway it is opposed to Freenet's philosophy.

Freenet is based on a balance of positive and negative feedback loops that bring requests for information to a node when it is functioning well, and keep requests away from it when it is not. The key to avoiding "cancers" is (as in the body) to make sure these loops can correctly identify even the most carefully designed malicious node and not keep sending requests to it. This issue is not fully dealt with by the current test code, but you can rest assured that a number of possible solutions have been on the table and discussed for some time now. Several have been implemented (enforcing hashes or signatures on content, per node failure tables, backing off from a node that causes timeouts ...)

What about attack Y?
Freenet is still in testing and there are bound to be attacks found that we have not dealt with yet. So if you do manage to figure out a truly new kind of attack, we are interested in hearing about it. Please keep in mind what Freenet is and what it is not, however. No single network can offer everybody everything, and there are security issues (like anonymity, discussed above) that Freenet, by it's nature, may not deal with to extent you might wish. If this upsets you, all of our code is freely available, so you are free to take as much of it as you like and write your own distributed network that suits your desires.

Where can I get a high quality copy of the rabbit icon?
Here.

Send spam to catchme@freenetproject.org ! :)