# stage 1 Generate Tendermint Binary FROM golang:1.17-alpine as builder RUN apk update && \ apk upgrade && \ apk --no-cache add make git COPY / /tendermint WORKDIR /tendermint RUN make build-linux # stage 2 FROM golang:1.17-alpine LABEL maintainer="hello@tendermint.com" # Tendermint will be looking for the genesis file in /tendermint/config/genesis.json # (unless you change `genesis_file` in config.toml). You can put your config.toml and # private validator file into /tendermint/config. # # The /tendermint/data dir is used by tendermint to store state. ENV TMHOME /tendermint # OS environment setup # Set user right away for determinism, create directory for persistence and give our user ownership # jq and curl used for extracting `pub_key` from private validator while # deploying tendermint with Kubernetes. It is nice to have bash so the users # could execute bash commands. RUN apk update && \ apk upgrade && \ apk --no-cache add curl jq bash && \ addgroup tmuser && \ adduser -S -G tmuser tmuser -h "$TMHOME" # Run the container with tmuser by default. (UID=100, GID=1000) USER tmuser WORKDIR $TMHOME # p2p, rpc and prometheus port EXPOSE 26656 26657 26660 STOPSIGNAL SIGTERM COPY --from=builder /tendermint/build/tendermint /usr/bin/tendermint # You can overwrite these before the first run to influence # config.json and genesis.json. Additionally, you can override # CMD to add parameters to `tendermint node`. ENV PROXY_APP=kvstore MONIKER=dockernode CHAIN_ID=dockerchain COPY ./DOCKER/docker-entrypoint.sh /usr/local/bin/ ENTRYPOINT ["docker-entrypoint.sh"] CMD ["start"] # Expose the data directory as a volume since there's mutable state in there VOLUME [ "$TMHOME" ]