mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-14 06:15:45 +00:00
Merge pull request #69756 from cheftako/trace
Added tracing for long running requests.
This commit is contained in:
commit
833dcc2be3
@ -167,6 +167,7 @@ func createHandler(r rest.NamedCreater, scope RequestScope, admit admission.Inte
|
|||||||
status.Code = int32(code)
|
status.Code = int32(code)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, code, result)
|
transformResponseObject(ctx, scope, req, w, code, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -175,6 +175,7 @@ func DeleteResource(r rest.GracefulDeleter, allowsOptions bool, scope RequestSco
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, status, result)
|
transformResponseObject(ctx, scope, req, w, status, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -182,6 +183,9 @@ func DeleteResource(r rest.GracefulDeleter, allowsOptions bool, scope RequestSco
|
|||||||
// DeleteCollection returns a function that will handle a collection deletion
|
// DeleteCollection returns a function that will handle a collection deletion
|
||||||
func DeleteCollection(r rest.CollectionDeleter, checkBody bool, scope RequestScope, admit admission.Interface) http.HandlerFunc {
|
func DeleteCollection(r rest.CollectionDeleter, checkBody bool, scope RequestScope, admit admission.Interface) http.HandlerFunc {
|
||||||
return func(w http.ResponseWriter, req *http.Request) {
|
return func(w http.ResponseWriter, req *http.Request) {
|
||||||
|
trace := utiltrace.New("Delete " + req.URL.Path)
|
||||||
|
defer trace.LogIfLong(500 * time.Millisecond)
|
||||||
|
|
||||||
if isDryRun(req.URL) && !utilfeature.DefaultFeatureGate.Enabled(features.DryRun) {
|
if isDryRun(req.URL) && !utilfeature.DefaultFeatureGate.Enabled(features.DryRun) {
|
||||||
scope.err(errors.NewBadRequest("the dryRun alpha feature is disabled"), w, req)
|
scope.err(errors.NewBadRequest("the dryRun alpha feature is disabled"), w, req)
|
||||||
return
|
return
|
||||||
@ -310,6 +314,7 @@ func DeleteCollection(r rest.CollectionDeleter, checkBody bool, scope RequestSco
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,7 +74,9 @@ func getResourceHandler(scope RequestScope, getter getterFunc) http.HandlerFunc
|
|||||||
}
|
}
|
||||||
|
|
||||||
trace.Step("About to write a response")
|
trace.Step("About to write a response")
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
||||||
|
trace.Step("Transformed response object")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -279,6 +281,7 @@ func ListResource(r rest.Lister, rw rest.Watcher, scope RequestScope, forceWatch
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
||||||
trace.Step(fmt.Sprintf("Writing http response done (%d items)", numberOfItems))
|
trace.Step(fmt.Sprintf("Writing http response done (%d items)", numberOfItems))
|
||||||
}
|
}
|
||||||
|
@ -201,6 +201,7 @@ func PatchResource(r rest.Patcher, scope RequestScope, admit admission.Interface
|
|||||||
}
|
}
|
||||||
trace.Step("Self-link added")
|
trace.Step("Self-link added")
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
transformResponseObject(ctx, scope, req, w, http.StatusOK, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -35,9 +35,11 @@ import (
|
|||||||
// Will write the complete response object.
|
// Will write the complete response object.
|
||||||
func transformResponseObject(ctx context.Context, scope RequestScope, req *http.Request, w http.ResponseWriter, statusCode int, result runtime.Object) {
|
func transformResponseObject(ctx context.Context, scope RequestScope, req *http.Request, w http.ResponseWriter, statusCode int, result runtime.Object) {
|
||||||
// TODO: fetch the media type much earlier in request processing and pass it into this method.
|
// TODO: fetch the media type much earlier in request processing and pass it into this method.
|
||||||
|
trace := scope.Trace
|
||||||
mediaType, _, err := negotiation.NegotiateOutputMediaType(req, scope.Serializer, &scope)
|
mediaType, _, err := negotiation.NegotiateOutputMediaType(req, scope.Serializer, &scope)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
status := responsewriters.ErrorToAPIStatus(err)
|
status := responsewriters.ErrorToAPIStatus(err)
|
||||||
|
trace.Step("Writing raw JSON response")
|
||||||
responsewriters.WriteRawJSON(int(status.Code), status, w)
|
responsewriters.WriteRawJSON(int(status.Code), status, w)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -68,6 +70,7 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
||||||
|
trace.Step(fmt.Sprintf("Serializing response as type %s", info.MediaType))
|
||||||
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, partial)
|
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, partial)
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -79,6 +82,7 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
list := &metav1beta1.PartialObjectMetadataList{}
|
list := &metav1beta1.PartialObjectMetadataList{}
|
||||||
|
trace.Step("Processing list items")
|
||||||
err := meta.EachListItem(result, func(obj runtime.Object) error {
|
err := meta.EachListItem(result, func(obj runtime.Object) error {
|
||||||
m, err := meta.Accessor(obj)
|
m, err := meta.Accessor(obj)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -101,6 +105,7 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
||||||
|
trace.Step(fmt.Sprintf("Serializing response as type %s", info.MediaType))
|
||||||
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, list)
|
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, list)
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -109,17 +114,20 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
// TODO: skip if this is a status response (delete without body)?
|
// TODO: skip if this is a status response (delete without body)?
|
||||||
|
|
||||||
opts := &metav1beta1.TableOptions{}
|
opts := &metav1beta1.TableOptions{}
|
||||||
|
trace.Step("Decoding parameters")
|
||||||
if err := metav1beta1.ParameterCodec.DecodeParameters(req.URL.Query(), metav1beta1.SchemeGroupVersion, opts); err != nil {
|
if err := metav1beta1.ParameterCodec.DecodeParameters(req.URL.Query(), metav1beta1.SchemeGroupVersion, opts); err != nil {
|
||||||
scope.err(err, w, req)
|
scope.err(err, w, req)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trace.Step("Converting to table")
|
||||||
table, err := scope.TableConvertor.ConvertToTable(ctx, result, opts)
|
table, err := scope.TableConvertor.ConvertToTable(ctx, result, opts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
scope.err(err, w, req)
|
scope.err(err, w, req)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trace.Step("Processing rows")
|
||||||
for i := range table.Rows {
|
for i := range table.Rows {
|
||||||
item := &table.Rows[i]
|
item := &table.Rows[i]
|
||||||
switch opts.IncludeObject {
|
switch opts.IncludeObject {
|
||||||
@ -156,6 +164,7 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
encoder := metainternalversion.Codecs.EncoderForVersion(info.Serializer, metav1beta1.SchemeGroupVersion)
|
||||||
|
trace.Step(fmt.Sprintf("Serializing response as type %s", info.MediaType))
|
||||||
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, table)
|
responsewriters.SerializeObject(info.MediaType, encoder, w, req, statusCode, table)
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -164,11 +173,13 @@ func transformResponseObject(ctx context.Context, scope RequestScope, req *http.
|
|||||||
accepted, _ := negotiation.MediaTypesForSerializer(metainternalversion.Codecs)
|
accepted, _ := negotiation.MediaTypesForSerializer(metainternalversion.Codecs)
|
||||||
err := negotiation.NewNotAcceptableError(accepted)
|
err := negotiation.NewNotAcceptableError(accepted)
|
||||||
status := responsewriters.ErrorToAPIStatus(err)
|
status := responsewriters.ErrorToAPIStatus(err)
|
||||||
|
trace.Step("Writing raw JSON response")
|
||||||
responsewriters.WriteRawJSON(int(status.Code), status, w)
|
responsewriters.WriteRawJSON(int(status.Code), status, w)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trace.Step("Writing response")
|
||||||
responsewriters.WriteObject(statusCode, scope.Kind.GroupVersion(), scope.Serializer, result, w, req)
|
responsewriters.WriteObject(statusCode, scope.Kind.GroupVersion(), scope.Serializer, result, w, req)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ import (
|
|||||||
"k8s.io/apiserver/pkg/endpoints/metrics"
|
"k8s.io/apiserver/pkg/endpoints/metrics"
|
||||||
"k8s.io/apiserver/pkg/endpoints/request"
|
"k8s.io/apiserver/pkg/endpoints/request"
|
||||||
"k8s.io/apiserver/pkg/registry/rest"
|
"k8s.io/apiserver/pkg/registry/rest"
|
||||||
|
utiltrace "k8s.io/apiserver/pkg/util/trace"
|
||||||
openapiproto "k8s.io/kube-openapi/pkg/util/proto"
|
openapiproto "k8s.io/kube-openapi/pkg/util/proto"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -56,6 +57,7 @@ type RequestScope struct {
|
|||||||
Typer runtime.ObjectTyper
|
Typer runtime.ObjectTyper
|
||||||
UnsafeConvertor runtime.ObjectConvertor
|
UnsafeConvertor runtime.ObjectConvertor
|
||||||
Authorizer authorizer.Authorizer
|
Authorizer authorizer.Authorizer
|
||||||
|
Trace *utiltrace.Trace
|
||||||
|
|
||||||
TableConvertor rest.TableConvertor
|
TableConvertor rest.TableConvertor
|
||||||
OpenAPISchema openapiproto.Schema
|
OpenAPISchema openapiproto.Schema
|
||||||
|
@ -190,6 +190,7 @@ func UpdateResource(r rest.Updater, scope RequestScope, admit admission.Interfac
|
|||||||
status = http.StatusCreated
|
status = http.StatusCreated
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scope.Trace = trace
|
||||||
transformResponseObject(ctx, scope, req, w, status, result)
|
transformResponseObject(ctx, scope, req, w, status, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user