2017-01-09 18:01:50 -05:00
# Installing LBRY
2015-08-20 11:27:15 -04:00
2019-10-06 02:45:43 +02:00
If only the JSON-RPC API server is needed, the recommended way to install LBRY is to use a pre-built binary. We provide binaries for all major operating systems. See the [README ](README.md )!
2015-08-20 11:27:15 -04:00
2018-10-01 18:44:32 -04:00
These instructions are for installing LBRY from source, which is recommended if you are interested in doing development work or LBRY is not available on your operating system (godspeed, TempleOS users).
2015-08-20 11:27:15 -04:00
2018-10-29 17:01:41 -04:00
Here's a video walkthrough of this setup, which is itself hosted by the LBRY network and provided via [spee.ch ](https://github.com/lbryio/spee.ch ):
2018-10-17 10:57:10 -04:00
[![Setup for development ](https://spee.ch/2018-10-04-17-13-54-017046806.png )](https://spee.ch/967f99344308f1e90f0620d91b6c93e4dfb240e0/lbrynet-dev-setup.mp4)
2017-01-09 18:01:50 -05:00
## Prerequisites
2015-08-20 11:27:15 -04:00
2021-07-07 13:23:08 -05:00
Running `lbrynet` from source requires Python 3.7. Get the installer for your OS [here ](https://www.python.org/downloads/release/python-370/ ).
2018-10-17 10:57:10 -04:00
2021-07-07 13:23:08 -05:00
After installing Python 3.7, you'll need to install some additional libraries depending on your operating system.
Because of [issue #2769 ](https://github.com/lbryio/lbry-sdk/issues/2769 )
at the moment the `lbrynet` daemon will only work correctly with Python 3.7.
If Python 3.8+ is used, the daemon will start but the RPC server
may not accept messages, returning the following:
```
Could not connect to daemon. Are you sure it's running?
```
2018-10-17 10:57:10 -04:00
2018-10-20 15:26:47 +03:00
### macOS
2016-05-23 15:21:47 -04:00
2018-10-20 15:26:47 +03:00
macOS users will need to install [xcode command line tools ](https://developer.xamarin.com/guides/testcloud/calabash/configuring/osx/install-xcode-command-line-tools/ ) and [homebrew ](http://brew.sh/ ).
2016-05-23 15:21:47 -04:00
2019-10-06 02:45:43 +02:00
These environment variables also need to be set:
2021-07-11 17:57:36 -05:00
```
PYTHONUNBUFFERED=1
EVENT_NOKQUEUE=1
```
2019-05-16 19:14:50 +05:30
2017-01-09 18:01:50 -05:00
Remaining dependencies can then be installed by running:
2016-09-22 10:19:28 -07:00
```
2019-03-11 12:57:33 -04:00
brew install python protobuf
2016-09-22 10:19:28 -07:00
```
2019-10-06 02:45:43 +02:00
Assistance installing Python3: https://docs.python-guide.org/starting/install3/osx/.
2019-03-11 12:57:33 -04:00
2018-10-17 10:57:10 -04:00
### Linux
2016-09-22 10:19:28 -07:00
2021-07-07 13:23:08 -05:00
On Ubuntu (we recommend 18.04 or 20.04), install the following:
2017-01-09 18:01:50 -05:00
```
2019-06-25 13:49:54 -04:00
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt-get update
sudo apt-get install build-essential python3.7 python3.7-dev git python3.7-venv libssl-dev python-protobuf
2017-01-09 18:01:50 -05:00
```
2016-01-26 22:52:55 -05:00
2021-07-19 14:15:21 -04:00
The [deadsnakes PPA ](https://launchpad.net/~deadsnakes/+archive/ubuntu/ppa ) provides Python 3.7
2021-07-07 13:23:08 -05:00
for those Ubuntu distributions that no longer have it in their
official repositories.
2017-06-01 14:23:57 -04:00
On Raspbian, you will also need to install `python-pyparsing` .
2018-10-29 17:01:41 -04:00
If you're running another Linux distro, install the equivalent of the above packages for your system.
2016-09-22 10:19:28 -07:00
2017-01-09 18:01:50 -05:00
## Installation
2019-06-25 13:49:54 -04:00
### Linux/Mac
2021-07-11 17:57:36 -05:00
Clone the repository:
2021-07-19 14:20:15 -04:00
```bash
git clone https://github.com/lbryio/lbry-sdk.git
cd lbry-sdk
2021-07-11 17:57:36 -05:00
```
Create a Python virtual environment for lbry-sdk:
2021-07-19 14:20:15 -04:00
```bash
python3.7 -m venv lbry-venv
2021-07-11 17:57:36 -05:00
```
2017-01-09 18:01:50 -05:00
2021-07-11 17:57:36 -05:00
Activate virtual environment:
2021-07-19 14:20:15 -04:00
```bash
source lbry-venv/bin/activate
2021-07-11 17:57:36 -05:00
```
2018-10-29 17:01:41 -04:00
2021-07-11 17:57:36 -05:00
Make sure you're on Python 3.7+ as default in the virtual environment:
2021-07-19 14:20:15 -04:00
```bash
python --version
2021-07-11 17:57:36 -05:00
```
2019-06-25 13:49:54 -04:00
2021-07-11 17:57:36 -05:00
Install packages:
2021-07-19 14:20:15 -04:00
```bash
make install
2021-07-11 17:57:36 -05:00
```
2019-06-25 13:49:54 -04:00
2021-07-11 17:57:36 -05:00
If you are on Linux and using PyCharm, generates initial configs:
2021-07-19 14:20:15 -04:00
```bash
make idea
2021-07-11 17:57:36 -05:00
```
2019-06-25 13:49:54 -04:00
2021-07-07 11:02:34 -05:00
To verify your installation, `which lbrynet` should return a path inside
of the `lbry-venv` folder.
2021-07-19 14:20:15 -04:00
```bash
2021-07-11 17:57:36 -05:00
(lbry-venv) $ which lbrynet
/opt/lbry-sdk/lbry-venv/bin/lbrynet
```
2021-07-07 11:02:34 -05:00
To exit the virtual environment simply use the command `deactivate` .
2019-06-25 13:49:54 -04:00
### Windows
2018-10-01 18:44:32 -04:00
2021-07-11 17:57:36 -05:00
Clone the repository:
2021-07-19 14:20:15 -04:00
```bash
git clone https://github.com/lbryio/lbry-sdk.git
cd lbry-sdk
2021-07-11 17:57:36 -05:00
```
2018-10-01 18:44:32 -04:00
2021-07-11 17:57:36 -05:00
Create a Python virtual environment for lbry-sdk:
2021-07-19 14:20:15 -04:00
```bash
python -m venv lbry-venv
2021-07-11 17:57:36 -05:00
```
2019-06-25 13:49:54 -04:00
2021-07-11 17:57:36 -05:00
Activate virtual environment:
2021-07-19 14:20:15 -04:00
```bash
lbry-venv\Scripts\activate
2021-07-11 17:57:36 -05:00
```
2019-06-25 13:49:54 -04:00
2021-07-11 17:57:36 -05:00
Install packages:
2021-07-19 14:20:15 -04:00
```bash
pip install -e .
2021-07-11 17:57:36 -05:00
```
2018-10-17 10:57:10 -04:00
## Run the tests
2021-05-12 05:27:51 -03:00
### Elasticsearch
For running integration tests, Elasticsearch is required to be available at localhost:9200/
The easiest way to start it is using docker with:
```bash
make elastic-docker
```
2021-07-11 17:57:36 -05:00
Alternative installation methods are available [at Elasticsearch website ](https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html ).
2019-06-25 13:49:54 -04:00
2021-05-12 05:30:26 -03:00
To run the unit and integration tests from the repo directory:
2021-07-11 17:57:36 -05:00
```
python -m unittest discover tests.unit
python -m unittest discover tests.integration
```
2016-01-26 22:52:55 -05:00
2018-10-17 10:57:10 -04:00
## Usage
2018-10-01 18:44:32 -04:00
To start the API server:
2021-07-07 11:02:34 -05:00
```
lbrynet start
```
Whenever the code inside [lbry-sdk/lbry ](./lbry )
is modified we should run `make install` to recompile the `lbrynet`
executable with the newest code.
2017-01-21 11:13:55 -05:00
2021-07-07 11:02:34 -05:00
## Development
When developing, remember to enter the environment,
and if you wish start the server interactively.
2021-07-19 14:20:15 -04:00
```bash
2021-07-07 11:02:34 -05:00
$ source lbry-venv/bin/activate
(lbry-venv) $ python lbry/extras/cli.py start
```
Parameters can be passed in the same way.
2021-07-19 14:20:15 -04:00
```bash
2021-07-07 11:02:34 -05:00
(lbry-venv) $ python lbry/extras/cli.py wallet balance
```
If a Python debugger (`pdb` or `ipdb` ) is installed we can also start it
in this way, set up break points, and step through the code.
2021-07-19 14:20:15 -04:00
```bash
2021-07-07 11:02:34 -05:00
(lbry-venv) $ pip install ipdb
(lbry-venv) $ ipdb lbry/extras/cli.py
```
2018-03-21 08:25:24 -04:00
Happy hacking!