Parameters for Creating Mesh¶
When using a service mesh, there may be some error messages. This page lists the detailed meanings of some error parameters for reference.
Max Retries¶
The service mesh embeds Envoy components, and some parameters related to Envoy can be set when creating the mesh. For more details, refer to the Envoy documentation.
HTTP¶
-
5xx
If the upstream server responds with any 5xx response code, or doesn't respond at all (connection closed/reset/read timeout), a retry will be attempted (including connect-failure and refused-stream).
-
connect-failure
If a request fails due to connection failure with the upstream server (such as connection timeout), a retry will be attempted (included in 5xx).
-
envoy-ratelimited
If the header x-envoy-ratelimited is present, Envoy will retry.
-
gateway-error
This policy is similar to the 5xx policy, but only retries requests that result in a 502, 503, or 504 error.
-
http3-post-connect-failure
If a request is sent to the upstream server via HTTP/3 and fails after connecting, a retry will be attempted.
-
refused-stream
If the upstream server resets the stream with the REFUSED_STREAM error code, a retry will be attempted. This reset type indicates that the request can be safely retried (included in 5xx).
-
reset
If the upstream server doesn't respond at all (connection closed/reset/read timeout), a retry will be attempted.
-
retriable-4xx
If the upstream server responds with a retriable 4xx response code, a retry will be attempted. Currently, the only response code in this category is 409.
Note: be careful when enabling this retry type. In some cases, 409 may indicate that an optimistic locking revision needs to be updated. Therefore, the caller should not retry and should read and then attempt write instead. If a retry occurs in this situation, it will always fail and return another 409.
-
retriable-headers
If any header in the upstream server response matches a retry policy or the x-envoy-retriable-header-names header, a retry will be attempted.
-
retriable-status-codes
If the upstream server responds with any response code that matches a retry policy or is defined in the x-envoy-retriable-status-codes header, a retry will be attempted.
gRPC¶
-
cancelled
If the gRPC status code in the response header is "cancelled", a retry will be attempted.
-
deadline-exceeded
If the gRPC status code in the response header is "deadline-exceeded", a retry will be attempted.
-
internal
If the gRPC status code in the response header is "internal", a retry will be attempted.
-
resource-exhausted
If the gRPC status code in the response header is "resource-exhausted", a retry will be attempted.
-
unavailable
If the gRPC status code in the response header is "unavailable", a retry will be attempted.
Sidecar Log Level¶
-
critical
Any errors that force the service or application to shut down to prevent data loss (or further data loss). These are reserved for the most egregious errors and situations where data corruption or loss is guaranteed.
-
debug
Using debug , you provide diagnostic information in a verbose manner. It's lengthy and contains more information than you need while using the application. The debug log level is used to get information needed to diagnose, troubleshoot, or test the application. This ensures the smooth operation of the application.
-
error
Unlike the critical log level, errors don't mean your application is aborting. Instead, it just can't access a service or file. This error indicates that something important in your application has failed. This log level is used when serious issues cause the functionality within the application to not work effectively. Most of the time, the application will continue to run but eventually needs this issue resolved.
-
info
General information to be logged (service start/stop, configuration assumptions, etc.). This is information that you want always available but typically don't care about in normal situations. This is the out-of-the-box configuration level.
-
off
This log level doesn't log anything. The off level is used to turn off logging and is the highest possible level. Using this log level, nothing is recorded at all.
-
trace
The trace log level captures all detailed information about application behavior. It's primarily diagnostic and more granular than the debug log level. This log level is used for situations where you need to see what's happening in your application or in third-party libraries used. You can use the trace log level to query parameters in your code or interpret algorithmic steps.
-
warning
When unexpected application issues are detected, the warning log level will be used. This means that you aren't quite sure if the problem will happen again or still exists. At this point, you might not notice any harm to your application. This issue is usually a case where a specific process has stopped running. But that doesn't mean that the application has been damaged. In fact, the code should continue to work as usual. You should eventually investigate these warnings to prevent the problem from happening again.