0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-24 00:17:37 +01:00
mongodb/docs/bazel.md
Daniel Moody 90a0582c0e SERVER-86052 Add ThinTargets support for bazel integration (#20011)
GitOrigin-RevId: 809a0c3eff9d4862eeab60f1a874b238aec06f62
2024-05-02 01:46:32 +00:00

2.1 KiB

(Note: This is a work-in-progress for the Build team; contact #ask-devprod-build for questions)

To perform a Bazel build via SCons:

  • You must be on a arm64 virtual workstation
  • You must generate engflow credentials and store them in the correct location (see below)
  • Build the Bazel-compatible target: python3 ./buildscripts/scons.py --build-profile=fast --ninja=disabled --link-model=static -j 200 --modules= build/fast/mongo/db/commands/libfsync_locked.a

To generate and install the engflow credentials:

  • Navigate to and log in with your mongodb gmail account: https://sodalite.cluster.engflow.com/gettingstarted
  • Generate and download the credentials; you will need to move them to the workstation machine (scp, copy paste plain text, etc...)
  • Store them (the same filename they downloaded as) on your machine at the default location our build expects: /engflow/creds/
  • You should run chmod 600 on them to make sure they are readable only by your user
  • If you don't want to use the cluster you can pass BAZEL_FLAGS=--config=local on the SCons command line or --config=local on the bazel command line

To perform a Bazel build and bypass SCons:

  • Install Bazelisk: curl -L https://mdb-build-public.s3.amazonaws.com/bazelisk-binaries/v1.19.0/bazelisk-linux-arm64 --output /tmp/bazelisk && chmod +x /tmp/bazelisk
  • Build the Bazel-compatible target: /tmp/bazelisk build --verbose_failures src/mongo/db/commands:fsync_locked

To perform a Bazel build using a local Buildfarm (to test remote execution capability):

  • For more details on Buildfarm, see https://bazelbuild.github.io/bazel-buildfarm
  • (One time only) Build and start the Buildfarm: ** Change into the buildfarm directory: cd buildfarm ** Build the image: docker-compose build ** Start the container: docker-compose up --detach ** Poll until the containers report status running: docker ps --filter status=running --filter name=buildfarm
  • (Whenever you build): ** Build the Bazel-compatible target with remote execution enabled: /tmp/bazelisk build --verbose_failures --remote_executor=grpc://localhost:8980 src/mongo/db/commands:fsync_locked