Merge pull request #502 from nspcc-dev/docker-compose-environment-for-neo-go

Create docker-compose environment
This commit is contained in:
Roman Khimov 2019-11-18 17:21:11 +03:00 committed by GitHub
commit 5076704019
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 193 additions and 108 deletions

View file

@ -82,10 +82,11 @@ jobs:
working_directory: /go/src/github.com/CityOfZion/neo-go working_directory: /go/src/github.com/CityOfZion/neo-go
executor: go1_12 executor: go1_12
docker: docker:
- image: alpine - image: golang:1-alpine
steps: steps:
- run: apk update && apk add git make curl tar - run: apk update && apk add git make curl tar
- checkout - checkout
- gomod
- setup_remote_docker - setup_remote_docker
- run: - run:
name: Install Docker client name: Install Docker client

View file

@ -0,0 +1,75 @@
version: '2.4'
networks:
neo_go_network:
name: neo_go_network
ipam:
config:
- subnet: 172.200.0.0/24
gateway: 172.200.0.254
volumes:
volume_chain:
driver: local
services:
node_one:
container_name: neo_go_node_one
image: env_neo_go_image
command: "node --config-path /config --privnet"
volumes:
- ../config/protocol.privnet.docker.one.yml:/config/protocol.privnet.yml
- volume_chain:/chains
networks:
neo_go_network:
ipv4_address: 172.200.0.1
ports:
- 20331:20331
- 20341:20341
- 20351:20351
node_two:
container_name: neo_go_node_two
image: env_neo_go_image
command: "node --config-path /config --privnet"
volumes:
- ../config/protocol.privnet.docker.two.yml:/config/protocol.privnet.yml
- volume_chain:/chains
networks:
neo_go_network:
ipv4_address: 172.200.0.2
ports:
- 20332:20332
- 20342:20342
- 20352:20352
node_three:
container_name: neo_go_node_three
image: env_neo_go_image
command: "node --config-path /config --privnet"
volumes:
- ../config/protocol.privnet.docker.three.yml:/config/protocol.privnet.yml
- volume_chain:/chains
networks:
neo_go_network:
ipv4_address: 172.200.0.3
ports:
- 20333:20333
- 20343:20343
- 20353:20353
node_four:
container_name: neo_go_node_four
image: env_neo_go_image
command: "node --config-path /config --privnet"
volumes:
- ../config/protocol.privnet.docker.four.yml:/config/protocol.privnet.yml
- volume_chain:/chains
networks:
neo_go_network:
ipv4_address: 172.200.0.4
ports:
- 20334:20334
- 20344:20344
- 20354:20354
depends_on:
- node_one
- node_two
- node_three

View file

@ -1,5 +1,5 @@
# Builder image # Builder image
FROM golang:1.12-alpine3.10 as builder FROM golang:1-alpine as builder
RUN set -x \ RUN set -x \
&& apk add --no-cache git \ && apk add --no-cache git \
@ -19,20 +19,16 @@ RUN set -x \
&& export GO111MODULE=on \ && export GO111MODULE=on \
&& export CGO_ENABLED=0 \ && export CGO_ENABLED=0 \
&& export LDFLAGS="-X ${REPO}/config.Version=${VERSION}" \ && export LDFLAGS="-X ${REPO}/config.Version=${VERSION}" \
&& go mod tidy -v \ && go build -v -mod=vendor -ldflags "${LDFLAGS}" -o /go/bin/neo-go ./cli
&& go mod vendor \
&& go build -v -mod=vendor -ldflags "${LDFLAGS}" -o /go/bin/neo-go ./cli/main.go
# Executable image # Executable image
FROM alpine:3.10 FROM scratch
ENV NETMODE=testnet
ARG VERSION ARG VERSION
LABEL version=$VERSION LABEL version=$VERSION
WORKDIR / WORKDIR /
ENV NETMODE=testnet
COPY --from=builder /neo-go/config /config COPY --from=builder /neo-go/config /config
COPY --from=builder /go/bin/neo-go /usr/bin/neo-go COPY --from=builder /go/bin/neo-go /usr/bin/neo-go
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/

View file

