FrostFS local Development and Testing environment
Find a file
a.y.volkov 90463fe3f6 Update readme file.
Signed-off-by: a.y.volkov <a.y.volkov@yadro.com>
2022-06-02 09:39:44 +03:00
.github Add README and related docs 2020-09-25 16:20:34 +03:00
bin [#164] services: Do not use underscore in hostnames 2022-03-04 16:18:05 +03:00
docs [#164] services: Do not use underscore in hostnames 2022-03-04 16:18:05 +03:00
services [#177] Fixed hyphens in generate_cert.sh script 2022-05-23 13:53:39 +03:00
wallets [#76] Update neo-go and contracts to N3 testnet RC2 version 2021-05-21 14:26:43 +03:00
.basic_services [#159] Add NATS service 2022-02-11 11:21:59 +03:00
.dockerignore Initial commit 2020-07-10 18:33:27 +03:00
.editorconfig Initial commit 2020-07-10 18:33:27 +03:00
.env [#173] Update neofs-s3-gw version to v0.21.0 2022-05-13 14:15:55 +03:00
.gitignore [#165] .gitignore: Add nats-related files 2022-03-04 16:18:05 +03:00
.int_test.env Add .int_test.env files for config amendments (#167) 2022-04-07 15:33:53 +03:00
.services Make up/down for services (#155) 2022-02-04 18:27:49 +03:00
CONTRIBUTING.md Add README and related docs 2020-09-25 16:20:34 +03:00
help.mk Update documentation 2020-12-03 15:12:11 +03:00
LICENSE Initial commit 2020-07-10 18:33:27 +03:00
Makefile Add .int_test.env files for config amendments (#167) 2022-04-07 15:33:53 +03:00
neofs_config.mk [#176] Add makefile target to set homomorphic hash disabled flag 2022-05-16 15:27:21 +03:00
README.md Update readme file. 2022-06-02 09:39:44 +03:00

NeoFS

NeoFS local Development and Testing environment


Overview

Tools to set up local NeoFS network and N3 privnets. Devenv, for short.

Prerequisites

Make sure you have installed all of the following prerequisites on your machine:

  • docker
  • docker-compose
  • make
  • expect
  • openssl
  • jq
  • base64 (coreutils)

Quick Start

$ git clone https://github.com/nspcc-dev/neofs-dev-env.git
$ make get
$ make hosts

Then add make hosts command output to /etc/hosts file.

$ make up

When all services are up, you need to make GAS deposit for test wallet to be able to pay for NeoFS operations. Test wallet is located in wallets/wallet.json with the corresponding key in wallets/wallet.key. The password is empty.

$ make prepare.ir
password >
fa6ba62bffb04030d303dcc95bda7413e03aa3c7e6ca9c2f999d65db9ec9b82c

Also you should add self-signed node (s04.neofs.devenv) certificate to truststore (default location might be changed using CA_CERTS_TRUSTED_STORE variable). This step is required for client services (neofs-http-gw, neofs-s3-gw) to interact with the node:

$ sudo make prepare.storage

Change NeoFS global configuration values with make update.* commands. The password of inner ring wallet is one. See examples in make help.

$ make update.epoch_duration val=30
Changing EpochDuration configration value to 30
Enter account NNudMSGzEoktFzdYGYoNb3bzHzbmM1genF password > 
Sent invocation transaction dbb8c1145b6d10f150135630e13bb0dc282023163f5956c6945a60db0cb45cb0
Updating NeoFS epoch to 2
Enter account NNudMSGzEoktFzdYGYoNb3bzHzbmM1genF password > 
Sent invocation transaction 0e6eb5e190f36332e5e5f4e866c7e100826e285fd949e11c085e15224f343ba6

You can see the addresses and hostnames of components with make hosts command.

$ make hosts
192.168.130.10 bastion.neofs.devenv
192.168.130.50 main-chain.neofs.devenv
192.168.130.61 ir01.neofs.devenv
...
192.168.130.74 s04.neofs.devenv

It's recommended to add make hosts output to your local /etc/hosts file.

For instructions on how to set up DevEnv on macOS, please refer the guide in docs directory.

How it's organized

.
├── Makefile         # Commands to manage devenv
├── .services        # List of services to work with
├── services         # Services definitions and files
│   ├── basenet
│   ├── chain
│   ├── ir
│   ├── morph_chain
│   └── storage
├── vendor           # Temporary files and artifacts
└── wallets          # Wallet files to manage GAS assets

Main commands and targets to manage devenv's services are in Makefile.

Each service is defined in it's own directory under services/ with all required files to run and scripts to get external artifacts or dependencies.

The list of services and the starting order is defined in .services file. You can comment out services you don't want to start or add your own new services.

You can find more information on each service in docs directory.

Maybe you will find the answer for your question in F.A.Q.

Notable make targets

make help will print the brief description of available targets. Here we describe some of them in a more detailed way.

up

Start all Devenv services.

This target call pull to get container images, get to download required artifacts, vendor/hosts to generate hosts file and then starts all services in the order defined in .services file.

down

Shutdowns all services. This will destroy all containers and networks. All changes made inside containers will be lost.

hosts

Display addresses and host names for each running service, if available.

clean

Clean up vendor directory.

Contributing

Feel free to contribute to this project after reading the contributing guidelines.

Before starting to work on a certain topic, create an new issue first, describing the feature/topic you are going to implement.

License