HTTPRoute

HTTPRoute Spec

An HTTPRoute spec may contain the following top level fields:

fieldvalue
parentRefsA set of ParentReferences which indicate which [Server]s or Services this HTTPRoute attaches to.
hostnamesA set of hostnames that should match against the HTTP Host header.
rulesAn array of HTTPRouteRules.

parentReference

A reference to the parent resource this HTTPRoute is a part of.

HTTPRoutes can be attached to a Server to allow defining an authorization policy for specific routes served on that Server.

HTTPRoutes can also be attached to a Service, in order to route requests depending on path, headers, query params, and/or verb. Requests can then be rerouted to different backend services. This can be used to perform dynamic request routing.

HTTPRoute - 图1

Warning

Outbound HTTPRoutes are incompatible with ServiceProfiles. If the ParentReference of an HTTPRoute is a Service, and a ServiceProfile is also defined for that Service, proxies will use the ServiceProfile configuration, rather than the HTTPRoute configuration, as long as the ServiceProfile exists.

fieldvalue
groupThe group of the referent. This must either be “policy.linkerd.io” (for Server) or “core” (for Service).
kindThe kind of the referent. This must be either “Server” or “Service”.
portThe targeted port number, when attaching to Services.
namespaceThe namespace of the referent. When unspecified (or empty string), this refers to the local namespace of the Route.
nameThe name of the referent.

httpRouteRule

HTTPRouteRule defines semantics for matching an HTTP request based on conditions (matches) and processing it (filters).

fieldvalue
matchesA list of httpRouteMatches. Each match is independent, i.e. this rule will be matched if any one of the matches is satisfied.
filtersA list of httpRouteFilters which will be applied to each request which matches this rule.
backendRefsAn array of HTTPBackendRefs to declare where the traffic should be routed to (only allowed with Service parentRefs).

httpRouteMatch

HTTPRouteMatch defines the predicate used to match requests to a given action. Multiple match types are ANDed together, i.e. the match will evaluate to true only if all conditions are satisfied.

fieldvalue
pathAn httpPathMatch. If this field is not specified, a default prefix match on the “/” path is provided.
headersA list of httpHeaderMatches. Multiple match values are ANDed together.
queryParamsA list of httpQueryParamMatches. Multiple match values are ANDed together.
methodWhen specified, this route will be matched only if the request has the specified method.

httpPathMatch

HTTPPathMatch describes how to select a HTTP route by matching the HTTP request path.

fieldvalue
typeHow to match against the path Value. One of: Exact, PathPrefix, RegularExpression. If this field is not specified, a default of “PathPrefix” is provided.
valueThe HTTP path to match against.

httpHeaderMatch

HTTPHeaderMatch describes how to select a HTTP route by matching HTTP request headers.

fieldvalue
typeHow to match against the value of the header. One of: Exact, RegularExpression. If this field is not specified, a default of “Exact” is provided.
nameThe HTTP Header to be matched against. Name matching MUST be case insensitive.
valueValue of HTTP Header to be matched.

httpQueryParamMatch

HTTPQueryParamMatch describes how to select a HTTP route by matching HTTP query parameters.

fieldvalue
typeHow to match against the value of the query parameter. One of: Exact, RegularExpression. If this field is not specified, a default of “Exact” is provided.
nameThe HTTP query param to be matched. This must be an exact string match.
valueValue of HTTP query param to be matched.

httpRouteFilter

HTTPRouteFilter defines processing steps that must be completed during the request or response lifecycle.

fieldvalue
typeOne of: RequestHeaderModifier, RequestRedirect.
requestHeaderModifierAn httpRequestHeaderFilter.
requestRedirectAn httpRequestRedirectFilter.

httpRequestHeaderFilter

A filter which modifies request headers.

fieldvalue
setA list of httpHeaders to overwrites on the request.
addA list of httpHeaders to add on the request, appending to any existing value.
removeA list of header names to remove from the request.

httpHeader

HTTPHeader represents an HTTP Header name and value as defined by RFC 7230.

fieldvalue
nameName of the HTTP Header to be matched. Name matching MUST be case insensitive.
valueValue of HTTP Header to be matched.

httpRequestRedirectFilter

HTTPRequestRedirect defines a filter that redirects a request.

fieldvalue
schemeThe scheme to be used in the value of the Location header in the response. When empty, the scheme of the request is used.
hostnameThe hostname to be used in the value of the Location header in the response. When empty, the hostname of the request is used.
pathAn httpPathModfier which modifies the path of the incoming request and uses the modified path in the Location header.
portThe port to be used in the value of the Location header in the response. When empty, port (if specified) of the request is used.
statusCodeThe HTTP status code to be used in response.

httpPathModfier

HTTPPathModifier defines configuration for path modifiers.

fieldvalue
typeOne of: ReplaceFullPath, ReplacePrefixMatch.
replaceFullPathThe value with which to replace the full path of a request during a rewrite or redirect.
replacePrefixMatchThe value with which to replace the prefix match of a request during a rewrite or redirect.

httpBackendRef

HTTPBackendRef defines the list of objects where matching requests should be sent to. Only allowed when a route has Service parentRefs.

fieldvalue
nameName of service for this backend.
portDestination port number for this backend.
namespaceNamespace of service for this backend.
weightProportion of requests sent to this backend.

HTTPRoute Examples

An HTTPRoute attached to a Server resource which matches GETs to /authors.json or /authors/*:

  1. apiVersion: policy.linkerd.io/v1beta2
  2. kind: HTTPRoute
  3. metadata:
  4. name: authors-get-route
  5. namespace: booksapp
  6. spec:
  7. parentRefs:
  8. - name: authors-server
  9. kind: Server
  10. group: policy.linkerd.io
  11. rules:
  12. - matches:
  13. - path:
  14. value: "/authors.json"
  15. method: GET
  16. - path:
  17. value: "/authors/"
  18. type: "PathPrefix"
  19. method: GET

An HTTPRoute attached to a Service to perform header-based routing. If there’s a x-faces-user: testuser header in the request, the request is routed to the smiley2 backend Service. Otherwise, the request is routed to the smiley backend Service.

  1. apiVersion: policy.linkerd.io/v1beta2
  2. kind: HTTPRoute
  3. metadata:
  4. name: smiley-a-b
  5. namespace: faces
  6. spec:
  7. parentRefs:
  8. - name: smiley
  9. kind: Service
  10. group: core
  11. port: 80
  12. rules:
  13. - matches:
  14. - headers:
  15. - name: "x-faces-user"
  16. value: "testuser"
  17. backendRefs:
  18. - name: smiley2
  19. port: 80
  20. - backendRefs:
  21. - name: smiley
  22. port: 80