@ -8,6 +8,8 @@ BINDIR = "/usr/bin"
SYSTEMDUNIT_DIR = "/lib/systemd/system" SYSTEMDUNIT_DIR = "/lib/systemd/system"
UNITWORKDIR = "/var/lib/neo-go" UNITWORKDIR = "/var/lib/neo-go"
DC_FILE=.docker/docker-compose.yml
REPO ?= "$(shell go list -m)" REPO ?= "$(shell go list -m)"
VERSION ?= "$(shell git describe --tags 2>/dev/null | sed 's/^v//')" VERSION ?= "$(shell git describe --tags 2>/dev/null | sed 's/^v//')"
BUILD_FLAGS = "-X $(REPO)/config.Version=$(VERSION)" BUILD_FLAGS = "-X $(REPO)/config.Version=$(VERSION)"
@ -44,7 +46,7 @@ postinst: install
&& chown -R neo-go:neo-go $(UNITWORKDIR) $(BINDIR)/neo-go \ && chown -R neo-go:neo-go $(UNITWORKDIR) $(BINDIR)/neo-go \
&& systemctl enable neo-go.service && systemctl enable neo-go.service
image: image: deps
@echo "=> Building image" @echo "=> Building image"
@docker build -t cityofzion/neo-go:latest --build-arg REPO=$(REPO) --build-arg VERSION=$(VERSION) . @docker build -t cityofzion/neo-go:latest --build-arg REPO=$(REPO) --build-arg VERSION=$(VERSION) .
@docker build -t cityofzion/neo-go:$(VERSION) --build-arg REPO=$(REPO) --build-arg VERSION=$(VERSION) . @docker build -t cityofzion/neo-go:$(VERSION) --build-arg REPO=$(REPO) --build-arg VERSION=$(VERSION) .
@ -52,12 +54,6 @@ image:
check-version: check-version:
git fetch && (! git rev-list ${VERSION}) git fetch && (! git rev-list ${VERSION})
clean-cluster:
@echo "=> Removing all containers and chain storage"
@rm -rf chains/privnet-docker-one chains/privnet-docker-two chains/privnet-docker-three chains/privnet-docker-four
@docker-compose stop
@docker-compose rm -f
deps: deps:
@go mod tidy -v @go mod tidy -v
@go mod vendor @go mod vendor
@ -77,14 +73,6 @@ push-to-registry:
run: build run: build
${BINARY} node -config-path ./config -${NETMODE} ${BINARY} node -config-path ./config -${NETMODE}
run-cluster: build-linux
@echo "=> Starting docker-compose cluster"
@echo "=> Building container image"
@docker-compose build
@docker-compose up -d
@echo "=> Tailing logs, exiting this prompt will not stop the cluster"
@docker-compose logs -f
test: test:
@go test ./... -cover @go test ./... -cover
@ -100,3 +88,30 @@ fmt:
cover: cover:
@go test -v -race ./... -coverprofile=coverage.txt -covermode=atomic @go test -v -race ./... -coverprofile=coverage.txt -covermode=atomic
@go tool cover -html=coverage.txt -o coverage.html @go tool cover -html=coverage.txt -o coverage.html
# --- Environment ---
env_vendor:
@echo "=> Update vendor"
@go mod tidy
@go mod download
@go mod vendor
env_image: env_vendor
@echo "=> Building env image"
@docker build \
-t env_neo_go_image \
--build-arg REPO=$(REPO) \
--build-arg VERSION=$(VERSION) .
env_up:
@echo "=> Bootup environment"
@docker-compose -f $(DC_FILE) up -d node_four
env_down:
@echo "=> Stop and cleanup environment"
@docker-compose -f $(DC_FILE) down
env_restart:
@echo "=> Stop and cleanup environment"
@docker-compose -f $(DC_FILE) restart

View file

