Building

    In order to build manually, follow the instructions at bazel/README.md.

    Envoy was initially developed and deployed on Ubuntu 14.04 LTS. It should work on any reasonably recent Linux including Ubuntu 18.04 LTS.

    Building Envoy has the following requirements:

    • These dependencies.

    Please see the linked CI and documentation for more information on performing manual builds. Please note that for Clang/LLVM 8 and lower, Envoy may need to be built with –define tcmalloc=gperftools as the new tcmalloc code is not guaranteed to compile with lower versions of Clang.

    We build and tag Docker images with release versions when we do official releases. These images can be found in the following repositories:

    • envoyproxy/envoy-debug: Release binary with debug symbols on top of an Ubuntu Bionic base.

    • : Release binary with symbols stripped on top of a glibc alpine base.

    Note

    In the above repositories, we tag a vX.Y-latest image for each security/stable release line.

    On every master commit we additionally create a set of development Docker images. These images can be found in the following repositories:

    • envoyproxy/envoy-dev: Release binary with symbols stripped on top of an Ubuntu Bionic base.

    • : Release binary with symbols stripped on top of a glibc alpine base.

    • envoyproxy/envoy-alpine-debug-dev: Deprecated in favor of envoyproxy/envoy-debug-dev. Release binary with debug symbols on top of a glibc alpine base.

    In the above dev repositories, the latest tag points to the last Envoy SHA in master that passed tests.

    Note

    The Envoy project considers master to be release candidate quality at all times, and many organizations track and deploy master in production. We encourage you to do the same so that issues can be reported as early as possible in the development process.

    Packaged Envoy pre-built binaries for a variety of platforms are available via .

    We will consider producing additional binary types depending on community interest in helping with CI, packaging, etc. Please open an issue in GetEnvoy for pre-built binaries for different platforms.

    If you’re interested in modifying Envoy and testing your changes, one approach is to use Docker. This guide will walk through the process of building your own Envoy binary, and putting the binary in an Ubuntu container.