[DOCS] Improve installation instructions (#20089)
This commit is contained in:
parent
611703beb9
commit
86b20d897e
|
@ -1,7 +1,8 @@
|
||||||
---
|
---
|
||||||
title: Installing Geth
|
title: Installing Geth
|
||||||
---
|
---
|
||||||
The Go implementation of Ethereum can be installed using a variety of ways. These include obtaining it as part of Mist; installing it via your favorite package manager; downloading a standalone pre-built bundle; running as a docker container; or building it yourself. This document will detail all of these possibilities to get you quickly joining the Ethereum network using whatever means you prefer.
|
|
||||||
|
You can install the Go implementation of Ethereum using a variety of ways. These include installing it via your favorite package manager; downloading a standalone pre-built bundle; running as a docker container; or building it yourself. This document details all of the possibilities to get you joining the Ethereum network using whatever means you prefer.
|
||||||
|
|
||||||
{:toc}
|
{:toc}
|
||||||
* this will be removed by the toc
|
* this will be removed by the toc
|
||||||
|
@ -10,10 +11,10 @@ The Go implementation of Ethereum can be installed using a variety of ways. Thes
|
||||||
|
|
||||||
### Install on macOS via Homebrew
|
### Install on macOS via Homebrew
|
||||||
|
|
||||||
By far the easiest way to install go-ethereum is to use our
|
The easiest way to install go-ethereum is to use our
|
||||||
Homebrew tap. If you don't have Homebrew, [install it first](http://brew.sh).
|
Homebrew tap. If you don't have Homebrew, [install it first](http://brew.sh).
|
||||||
|
|
||||||
Then run the following commands to add the tap and install `geth`:
|
Run the following commands to add the tap and install `geth`:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
brew tap ethereum/ethereum
|
brew tap ethereum/ethereum
|
||||||
|
@ -30,65 +31,65 @@ After installing, run `geth account new` to create an account on your node.
|
||||||
|
|
||||||
You should now be able to run `geth` and connect to the network.
|
You should now be able to run `geth` and connect to the network.
|
||||||
|
|
||||||
Make sure to check the different options and commands with `geth --help`
|
Check the different options and commands with `geth --help`
|
||||||
|
|
||||||
For options and patches, see: <https://github.com/ethereum/homebrew-ethereum>
|
For options and patches, see: <https://github.com/ethereum/homebrew-ethereum>
|
||||||
|
|
||||||
|
|
||||||
### Install on Ubuntu via PPAs
|
### Install on Ubuntu via PPAs
|
||||||
|
|
||||||
The simplest way to install go-ethereum on Ubuntu distributions is via the built in launchpad PPAs (Personal Package Archives). We provide a single PPA repository that contains both our stable as well as our develop releases for Ubuntu versions `trusty`, `xenial`, `zesty` and `artful`.
|
The easiest way to install go-ethereum on Ubuntu-based distributions is with the built in launchpad PPAs (Personal Package Archives). We provide a single PPA repository that contains both our stable and develop releases for Ubuntu versions `trusty`, `xenial`, `zesty` and `artful`.
|
||||||
|
|
||||||
To enable our launchpad repository please run:
|
To enable our launchpad repository run:
|
||||||
|
|
||||||
```
|
```shell
|
||||||
sudo add-apt-repository -y ppa:ethereum/ethereum
|
sudo add-apt-repository -y ppa:ethereum/ethereum
|
||||||
```
|
```
|
||||||
|
|
||||||
After that you can install the stable version of Go Ethereum:
|
Then install the stable version of go-ethereum:
|
||||||
|
|
||||||
```
|
```shell
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install ethereum
|
sudo apt-get install ethereum
|
||||||
```
|
```
|
||||||
|
|
||||||
Or the develop version via:
|
Or the develop version via:
|
||||||
|
|
||||||
```
|
```shell
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install ethereum-unstable
|
sudo apt-get install ethereum-unstable
|
||||||
```
|
```
|
||||||
|
|
||||||
### Installing on FreeBSD via `pkg`
|
### Install on FreeBSD via `pkg`
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
pkg install go-ethereum
|
pkg install go-ethereum
|
||||||
```
|
```
|
||||||
|
|
||||||
The `geth` command is then available on your system in `/usr/local/bin/geth`, you can start it e.g. on the testnet by typing:
|
The `geth` command is then available on your system in `/usr/local/bin/geth`, you can start it on the testnet (for example) by using:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
geth -rinkeby
|
geth -rinkeby
|
||||||
```
|
```
|
||||||
|
|
||||||
### Installing on FreeBSD via ports
|
### Install on FreeBSD via ports
|
||||||
|
|
||||||
Go to the `net-p2p/go-ethereum` ports directory:
|
Go to the `net-p2p/go-ethereum` ports directory:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
cd /usr/ports/net-p2p/go-ethereum
|
cd /usr/ports/net-p2p/go-ethereum
|
||||||
```
|
```
|
||||||
|
|
||||||
Then build it the standard way (as root):
|
Then build it the standard way (as root):
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
make install
|
make install
|
||||||
```
|
```
|
||||||
|
|
||||||
### Installing on Arch Linux via `pacman`
|
### Install on Arch Linux via `pacman`
|
||||||
|
|
||||||
The `geth` package is available from the [community repo](https://www.archlinux.org/packages/community/x86_64/geth/).
|
The `geth` package is available from the [community repo](https://www.archlinux.org/packages/community/x86_64/geth/).
|
||||||
|
|
||||||
You can install it using
|
You can install it using:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
pacman -S geth
|
pacman -S geth
|
||||||
|
@ -96,69 +97,66 @@ pacman -S geth
|
||||||
|
|
||||||
## Download standalone bundle
|
## Download standalone bundle
|
||||||
|
|
||||||
All our stable releases and develop builds are distributed as standalone bundles too. These can be useful for scenarios where you'd like to: a) install a specific version of our code (e.g. for reproducible environments); b) install on machines without internet access (e.g. air gapped computers); or c) simply do not like automatic updates and would rather manually install software.
|
We distribute our stable releases and develop builds as standalone bundles. These are useful when you'd like to: a) install a specific version of our code (e.g., for reproducible environments); b) install on machines without internet access (e.g., air-gapped computers); or c) do not like automatic updates and would rather manually install software.
|
||||||
|
|
||||||
We create the following standalone bundles:
|
We create the following standalone bundles:
|
||||||
|
|
||||||
* 32bit, 64bit, ARMv5, ARMv6, ARMv7 and ARM64 archives (`.tar.gz`) on Linux
|
- 32bit, 64bit, ARMv5, ARMv6, ARMv7 and ARM64 archives (`.tar.gz`) on Linux
|
||||||
* 64bit archives (`.tar.gz`) on macOS
|
- 64bit archives (`.tar.gz`) on macOS
|
||||||
* 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows
|
- 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows
|
||||||
|
|
||||||
For all archives we provide separate ones containing only Geth, and separate ones containing Geth along with all the developer tools from our repository (`abigen`, `bootnode`, `disasm`, `evm`, `rlpdump`). Please see our [`README`](https://github.com/ethereum/go-ethereum#executables) for more information about these executables.
|
For all archives we provide separate ones containing only Geth, and separate ones containing Geth along with all the developer tools from our repository (`abigen`, `bootnode`, `disasm`, `evm`, `rlpdump`). Read our [`README`](https://github.com/ethereum/go-ethereum#executables) for more information about these executables.
|
||||||
|
|
||||||
To download these bundles, please head the [Go Ethereum Downloads](https://geth.ethereum.org/downloads) page.
|
Download these bundles from the [Go Ethereum Downloads](https://geth.ethereum.org/downloads) page.
|
||||||
|
|
||||||
## Run inside docker container
|
## Run inside Docker container
|
||||||
|
|
||||||
If you prefer containerized processes, you can run go-ethereum as a docker container too. We currently maintain four different docker images for running the latest stable or develop versions of Geth.
|
If you prefer containerized processes, you can run go-ethereum as a Docker container. We maintain four different Docker images for running the latest stable or develop versions of Geth.
|
||||||
|
|
||||||
* `ethereum/client-go:latest` is the latest develop version of Geth
|
- `ethereum/client-go:latest` is the latest develop version of Geth
|
||||||
* `ethereum/client-go:stable` is the latest stable version of Geth
|
- `ethereum/client-go:stable` is the latest stable version of Geth
|
||||||
* `ethereum/client-go:{version}` is the stable version of Geth at a specific version number
|
- `ethereum/client-go:{version}` is the stable version of Geth at a specific version number
|
||||||
* `ethereum/client-go:release-{version}` is the latest stable version of Geth at a specific version family
|
- `ethereum/client-go:release-{version}` is the latest stable version of Geth at a specific version family
|
||||||
|
|
||||||
We also maintain four different docker images for running the latest stable or develop versions of miscellaneous Ethereum tools.
|
We also maintain four different Docker images for running the latest stable or develop versions of miscellaneous Ethereum tools.
|
||||||
|
|
||||||
* `ethereum/client-go:alltools-latest` is the latest develop version of the Ethereum tools
|
- `ethereum/client-go:alltools-latest` is the latest develop version of the Ethereum tools
|
||||||
* `ethereum/client-go:alltools-stable` is the latest stable version of the Ethereum tools
|
- `ethereum/client-go:alltools-stable` is the latest stable version of the Ethereum tools
|
||||||
* `ethereum/client-go:alltools-{version}` is the stable version of the Ethereum tools at a specific version number
|
- `ethereum/client-go:alltools-{version}` is the stable version of the Ethereum tools at a specific version number
|
||||||
* `ethereum/client-go:alltools-release-{version}` is the latest stable version of the Ethereum tools at a specific version family
|
- `ethereum/client-go:alltools-release-{version}` is the latest stable version of the Ethereum tools at a specific version family
|
||||||
|
|
||||||
The image has the following ports automatically exposed:
|
The image has the following ports automatically exposed:
|
||||||
|
|
||||||
* `8545` TCP, used by the HTTP based JSON RPC API
|
- `8545` TCP, used by the HTTP based JSON RPC API
|
||||||
* `8546` TCP, used by the WebSocket based JSON RPC API
|
- `8546` TCP, used by the WebSocket based JSON RPC API
|
||||||
* `8547` TCP, used by the GraphQL API
|
- `8547` TCP, used by the GraphQL API
|
||||||
* `30303` TCP and UDP, used by the P2P protocol running the network
|
- `30303` TCP and UDP, used by the P2P protocol running the network
|
||||||
|
|
||||||
*Note, if you are running an Ethereum client inside a docker container, you might want to mount in a data volume as the client's data directory (located at `/root/.ethereum` inside the container) to ensure that downloaded data is preserved between restarts and/or container life-cycles.*
|
_Note, if you are running an Ethereum client inside a Docker container, you should mount a data volume as the client's data directory (located at `/root/.ethereum` inside the container) to ensure that downloaded data is preserved between restarts and/or container life-cycles._
|
||||||
|
|
||||||
## Build it from source code
|
## Build go-ethereum from source code
|
||||||
|
|
||||||
### Most Linux systems
|
### Most Linux systems
|
||||||
Go Ethereum (as its name implies) is written in [Go](https://golang.org), and as such to build from source code you'll need to ensure that you have the most recent version of Go. This guide will not go into details on how to install Go itself, for that please consult the [Go installation instructions](https://golang.org/doc/install) and grab any needed bundles from the [Go download page](https://golang.org/dl/).
|
|
||||||
|
|
||||||
Assuming you have Go installed, you can download our project via:
|
Go Ethereum is written in [Go](https://golang.org), so to build from source code you need the most recent version of Go. This guide doesn't cover how to install Go itself, for details read the [Go installation instructions](https://golang.org/doc/install) and grab any needed bundles from the [Go download page](https://golang.org/dl/).
|
||||||
|
|
||||||
```
|
With Go installed, you can download our project via:
|
||||||
|
|
||||||
|
```shell
|
||||||
go get -d github.com/ethereum/go-ethereum
|
go get -d github.com/ethereum/go-ethereum
|
||||||
```
|
```
|
||||||
|
|
||||||
The above command will checkout the default version of Go Ethereum into your local `GOPATH` work space, but it will not build any executables for you. To do that you can either build one specifically:
|
The above command checks out the default version of Go Ethereum into your local `GOPATH` work space, but does not build any executables. To do that you can either build one specifically:
|
||||||
|
|
||||||
```
|
```shell
|
||||||
go install github.com/ethereum/go-ethereum/cmd/geth
|
go install github.com/ethereum/go-ethereum/cmd/geth
|
||||||
```
|
```
|
||||||
|
|
||||||
Or you can also build the entire project and install `geth` along with all developer tools by running `go install ./...` in the repository root inside your `GOPATH` work space.
|
Or you can build the entire project and install `geth` along with all developer tools by running `go install ./...` in the repository root inside your `GOPATH` work space.
|
||||||
|
|
||||||
### MacOS
|
### macOS
|
||||||
|
|
||||||
If you see some errors related to header files of Mac OS system library, install XCode Command Line Tools, and try again.
|
If you see errors related to macOS header files, install XCode Command Line Tools with `xcode-select --install`, and try again.
|
||||||
|
|
||||||
```shell
|
|
||||||
xcode-select --install
|
|
||||||
```
|
|
||||||
|
|
||||||
### FreeBSD
|
### FreeBSD
|
||||||
|
|
||||||
|
@ -176,12 +174,15 @@ Building `geth` requires the Go compiler:
|
||||||
pkg install go
|
pkg install go
|
||||||
```
|
```
|
||||||
|
|
||||||
If your golang version is >= 1.5, build the `geth` program using the following command.
|
If your golang version is >= 1.5, build the `geth` program using the following command:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
cd go-ethereum
|
cd go-ethereum
|
||||||
make geth
|
make geth
|
||||||
```
|
```
|
||||||
If your golang version is < 1.5 (quarterly packages, for example), use the following command instead.
|
|
||||||
|
If your golang version is < 1.5 (quarterly packages, for example), use the following command instead:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
cd go-ethereum
|
cd go-ethereum
|
||||||
CC=clang make geth
|
CC=clang make geth
|
||||||
|
@ -189,15 +190,14 @@ CC=clang make geth
|
||||||
|
|
||||||
You can now run `build/bin/geth` to start your node.
|
You can now run `build/bin/geth` to start your node.
|
||||||
|
|
||||||
|
|
||||||
### Building without a Go workflow
|
### Building without a Go workflow
|
||||||
|
|
||||||
If you do not want to set up Go work spaces on your machine, only build `geth` and forget about the build process, you can clone our repository directly into a folder of your choosing and invoke `make`, which will configure everything for a temporary build and clean up after itself:
|
If you do not want to set up Go workspaces on your machine, only build `geth` and forget about the build process, you can clone our repository directly into a folder of your choosing and invoke `make`, which configures everything for a temporary build and cleans up afterwards. Note that this method of building only works on UNIX-like operating systems.
|
||||||
|
|
||||||
```
|
```shell
|
||||||
git clone https://github.com/ethereum/go-ethereum.git
|
git clone https://github.com/ethereum/go-ethereum.git
|
||||||
cd go-ethereum
|
cd go-ethereum
|
||||||
make geth
|
make geth
|
||||||
```
|
```
|
||||||
|
|
||||||
This will create a `geth` (or `geth.exe` on Windows) executable file in the `go-ethereum/build/bin` folder that you can move wherever you want to run from. The binary is standalone and doesn't require any additional files.
|
This creates a `geth` executable file in the `go-ethereum/build/bin` folder that you can move wherever you want to run from. The binary is standalone and doesn't require any additional files.
|
||||||
|
|
Loading…
Reference in New Issue