Contour Logo

Documentation

Redeploying Envoy

The Envoy process, the data path component of Contour, at times needs to be re-deployed. This could be due to an upgrade, a change in configuration, or a node-failure forcing a redeployment.

When implementing this roll out, the following steps should be taken:

  1. Stop Envoy from accepting new connections
  2. Start draining existing connections in Envoy by sending a POST request to /healthcheck/fail endpoint
  3. Wait for connections to drain before allowing Kubernetes to SIGTERM the pod

Overview

Contour implements an envoy sub-command named shutdown-manager whose job is to manage a single Envoy instances lifecycle for Kubernetes. The shutdown-manager runs as a new container alongside the Envoy container in the same pod. It exposes two HTTP endpoints which are used for livenessProbe as well as to handle the Kubernetes preStop event hook.

  • livenessProbe: This is used to validate the shutdown manager is still running properly. If requests to /healthz fail, the container will be restarted.
  • preStop: This is used to keep the Envoy container running while waiting for connections to drain. The /shutdown endpoint blocks until the connections are drained.
 - name: shutdown-manager
   command:
   - /bin/contour
   args:
     - envoy
     - shutdown-manager
   image: ghcr.io/projectcontour/contour:main
   imagePullPolicy: Always
   lifecycle:
     preStop:
       exec:
         command:
           - /bin/contour
           - envoy
           - shutdown
   livenessProbe:
     httpGet:
       path: /healthz
       port: 8090
     initialDelaySeconds: 3
     periodSeconds: 10

The Envoy container also has some configuration to implement the shutdown manager. First the preStop hook is configured to use the /shutdown endpoint which blocks the Envoy container from exiting. Finally, the pod’s terminationGracePeriodSeconds is customized to extend the time in which Kubernetes will allow the pod to be in the Terminating state. The termination grace period defines an upper bound for long-lived sessions. If during shutdown, the connections aren’t drained to the configured amount, the terminationGracePeriodSeconds will send a SIGTERM to the pod killing it.

shutdown-manager overview

Shutdown Manager Config Options

The shutdown-manager runs as another container in the Envoy pod. When the pod is requested to terminate, the preStop hook on the shutdown-manager executes the contour envoy shutdown command initiating the shutdown sequence.

The shutdown manager has a single argument that can be passed to change how it behaves:

NameTypeDefaultDescription
serve-portinteger8090Port to serve the http server on
ready-filestring/admin/okFile to poll while waiting shutdown to be completed.

Shutdown Config Options

The shutdown command does the work of draining connections from Envoy and polling for open connections.

The shutdown command has a few arguments that can be passed to change how it behaves:

NameTypeDefaultDescription
check-intervalduration5sTime interval to poll Envoy for open connections.
check-delayduration0sTime wait before polling Envoy for open connections.
drain-delayduration0sTime wait before draining Envoy connections.
min-open-connectionsinteger0Min number of open connections when polling Envoy.
admin-port (Deprecated)integer9001Deprecated: No longer used, Envoy admin interface runs as a unix socket.
admin-addressstring/admin/admin.sockPath to Envoy admin unix domain socket.
ready-filestring/admin/okFile to write when shutdown is completed.

Ready to try Contour?

Read our getting started documentation.