O'Reilly book: Linkerd Up & Running   Download now  »


Service Profiles

Service profiles provide Linkerd additional information about a service. This is a reference for everything that can be done with service profiles.

Spec

A service profile spec must contain the following top level fields:

field value
routes a list of route objects
retryBudget a retry budget object that defines the maximum retry rate to this service

Route

A route object must contain the following fields:

field value
name the name of this route as it will appear in the route label
condition a request match object that defines if a request matches this route
responseClasses (optional) a list of response class objects
isRetryable indicates that requests to this route are always safe to retry and will cause the proxy to retry failed requests on this route whenever possible
timeout the maximum amount of time to wait for a response (including retries) to complete after the request is sent

Request Match

A request match object must contain exactly one of the following fields:

field value
pathRegex a regular expression to match the request path against
method one of GET, POST, PUT, DELETE, OPTION, HEAD, TRACE
all a list of request match objects which must all match
any a list of request match objects, at least one of which must match
not a request match object which must not match

Request Match Usage Examples

The simplest condition is a path regular expression:

pathRegex: '/authors/\d+'

This is a condition that checks the request method:

method: POST

If more than one condition field is set, all of them must be satisfied. This is equivalent to using the ‘all’ condition:

all:
- pathRegex: '/authors/\d+'
- method: POST

Conditions can be combined using ‘all’, ‘any’, and ’not’:

any:
- all:
  - method: POST
  - pathRegex: '/authors/\d+'
- all:
  - not:
      method: DELETE
  - pathRegex: /info.txt

Response Class

A response class object must contain the following fields:

field value
condition a response match object that defines if a response matches this response class
isFailure a boolean that defines if these responses should be classified as failed

Response Match

A response match object must contain exactly one of the following fields:

field value
status a status range object to match the response status code against
all a list of response match objects which must all match
any a list of response match objects, at least one of which must match
not a response match object which must not match

Response Match conditions can be combined in a similar way as shown above for Request Match Usage Examples

Status Range

A status range object must contain at least one of the following fields. Specifying only one of min or max matches just that one status code.

field value
min the status code must be greater than or equal to this value
max the status code must be less than or equal to this value

Retry Budget

A retry budget specifies the maximum total number of retries that should be sent to this service as a ratio of the original request volume.

field value
retryRatio the maximum ratio of retries requests to original requests
minRetriesPerSecond allowance of retries per second in addition to those allowed by the retryRatio
ttl indicates for how long requests should be considered for the purposes of calculating the retryRatio