@ -1,15 +1,18 @@
ProtocolConfiguration: ProtocolConfiguration:
Magic: 56753 Magic: 56753
AddressVersion: 23 AddressVersion: 23
SecondsPerBlock: 15
LowPriorityThreshold: 0.000
StandbyValidators: StandbyValidators:
- 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2 - 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2
- 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e - 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e
- 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699 - 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699
- 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62 - 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62
SeedList: SeedList:
- node_one:20334 - 172.20.0.1:20331
- node_two:20335 - 172.20.0.2:20332
- node_three:20336 - 172.20.0.3:20333
- 172.20.0.4:20334
SystemFee: SystemFee:
EnrollmentTransaction: 1000 EnrollmentTransaction: 1000
IssueTransaction: 500 IssueTransaction: 500
@ -25,7 +28,7 @@ ApplicationConfiguration:
Type: "leveldb" #other options: 'inmemory','redis','boltdb'. Type: "leveldb" #other options: 'inmemory','redis','boltdb'.
# DB type options. Uncomment those you need in case you want to switch DB type. # DB type options. Uncomment those you need in case you want to switch DB type.
LevelDBOptions: LevelDBOptions:
DataDirectoryPath: "./chains/privnet" DataDirectoryPath: "/chains/four"
# RedisDBOptions: # RedisDBOptions:
# Addr: "localhost:6379" # Addr: "localhost:6379"
# Password: "" # Password: ""
@ -34,7 +37,7 @@ ApplicationConfiguration:
# FilePath: "./chains/privnet.bolt" # FilePath: "./chains/privnet.bolt"
# Uncomment in order to set up custom address for node. # Uncomment in order to set up custom address for node.
# Address: 127.0.0.1 # Address: 127.0.0.1
NodePort: 20337 NodePort: 20334
Relay: true Relay: true
DialTimeout: 3 DialTimeout: 3
ProtoTickInterval: 2 ProtoTickInterval: 2
@ -44,7 +47,10 @@ ApplicationConfiguration:
RPC: RPC:
Enabled: true Enabled: true
EnableCORSWorkaround: false EnableCORSWorkaround: false
Port: 20336 Port: 20344
Monitoring: Monitoring:
Enabled: true Enabled: true
Port: 2112 Port: 20354
UnlockWallet:
Path: "6PYRXVwHSqFSukL3CuXxdQ75VmsKpjeLgQLEjt83FrtHf1gCVphHzdD4nc"
Password: "four"

View file

@ -1,12 +1,18 @@
ProtocolConfiguration: ProtocolConfiguration:
Magic: 56753 Magic: 56753
AddressVersion: 23 AddressVersion: 23
SecondsPerBlock: 15
LowPriorityThreshold: 0.000
StandbyValidators: StandbyValidators:
- 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2 - 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2
- 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e - 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e
- 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699 - 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699
- 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62 - 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62
SeedList: [] SeedList:
- 172.200.0.1:20331
- 172.200.0.2:20332
- 172.200.0.3:20333
- 172.200.0.4:20334
SystemFee: SystemFee:
EnrollmentTransaction: 1000 EnrollmentTransaction: 1000
IssueTransaction: 500 IssueTransaction: 500
@ -22,7 +28,7 @@ ApplicationConfiguration:
Type: "leveldb" #other options: 'inmemory','redis','boltdb'. Type: "leveldb" #other options: 'inmemory','redis','boltdb'.
# DB type options. Uncomment those you need in case you want to switch DB type. # DB type options. Uncomment those you need in case you want to switch DB type.
LevelDBOptions: LevelDBOptions:
DataDirectoryPath: "./chains/privnet" DataDirectoryPath: "/chains/one"
# RedisDBOptions: # RedisDBOptions:
# Addr: "localhost:6379" # Addr: "localhost:6379"
# Password: "" # Password: ""
@ -31,7 +37,7 @@ ApplicationConfiguration:
# FilePath: "./chains/privnet.bolt" # FilePath: "./chains/privnet.bolt"
# Uncomment in order to set up custom address for node. # Uncomment in order to set up custom address for node.
# Address: 127.0.0.1 # Address: 127.0.0.1
NodePort: 20334 NodePort: 20331
Relay: true Relay: true
DialTimeout: 3 DialTimeout: 3
ProtoTickInterval: 2 ProtoTickInterval: 2
@ -41,7 +47,10 @@ ApplicationConfiguration:
RPC: RPC:
Enabled: true Enabled: true
EnableCORSWorkaround: false EnableCORSWorkaround: false
Port: 20333 Port: 20341
Monitoring: Monitoring:
Enabled: true Enabled: true
Port: 2112 Port: 20351
UnlockWallet:
Path: "6PYLmjBYJ4wQTCEfqvnznGJwZeW9pfUcV5m5oreHxqryUgqKpTRAFt9L8Y"
Password: "one"

