README.md 10.1 KB
Newer Older
Richard Littauer's avatar
Richard Littauer committed
1
# IPFS implementation in Go
2
[![GoDoc](https://godoc.org/github.com/ipfs/go-ipfs?status.svg)](https://godoc.org/github.com/ipfs/go-ipfs) [![Build Status](https://travis-ci.org/ipfs/go-ipfs.svg?branch=master)](https://travis-ci.org/ipfs/go-ipfs)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
3

Richard Littauer's avatar
Richard Littauer committed
4
IPFS is a global, versioned, peer-to-peer filesystem. It combines good ideas from
Jeromy's avatar
Jeromy committed
5 6 7 8
Git, BitTorrent, Kademlia, SFS, and the Web. It is like a single bittorrent swarm,
exchanging git objects. IPFS provides an interface as simple as the HTTP web, but
with permanence built in. You can also mount the world at /ipfs.

Richard Littauer's avatar
Richard Littauer committed
9
For more info see: https://github.com/ipfs/ipfs.
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
10 11

Please put all issues regarding IPFS _design_ in the
12
[ipfs repo issues](https://github.com/ipfs/ipfs/issues).
Richard Littauer's avatar
Richard Littauer committed
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
Please put all issues regarding Go IPFS _implementation_ in [this repo](https://github.com/ipfs/go-ipfs/issues).

## Table of Contents

- [Security Issues](#security-issues)
- [Install](#install)
  - [Install prebuilt packages](#install-prebuilt-packages)
  - [Build from Source](#build-from-source)
  - [Prerequisite: Install Go](#prerequisite-install-go)
  - [Download + Compile IPFS](#download--compile-ipfs)
  - [Development Dependencies](#development-dependencies)
- [Updating](#updating)
- [Usage](#usage)
- [Getting Started](#getting-started)
  - [Some things to try](#some-things-to-try)
  - [Docker usage](#docker-usage)
    - [Docker usage with VirtualBox/boot2docker (OSX and Windows)](#docker-usage-with-virtualboxboot2docker-osx-and-windows)
- [Troubleshooting](#troubleshooting)
- [Contributing](#contributing)
- [Todo](#todo)
- [License](#license)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
34

Richard Littauer's avatar
Richard Littauer committed
35 36 37 38 39 40 41 42
## Security Issues

The IPFS protocol and its implementations are still in heavy development. This means that there may be problems in our protocols, or there may be mistakes in our implementations. And -- though IPFS is not production-ready yet -- many people are already running nodes in their machines. So we take security vulnerabilities very seriously. If you discover a security issue, please bring it to our attention right away!

If you find a vulnerability that may affect live deployments -- for example, by exposing a remote execution exploit -- please send your report privately to security@ipfs.io. Please DO NOT file a public issue.

If the issue is a protocol weakness that cannot be immediately exploited or something not yet deployed, just discuss it openly.

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
43 44
## Install

Richard Littauer's avatar
Richard Littauer committed
45
The canonical download instructions for IPFS are over at: http://ipfs.io/docs/install/. It is **highly suggested** you follow those instructions if you are not interested in working on IPFS development.
Muneeb Ali's avatar
Muneeb Ali committed
46

Richard Littauer's avatar
Richard Littauer committed
47
### Install prebuilt packages
48

49
We host prebuilt binaries over at our [distributions page](https://ipfs.io/ipns/dist.ipfs.io#go-ipfs).
50 51

From there:
52
- Click the blue "Download go-ipfs" on the right side of the page.
Richard Littauer's avatar
Richard Littauer committed
53
- Open/extract the archive.
54
- Move `ipfs` to your path (`install.sh` can do it for you).
55

Richard Littauer's avatar
Richard Littauer committed
56
### Build from Source
57

58
#### Install Go
59

60
First, you'll need Go. If you don't have it: [Download Go 1.5.2+](https://golang.org/dl/). **Go 1.6 is not yet supported.**
61 62

You'll need to add Go's bin directories to your `$PATH` environment variable e.g., by adding these lines to your `/etc/profile` (for a system-wide installation) or `$HOME/.profile`:
Richard Littauer's avatar
Richard Littauer committed
63

Muneeb Ali's avatar
Muneeb Ali committed
64 65 66 67 68
```
export PATH=$PATH:/usr/local/go/bin
export PATH=$PATH:$GOPATH/bin
```

Richard Littauer's avatar
Richard Littauer committed
69
(If you run into trouble, see the [Go install instructions](https://golang.org/doc/install)).
70

Richard Littauer's avatar
Richard Littauer committed
71
#### Download + Compile IPFS
72

73 74 75 76 77 78
go-ipfs differs from the vanilla `go get` flow: it uses
[gx](https://github.com/whyrusleeping/gx)/[gx-go](https://github.com/whyrusleeping/gx-go)
for dependency management. This means you'll need to perform download and
install steps separately.

First download `go-ipfs` without installing:
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
79 80

```
81
$ go get -d github.com/ipfs/go-ipfs
82

83
$ cd $GOPATH/src/github.com/ipfs/go-ipfs
84 85 86 87 88 89 90 91 92 93 94
```

If you don't already have them on your system, install `gx` and `gx-go`:

```sh
$ make toolkit_upgrade
```

Finally, install `go-ipfs`:

```
95
$ make install
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
96 97
```

98
#### Troubleshooting
99

100
* `git` is required in order for `go get` to fetch all dependencies.
101
* Package managers often contain out-of-date `golang` packages.
Jeromy's avatar
Jeromy committed
102
  Ensure that `go version` reports at least 1.5.2. See above for how to install go.
103
* If you are interested in development, please install the development
Jeromy's avatar
Jeromy committed
104
dependencies as well.
Richard Littauer's avatar
Richard Littauer committed
105
* *WARNING: Older versions of OSX FUSE (for Mac OS X) can cause kernel panics when mounting!*
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
106
  We strongly recommend you use the [latest version of OSX FUSE](http://osxfuse.github.io/).
107
  (See https://github.com/ipfs/go-ipfs/issues/177)
Richard Littauer's avatar
Richard Littauer committed
108
* For more details on setting up FUSE (so that you can mount the filesystem), see the docs folder.
109
* Shell command completion is available in `misc/completion/ipfs-completion.bash`. Read [docs/command-completion.md](docs/command-completion.md) to learn how to install it.
110
* See the [init examples](https://github.com/ipfs/examples/tree/master/examples/init) for how to connect IPFS to systemd or whatever init system your distro uses.
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
111

Richard Littauer's avatar
Richard Littauer committed
112 113 114 115 116 117 118 119
### Development Dependencies

If you make changes to the protocol buffers, you will need to install the [protoc compiler](https://github.com/google/protobuf).

## Updating
IPFS has an updating tool that can be accessed through `ipfs update`. The tool is
not installed alongside IPFS in order to keep that logic independent of the main
codebase. To install `ipfs update`, either [download it here](https://gobuilder.me/github.com/ipfs/ipfs-update)
Jeromy's avatar
Jeromy committed
120
or install it from source with `go get -u github.com/ipfs/ipfs-update`.
Chas Leichner's avatar
Chas Leichner committed
121

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
122 123 124
## Usage

```
drathir's avatar
drathir committed
125 126
USAGE:

127 128 129 130
    ipfs - global p2p merkle-dag filesystem

    ipfs [<flags>] <command> [<arg>] ...

drathir's avatar
drathir committed
131
    BASIC COMMANDS
132

133
        init          Initialize ipfs local configuration
Richard Littauer's avatar
Richard Littauer committed
134
        add <path>    Add an object to ipfs
135
        cat <ref>     Show ipfs object data
drathir's avatar
drathir committed
136
        get <ref>     Download ipfs objects
137
        ls <ref>      List links from an object
drathir's avatar
drathir committed
138
        refs <ref>    List hashes of links from an object
139

drathir's avatar
drathir committed
140
    DATA STRUCTURE COMMANDS
141

drathir's avatar
drathir committed
142 143 144
        block         Interact with raw blocks in the datastore
        object        Interact with raw dag nodes
        file          Interact with Unix filesystem objects
145

drathir's avatar
drathir committed
146
    ADVANCED COMMANDS
147

148 149
        daemon        Start a long-running daemon process
        mount         Mount an ipfs read-only mountpoint
drathir's avatar
drathir committed
150 151 152 153 154
        resolve       Resolve any type of name
        name          Publish or resolve IPNS names
        dns           Resolve DNS links
        pin           Pin objects to local storage
        repo gc       Garbage collect unpinned objects
155

drathir's avatar
drathir committed
156
    NETWORK COMMANDS
157

drathir's avatar
drathir committed
158 159 160
        id            Show info about ipfs peers
        bootstrap     Add or remove bootstrap peers
        swarm         Manage connections to the p2p network
Richard Littauer's avatar
Richard Littauer committed
161
        dht           Query the DHT for values or peers
drathir's avatar
drathir committed
162
        ping          Measure the latency of a connection
163
        diag          Print diagnostics
164

drathir's avatar
drathir committed
165
    TOOL COMMANDS
166

drathir's avatar
drathir committed
167 168 169 170
        config        Manage configuration
        version       Show ipfs version information
        update        Download and apply go-ipfs updates
        commands      List all available commands
171

drathir's avatar
drathir committed
172
    Use 'ipfs <command> --help' to learn more about each command.
173 174


Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
175
```
176

177
## Getting Started
178 179 180

See also: http://ipfs.io/docs/getting-started/

Richard Littauer's avatar
Richard Littauer committed
181
To start using IPFS, you must first initialize IPFS's config files on your
182
system, this is done with `ipfs init`. See `ipfs init --help` for information on
Jeromy's avatar
Jeromy committed
183 184
the optional arguments it takes. After initialization is complete, you can use
`ipfs mount`, `ipfs add` and any of the other commands to explore!
185

Jeromy's avatar
Jeromy committed
186 187 188 189 190 191 192 193 194
### Some things to try

Basic proof of 'ipfs working' locally:

	echo "hello world" > hello
	ipfs add hello
	# This should output a hash string that looks something like:
	# QmT78zSuBmuS4z925WZfrqQ1qHaJ56DQaTfyMUF7F8ff5o
	ipfs cat <that hash>
195

Jeromy's avatar
Jeromy committed
196

197 198
### Docker usage

199
An IPFS docker image is hosted at [hub.docker.com/r/ipfs/go-ipfs](https://hub.docker.com/r/ipfs/go-ipfs/).
200
To make files visible inside the container you need to mount a host directory
201
with the `-v` option to docker. Choose a directory that you want to use to
Richard Littauer's avatar
Richard Littauer committed
202 203
import/export files from IPFS. You should also choose a directory to store
IPFS files that will persist when you restart the container.
204 205 206

    export ipfs_staging=</absolute/path/to/somewhere/>
    export ipfs_data=</absolute/path/to/somewhere_else/>
Richard Littauer's avatar
Richard Littauer committed
207

208
Make sure docker can access these folders:
209 210 211

    sudo chmod -R 777 /absolute/path/to/somewhere/
    sudo chmod -R 777 /absolute/path/to/somewhere_else/
212

213 214
Start a container running ipfs and expose ports 4001, 5001 and 8080:

215
    docker run -d --name ipfs_host -v $ipfs_staging:/export -v $ipfs_data:/data/ipfs -p 8080:8080 -p 4001:4001 -p 5001:5001 ipfs/go-ipfs:latest
216

Michael Lovci's avatar
Michael Lovci committed
217 218 219
Watch the ipfs log:

    docker logs -f ipfs_host
220

221 222 223
Wait for ipfs to start. ipfs is running when you see:

    Gateway (readonly) server
Michael Lovci's avatar
Michael Lovci committed
224
    listening on /ip4/0.0.0.0/tcp/8080
225

Richard Littauer's avatar
Richard Littauer committed
226
You can now stop watching the log.
227

228 229 230 231 232
Run ipfs commands:

    docker exec ipfs_host ipfs <args...>

For example: connect to peers
233

234
    docker exec ipfs_host ipfs swarm peers
235

236 237 238 239
Add files:

    cp -r <something> $ipfs_staging
    docker exec ipfs_host ipfs add -r /export/<something>
240

241 242 243
Stop the running container:

    docker stop ipfs_host
244

245 246
#### Docker usage with VirtualBox/boot2docker (OSX and Windows)

247
Since docker is running in the boot2docker VM, you need to forward
Richard Littauer's avatar
Richard Littauer committed
248
relevant ports from the VM to your host for IPFS to act normally. This is
249 250 251 252
accomplished with the following command:

    boot2docker ssh -L 5001:localhost:5001 -L 4001:localhost:4001 -L 8080:localhost:8080 -fN

Jeromy's avatar
Jeromy committed
253
### Troubleshooting
Richard Littauer's avatar
Richard Littauer committed
254
If you have previously installed IPFS before and you are running into
Jeromy's avatar
Jeromy committed
255
problems getting a newer version to work, try deleting (or backing up somewhere
Richard Littauer's avatar
Richard Littauer committed
256
else) your IPFS config directory (~/.ipfs by default) and rerunning `ipfs init`.
Jeromy's avatar
Jeromy committed
257 258
This will reinitialize the config file to its defaults and clear out the local
datastore of any bad entries.
259

260
For any other problems, check the [issues list](https://github.com/ipfs/go-ipfs/issues)
Jeromy's avatar
Jeromy committed
261 262 263
and if you dont see your problem there, either come talk to us on irc (freenode #ipfs) or
file an issue of your own!

264 265
## Contributing

Richard Littauer's avatar
Richard Littauer committed
266
Please see [Contribute.md](contribute.md)!
267

268 269
## Todo

Richard Littauer's avatar
Richard Littauer committed
270
An IPFS alpha version has been released in February 2015. Things left to be done are all marked as [issues](https://github.com/ipfs/go-ipfs/issues).
271 272 273 274

## License

MIT