diff --git a/.github/workflows/docker-publish.yml b/.github/workflows/docker-publish.yml index 6b3fb23..6c6a189 100644 --- a/.github/workflows/docker-publish.yml +++ b/.github/workflows/docker-publish.yml @@ -30,4 +30,4 @@ jobs: username: ${{ github.repository_owner }} password: ${{ secrets.GITHUB_TOKEN }} image: ghcr.io/fuellabs/fuel-graph-node - dockerfile: fuel-graph-node/docker/Dockerfile \ No newline at end of file + dockerfile: fuel-graph-node/Dockerfile \ No newline at end of file diff --git a/fuel-graph-node/Dockerfile b/fuel-graph-node/Dockerfile new file mode 100644 index 0000000..37425fa --- /dev/null +++ b/fuel-graph-node/Dockerfile @@ -0,0 +1,72 @@ + +#FROM rust:bullseye as graph-node-build + +# extractor + +FROM lukemathwalker/cargo-chef:latest-rust-1.76-slim AS chef + +WORKDIR /app + +FROM chef AS planner +COPY . . +RUN cargo chef prepare --recipe-path recipe.json + +FROM chef AS extract_builder +RUN apt update && apt install -y protobuf-compiler +COPY --from=planner /app/recipe.json recipe.json +RUN cargo chef cook --release --recipe-path recipe.json +# Build application +COPY . . +RUN cargo build --release + + +# The graph-node runtime image with only the executable +FROM debian:bullseye-slim as graph-node +ENV RUST_LOG "" +ENV GRAPH_LOG "" +ENV EARLY_LOG_CHUNK_SIZE "" + +ENV postgres_host "" +ENV postgres_user "" +ENV postgres_pass "" +ENV postgres_db "" +ENV postgres_args "sslmode=prefer" +# The full URL to the IPFS node +ENV ipfs "" +# The etherum network(s) to connect to. Set this to a space-separated +# list of the networks where each entry has the form NAME:URL +ENV ethereum "" +# The role the node should have, one of index-node, query-node, or +# combined-node +ENV node_role "combined-node" +# The name of this node +ENV node_id "default" +# The ethereum network polling interval (in milliseconds) +ENV ethereum_polling_interval "" + +# The location of an optional configuration file for graph-node, as +# described in ../docs/config.md +# Using a configuration file is experimental, and the file format may +# change in backwards-incompatible ways +ENV GRAPH_NODE_CONFIG "" + +# Disable core dumps; this is useful for query nodes with large caches. Set +# this to anything to disable coredumps (via 'ulimit -c 0') +ENV disable_core_dumps "" + +# HTTP port +EXPOSE 8000 +# WebSocket port +EXPOSE 8001 +# JSON-RPC port +EXPOSE 8020 +# Indexing status port +EXPOSE 8030 + +RUN apt-get update \ + && apt-get install -y libpq-dev ca-certificates netcat \ + +#COPY --from=graph-node-build /usr/local/bin/graph-node /usr/local/bin/ +COPY --from=graph-node-build /app/target/release/graph-node /app/graph-node + +CMD ["/app/graph-node"] diff --git a/fuel-graph-node/docker/Dockerfile b/fuel-graph-node/docker/Dockerfile index 4deac77..0044c6b 100644 --- a/fuel-graph-node/docker/Dockerfile +++ b/fuel-graph-node/docker/Dockerfile @@ -103,5 +103,5 @@ ADD docker/wait_for docker/start /usr/local/bin/ COPY --from=graph-node-build /usr/local/bin/graph-node /usr/local/bin/graphman /usr/local/bin/ COPY --from=graph-node-build /etc/image-info /etc/image-info COPY --from=envsubst /go/bin/envsubst /usr/local/bin/ -#COPY docker/Dockerfile /Dockerfile +COPY docker/Dockerfile /Dockerfile CMD ["start"]