View file

@ -1,12 +1,18 @@
ProtocolConfiguration: ProtocolConfiguration:
Magic: 56753 Magic: 56753
AddressVersion: 23 AddressVersion: 23
SecondsPerBlock: 15
LowPriorityThreshold: 0.000
StandbyValidators: StandbyValidators:
- 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2 - 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2
- 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e - 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e
- 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699 - 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699
- 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62 - 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62
SeedList: [] SeedList:
- 172.200.0.1:20331
- 172.200.0.2:20332
- 172.200.0.3:20333
- 172.200.0.4:20334
SystemFee: SystemFee:
EnrollmentTransaction: 1000 EnrollmentTransaction: 1000
IssueTransaction: 500 IssueTransaction: 500
@ -22,7 +28,7 @@ ApplicationConfiguration:
Type: "leveldb" #other options: 'inmemory','redis','boltdb'. Type: "leveldb" #other options: 'inmemory','redis','boltdb'.
# DB type options. Uncomment those you need in case you want to switch DB type. # DB type options. Uncomment those you need in case you want to switch DB type.
LevelDBOptions: LevelDBOptions:
DataDirectoryPath: "./chains/privnet" DataDirectoryPath: "/chains/three"
# RedisDBOptions: # RedisDBOptions:
# Addr: "localhost:6379" # Addr: "localhost:6379"
# Password: "" # Password: ""
@ -31,7 +37,7 @@ ApplicationConfiguration:
# FilePath: "./chains/privnet.bolt" # FilePath: "./chains/privnet.bolt"
# Uncomment in order to set up custom address for node. # Uncomment in order to set up custom address for node.
# Address: 127.0.0.1 # Address: 127.0.0.1
NodePort: 20336 NodePort: 20333
Relay: true Relay: true
DialTimeout: 3 DialTimeout: 3
ProtoTickInterval: 2 ProtoTickInterval: 2
@ -41,7 +47,10 @@ ApplicationConfiguration:
RPC: RPC:
Enabled: true Enabled: true
EnableCORSWorkaround: false EnableCORSWorkaround: false
Port: 20335 Port: 20343
Monitoring: Monitoring:
Enabled: true Enabled: true
Port: 2112 Port: 20353
UnlockWallet:
Path: "6PYX86vYiHfUbpD95hfN1xgnvcSxy5skxfWYKu3ztjecxk6ikYs2kcWbeh"
Password: "three"

View file

