Files
hub-monorepo/Dockerfile.hubble
Marius Scurtescu 37241d8247 feat: add docker heath checks to services (#1948)
## Motivation

For each service in docker-compose.yml add a healtcheck entry.

Issue: https://github.com/farcasterxyz/hub-monorepo/issues/1646


## Change Summary

- adding `healthcheck` commands to all 3 services in
`apps/hubble/docker-compose.yml`
- installing `curl` command into `farcasterxyz/hubble` docker image
(`Dockerfile.hubble`), required by `healthcheck`

## Merge Checklist

_Choose all relevant options below by adding an `x` now or at any time
before submitting for review_

- [x] PR title adheres to the [conventional
commits](https://www.conventionalcommits.org/en/v1.0.0/) standard
- [ ] PR has a
[changeset](https://github.com/farcasterxyz/hub-monorepo/blob/main/CONTRIBUTING.md#35-adding-changesets)
- [x] PR has been tagged with a change label(s) (i.e. documentation,
feature, bugfix, or chore)
- [ ] PR includes
[documentation](https://github.com/farcasterxyz/hub-monorepo/blob/main/CONTRIBUTING.md#32-writing-docs)
if necessary.
- [x] All [commits have been
signed](https://github.com/farcasterxyz/hub-monorepo/blob/main/CONTRIBUTING.md#22-signing-commits)

<!-- start pr-codex -->

---

## PR-Codex overview
This PR enhances Docker health checks for `hubble` services with `curl`
and `nc` commands.

### Detailed summary
- Added `curl` health check for `hubble` service
- Added `nc` health check for `statsd` service
- Added `curl` health check for `grafana` service

>  Ask PR-Codex anything about this PR by commenting with `/codex {your
question}`

<!-- end pr-codex -->

---------

Co-authored-by: Shane da Silva <shane@dasilva.io>
2024-06-09 22:00:16 -07:00

99 lines
3.8 KiB
Docker

# This docker file uses a multi-stage build pattern as described here:
# https://github.com/goldbergyoni/nodebestpractices/blob/master/sections/docker/multi_stage_builds.md
###############################################################################
############## Stage 1: Create pruned version of monorepo #####################
###############################################################################
FROM node:21.6-slim AS prune
USER node
RUN mkdir /home/node/app
WORKDIR /home/node/app
# Run turbo prune to create a pruned version of monorepo
COPY --chown=node:node ./package.json ./package.json
RUN yarn global add turbo@$(node -e "console.log(require('./package.json').devDependencies.turbo)")
COPY --chown=node:node . .
RUN /home/node/.yarn/bin/turbo prune --scope=@farcaster/hubble --docker
###############################################################################
############## Stage 2: Build the code using a full node image ################
###############################################################################
FROM node:21.6-slim AS build
# Needed for compilation step
RUN apt-get update && apt-get install -y python3 make g++ linux-headers-generic curl protobuf-compiler libclang-dev cmake
USER node
RUN mkdir /home/node/app
WORKDIR /home/node/app
# Install Rust
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain 1.70.0
ENV PATH="/home/node/.cargo/bin:${PATH}"
# Rust flags to allow building with musl, which is needed for alpine
ENV RUSTFLAGS="-C target-feature=-crt-static"
# Copy dependency information and install all dependencies
COPY --chown=node:node --from=prune /home/node/app/out/json/ .
COPY --chown=node:node --from=prune /home/node/app/out/yarn.lock ./yarn.lock
RUN yarn install --frozen-lockfile --network-timeout 1800000
# Copy source code (and all other relevant files)
COPY --chown=node:node --from=prune /home/node/app/out/full/ .
# turbo prune doesn't include global tsconfig.json (https://github.com/vercel/turbo/issues/2177)
COPY --chown=node:node tsconfig.json tsconfig.json
COPY --chown=node:node protobufs protobufs
# Build code
RUN yarn build
# Purge dev dependencies and only install production dependencies
RUN rm -rf node_modules && yarn install --production --ignore-scripts --prefer-offline --force --frozen-lockfile
###############################################################################
########## Stage 3: Copy over the built code to a leaner alpine image #########
###############################################################################
FROM node:21.6-slim as app
RUN apt-get update && apt-get install -y curl procps
# Set non-root user and expose ports
USER node
# Many npm packages use this to trigger production optimized behaviors
ENV NODE_ENV production
RUN mkdir /home/node/app
WORKDIR /home/node/app
# Copy results from previous stage.
# The base image is same as the build stage, so it is safe to copy node_modules over to this stage.
COPY --chown=node:node --from=prune /home/node/app/out/json/ .
COPY --chown=node:node --from=build /home/node/app/apps/hubble/build ./apps/hubble/build
COPY --chown=node:node --from=build /home/node/app/node_modules ./node_modules
COPY --chown=node:node --from=build /home/node/app/packages/core/dist ./packages/core/dist/
COPY --chown=node:node --from=build /home/node/app/packages/hub-nodejs/dist ./packages/hub-nodejs/dist/
# BuildKit doesn't support --squash flag, so emulate by copying into fewer layers
FROM scratch
COPY --from=app / /
# Repeat of above since it is lost between build stages
USER node
EXPOSE 2282
EXPOSE 2283
WORKDIR /home/node/app/apps/hubble
# Run using pm2 as supervisor for faster recoveries on failure
COPY --chown=node:node ./apps/hubble/pm2.config.cjs ./pm2.config.cjs
ENV NODE_ARGS="--max-old-space-size=8192"
ENV HUBBLE_ARGS="start --network 1"
CMD ["npx", "pm2-runtime", "start", "pm2.config.cjs"]