@ -1,12 +1,18 @@
ProtocolConfiguration: ProtocolConfiguration:
Magic: 56753 Magic: 56753
AddressVersion: 23 AddressVersion: 23
SecondsPerBlock: 15
LowPriorityThreshold: 0.000
StandbyValidators: StandbyValidators:
- 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2 - 02b3622bf4017bdfe317c58aed5f4c753f206b7db896046fa7d774bbc4bf7f8dc2
- 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e - 02103a7f7dd016558597f7960d27c516a4394fd968b9e65155eb4b013e4040406e
- 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699 - 03d90c07df63e690ce77912e10ab51acc944b66860237b608c4f8f8309e71ee699
- 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62 - 02a7bc55fe8684e0119768d104ba30795bdcc86619e864add26156723ed185cd62
SeedList: [] SeedList:
- 172.200.0.1:20331
- 172.200.0.2:20332
- 172.200.0.3:20333
- 172.200.0.4:20334
SystemFee: SystemFee:
EnrollmentTransaction: 1000 EnrollmentTransaction: 1000
IssueTransaction: 500 IssueTransaction: 500
@ -22,7 +28,7 @@ ApplicationConfiguration:
Type: "leveldb" #other options: 'inmemory','redis','boltdb'. Type: "leveldb" #other options: 'inmemory','redis','boltdb'.
# DB type options. Uncomment those you need in case you want to switch DB type. # DB type options. Uncomment those you need in case you want to switch DB type.
LevelDBOptions: LevelDBOptions:
DataDirectoryPath: "./chains/privnet" DataDirectoryPath: "/chains/two"
# RedisDBOptions: # RedisDBOptions:
# Addr: "localhost:6379" # Addr: "localhost:6379"
# Password: "" # Password: ""
@ -31,7 +37,7 @@ ApplicationConfiguration:
# FilePath: "./chains/privnet.bolt" # FilePath: "./chains/privnet.bolt"
# Uncomment in order to set up custom address for node. # Uncomment in order to set up custom address for node.
# Address: 127.0.0.1 # Address: 127.0.0.1
NodePort: 20335 NodePort: 20332
Relay: true Relay: true
DialTimeout: 3 DialTimeout: 3
ProtoTickInterval: 2 ProtoTickInterval: 2
@ -41,7 +47,10 @@ ApplicationConfiguration:
RPC: RPC:
Enabled: true Enabled: true
EnableCORSWorkaround: false EnableCORSWorkaround: false
Port: 20334 Port: 20342
Monitoring: Monitoring:
Enabled: true Enabled: true
Port: 2112 Port: 20352
UnlockWallet:
Path: "6PYXHjPaNvW8YknSXaKsTWjf9FRxo1s4naV2jdmSQEgzaqKGX368rndN3L"
Password: "two"

View file

@ -1,38 +0,0 @@
version: '3'
services:
node_one:
build: .
volumes:
- ./config/protocol.privnet.docker.one.yml:/config/protocol.privnet.yml
- ./chains/privnet-docker-one:/chains/privnet
ports:
- 20334:20334
command: "node --config-path /config --privnet"
node_two:
build: .
volumes:
- ./config/protocol.privnet.docker.two.yml:/config/protocol.privnet.yml
- ./chains/privnet-docker-two:/chains/privnet
ports:
- 20335:20335
command: "node --config-path /config --privnet"
node_three:
build: .
volumes:
- ./config/protocol.privnet.docker.three.yml:/config/protocol.privnet.yml
- ./chains/privnet-docker-three:/chains/privnet
ports:
- 20336:20336
command: "node --config-path /config --privnet"
node_four:
build: .
volumes:
- ./config/protocol.privnet.docker.four.yml:/config/protocol.privnet.yml
- ./chains/privnet-docker-four:/chains/privnet
ports:
- 20337:20337
command: "node --config-path /config --privnet"
depends_on:
- node_one
- node_two
- node_three

View file

@ -1,9 +1,10 @@
package network package network
import ( import (
"crypto/rand"
"encoding/binary"
"errors" "errors"
"fmt" "fmt"
"math/rand"
"net" "net"
"strconv" "strconv"
"sync" "sync"
@ -68,13 +69,19 @@ type (
} }
) )
func randomID() uint32 {
buf := make([]byte, 4)
_, _ = rand.Read(buf)
return binary.BigEndian.Uint32(buf)
}
// NewServer returns a new Server, initialized with the given configuration. // NewServer returns a new Server, initialized with the given configuration.
func NewServer(config ServerConfig, chain core.Blockchainer) *Server { func NewServer(config ServerConfig, chain core.Blockchainer) *Server {
s := &Server{ s := &Server{
ServerConfig: config, ServerConfig: config,
chain: chain, chain: chain,
bQueue: newBlockQueue(maxBlockBatch, chain), bQueue: newBlockQueue(maxBlockBatch, chain),
id: rand.Uint32(), id: randomID(),
quit: make(chan struct{}), quit: make(chan struct{}),
addrReq: make(chan *Message, config.MinPeers), addrReq: make(chan *Message, config.MinPeers),
register: make(chan Peer), register: make(chan Peer),
@ -536,7 +543,3 @@ func (s *Server) RelayDirectly(p Peer, inv *payload.Inventory) {
p.WriteMsg(NewMessage(s.Net, CMDInv, inv)) p.WriteMsg(NewMessage(s.Net, CMDInv, inv))
} }
func init() {
rand.Seed(time.Now().UTC().UnixNano())
}