...

Package cloudprofiler

import "google.golang.org/genproto/googleapis/devtools/cloudprofiler/v2"
Overview
Index

Overview ▾

Index ▾

Variables
func RegisterProfilerServiceServer(s *grpc.Server, srv ProfilerServiceServer)
type CreateOfflineProfileRequest
    func (*CreateOfflineProfileRequest) Descriptor() ([]byte, []int)
    func (x *CreateOfflineProfileRequest) GetParent() string
    func (x *CreateOfflineProfileRequest) GetProfile() *Profile
    func (*CreateOfflineProfileRequest) ProtoMessage()
    func (x *CreateOfflineProfileRequest) ProtoReflect() protoreflect.Message
    func (x *CreateOfflineProfileRequest) Reset()
    func (x *CreateOfflineProfileRequest) String() string
type CreateProfileRequest
    func (*CreateProfileRequest) Descriptor() ([]byte, []int)
    func (x *CreateProfileRequest) GetDeployment() *Deployment
    func (x *CreateProfileRequest) GetParent() string
    func (x *CreateProfileRequest) GetProfileType() []ProfileType
    func (*CreateProfileRequest) ProtoMessage()
    func (x *CreateProfileRequest) ProtoReflect() protoreflect.Message
    func (x *CreateProfileRequest) Reset()
    func (x *CreateProfileRequest) String() string
type Deployment
    func (*Deployment) Descriptor() ([]byte, []int)
    func (x *Deployment) GetLabels() map[string]string
    func (x *Deployment) GetProjectId() string
    func (x *Deployment) GetTarget() string
    func (*Deployment) ProtoMessage()
    func (x *Deployment) ProtoReflect() protoreflect.Message
    func (x *Deployment) Reset()
    func (x *Deployment) String() string
type Profile
    func (*Profile) Descriptor() ([]byte, []int)
    func (x *Profile) GetDeployment() *Deployment
    func (x *Profile) GetDuration() *durationpb.Duration
    func (x *Profile) GetLabels() map[string]string
    func (x *Profile) GetName() string
    func (x *Profile) GetProfileBytes() []byte
    func (x *Profile) GetProfileType() ProfileType
    func (*Profile) ProtoMessage()
    func (x *Profile) ProtoReflect() protoreflect.Message
    func (x *Profile) Reset()
    func (x *Profile) String() string
type ProfileType
    func (ProfileType) Descriptor() protoreflect.EnumDescriptor
    func (x ProfileType) Enum() *ProfileType
    func (ProfileType) EnumDescriptor() ([]byte, []int)
    func (x ProfileType) Number() protoreflect.EnumNumber
    func (x ProfileType) String() string
    func (ProfileType) Type() protoreflect.EnumType
type ProfilerServiceClient
    func NewProfilerServiceClient(cc grpc.ClientConnInterface) ProfilerServiceClient
type ProfilerServiceServer
type UnimplementedProfilerServiceServer
    func (*UnimplementedProfilerServiceServer) CreateOfflineProfile(context.Context, *CreateOfflineProfileRequest) (*Profile, error)
    func (*UnimplementedProfilerServiceServer) CreateProfile(context.Context, *CreateProfileRequest) (*Profile, error)
    func (*UnimplementedProfilerServiceServer) UpdateProfile(context.Context, *UpdateProfileRequest) (*Profile, error)
type UpdateProfileRequest
    func (*UpdateProfileRequest) Descriptor() ([]byte, []int)
    func (x *UpdateProfileRequest) GetProfile() *Profile
    func (x *UpdateProfileRequest) GetUpdateMask() *fieldmaskpb.FieldMask
    func (*UpdateProfileRequest) ProtoMessage()
    func (x *UpdateProfileRequest) ProtoReflect() protoreflect.Message
    func (x *UpdateProfileRequest) Reset()
    func (x *UpdateProfileRequest) String() string

Package files

profiler.pb.go

Variables

Enum value maps for ProfileType.

var (
    ProfileType_name = map[int32]string{
        0: "PROFILE_TYPE_UNSPECIFIED",
        1: "CPU",
        2: "WALL",
        3: "HEAP",
        4: "THREADS",
        5: "CONTENTION",
        6: "PEAK_HEAP",
        7: "HEAP_ALLOC",
    }
    ProfileType_value = map[string]int32{
        "PROFILE_TYPE_UNSPECIFIED": 0,
        "CPU":                      1,
        "WALL":                     2,
        "HEAP":                     3,
        "THREADS":                  4,
        "CONTENTION":               5,
        "PEAK_HEAP":                6,
        "HEAP_ALLOC":               7,
    }
)
var File_google_devtools_cloudprofiler_v2_profiler_proto protoreflect.FileDescriptor

func RegisterProfilerServiceServer

func RegisterProfilerServiceServer(s *grpc.Server, srv ProfilerServiceServer)

type CreateOfflineProfileRequest

CreateOfflineProfileRequest describes a profile resource offline creation request.

type CreateOfflineProfileRequest struct {

    // Parent project to create the profile in.
    Parent string `protobuf:"bytes,1,opt,name=parent,proto3" json:"parent,omitempty"`
    // Contents of the profile to create.
    Profile *Profile `protobuf:"bytes,2,opt,name=profile,proto3" json:"profile,omitempty"`
    // contains filtered or unexported fields
}

func (*CreateOfflineProfileRequest) Descriptor

func (*CreateOfflineProfileRequest) Descriptor() ([]byte, []int)

Deprecated: Use CreateOfflineProfileRequest.ProtoReflect.Descriptor instead.

func (*CreateOfflineProfileRequest) GetParent

func (x *CreateOfflineProfileRequest) GetParent() string

func (*CreateOfflineProfileRequest) GetProfile

func (x *CreateOfflineProfileRequest) GetProfile() *Profile

func (*CreateOfflineProfileRequest) ProtoMessage

func (*CreateOfflineProfileRequest) ProtoMessage()

func (*CreateOfflineProfileRequest) ProtoReflect

func (x *CreateOfflineProfileRequest) ProtoReflect() protoreflect.Message

func (*CreateOfflineProfileRequest) Reset

func (x *CreateOfflineProfileRequest) Reset()

func (*CreateOfflineProfileRequest) String

func (x *CreateOfflineProfileRequest) String() string

type CreateProfileRequest

CreateProfileRequest describes a profile resource online creation request. The deployment field must be populated. The profile_type specifies the list of profile types supported by the agent. The creation call will hang until a profile of one of these types needs to be collected.

type CreateProfileRequest struct {

    // Parent project to create the profile in.
    Parent string `protobuf:"bytes,4,opt,name=parent,proto3" json:"parent,omitempty"`
    // Deployment details.
    Deployment *Deployment `protobuf:"bytes,1,opt,name=deployment,proto3" json:"deployment,omitempty"`
    // One or more profile types that the agent is capable of providing.
    ProfileType []ProfileType `protobuf:"varint,2,rep,packed,name=profile_type,json=profileType,proto3,enum=google.devtools.cloudprofiler.v2.ProfileType" json:"profile_type,omitempty"`
    // contains filtered or unexported fields
}

func (*CreateProfileRequest) Descriptor

func (*CreateProfileRequest) Descriptor() ([]byte, []int)

Deprecated: Use CreateProfileRequest.ProtoReflect.Descriptor instead.

func (*CreateProfileRequest) GetDeployment

func (x *CreateProfileRequest) GetDeployment() *Deployment

func (*CreateProfileRequest) GetParent

func (x *CreateProfileRequest) GetParent() string

func (*CreateProfileRequest) GetProfileType

func (x *CreateProfileRequest) GetProfileType() []ProfileType

func (*CreateProfileRequest) ProtoMessage

func (*CreateProfileRequest) ProtoMessage()

func (*CreateProfileRequest) ProtoReflect

func (x *CreateProfileRequest) ProtoReflect() protoreflect.Message

func (*CreateProfileRequest) Reset

func (x *CreateProfileRequest) Reset()

func (*CreateProfileRequest) String

func (x *CreateProfileRequest) String() string

type Deployment

Deployment contains the deployment identification information.

type Deployment struct {

    // Project ID is the ID of a cloud project.
    // Validation regex: `^[a-z][-a-z0-9:.]{4,61}[a-z0-9]$`.
    ProjectId string `protobuf:"bytes,1,opt,name=project_id,json=projectId,proto3" json:"project_id,omitempty"`
    // Target is the service name used to group related deployments:
    // * Service name for App Engine Flex / Standard.
    // * Cluster and container name for GKE.
    // * User-specified string for direct Compute Engine profiling (e.g. Java).
    // * Job name for Dataflow.
    // Validation regex: `^[a-z0-9]([-a-z0-9_.]{0,253}[a-z0-9])?$`.
    Target string `protobuf:"bytes,2,opt,name=target,proto3" json:"target,omitempty"`
    // Labels identify the deployment within the user universe and same target.
    // Validation regex for label names: `^[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?$`.
    // Value for an individual label must be <= 512 bytes, the total
    // size of all label names and values must be <= 1024 bytes.
    //
    // Label named "language" can be used to record the programming language of
    // the profiled deployment. The standard choices for the value include "java",
    // "go", "python", "ruby", "nodejs", "php", "dotnet".
    //
    // For deployments running on Google Cloud Platform, "zone" or "region" label
    // should be present describing the deployment location. An example of a zone
    // is "us-central1-a", an example of a region is "us-central1" or
    // "us-central".
    Labels map[string]string `protobuf:"bytes,3,rep,name=labels,proto3" json:"labels,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"`
    // contains filtered or unexported fields
}

func (*Deployment) Descriptor

func (*Deployment) Descriptor() ([]byte, []int)

Deprecated: Use Deployment.ProtoReflect.Descriptor instead.

func (*Deployment) GetLabels

func (x *Deployment) GetLabels() map[string]string

func (*Deployment) GetProjectId

func (x *Deployment) GetProjectId() string

func (*Deployment) GetTarget

func (x *Deployment) GetTarget() string

func (*Deployment) ProtoMessage

func (*Deployment) ProtoMessage()

func (*Deployment) ProtoReflect

func (x *Deployment) ProtoReflect() protoreflect.Message

func (*Deployment) Reset

func (x *Deployment) Reset()

func (*Deployment) String

func (x *Deployment) String() string

type Profile

Profile resource.

type Profile struct {

    // Output only. Opaque, server-assigned, unique ID for this profile.
    Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
    // Type of profile.
    // For offline mode, this must be specified when creating the profile. For
    // online mode it is assigned and returned by the server.
    ProfileType ProfileType `protobuf:"varint,2,opt,name=profile_type,json=profileType,proto3,enum=google.devtools.cloudprofiler.v2.ProfileType" json:"profile_type,omitempty"`
    // Deployment this profile corresponds to.
    Deployment *Deployment `protobuf:"bytes,3,opt,name=deployment,proto3" json:"deployment,omitempty"`
    // Duration of the profiling session.
    // Input (for the offline mode) or output (for the online mode).
    // The field represents requested profiling duration. It may slightly differ
    // from the effective profiling duration, which is recorded in the profile
    // data, in case the profiling can't be stopped immediately (e.g. in case
    // stopping the profiling is handled asynchronously).
    Duration *durationpb.Duration `protobuf:"bytes,4,opt,name=duration,proto3" json:"duration,omitempty"`
    // Input only. Profile bytes, as a gzip compressed serialized proto, the
    // format is https://github.com/google/pprof/blob/master/proto/profile.proto.
    ProfileBytes []byte `protobuf:"bytes,5,opt,name=profile_bytes,json=profileBytes,proto3" json:"profile_bytes,omitempty"`
    // Input only. Labels associated to this specific profile. These labels will
    // get merged with the deployment labels for the final data set. See
    // documentation on deployment labels for validation rules and limits.
    Labels map[string]string `protobuf:"bytes,6,rep,name=labels,proto3" json:"labels,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"`
    // contains filtered or unexported fields
}

func (*Profile) Descriptor

func (*Profile) Descriptor() ([]byte, []int)

Deprecated: Use Profile.ProtoReflect.Descriptor instead.

func (*Profile) GetDeployment

func (x *Profile) GetDeployment() *Deployment

func (*Profile) GetDuration

func (x *Profile) GetDuration() *durationpb.Duration

func (*Profile) GetLabels

func (x *Profile) GetLabels() map[string]string

func (*Profile) GetName

func (x *Profile) GetName() string

func (*Profile) GetProfileBytes

func (x *Profile) GetProfileBytes() []byte

func (*Profile) GetProfileType

func (x *Profile) GetProfileType() ProfileType

func (*Profile) ProtoMessage

func (*Profile) ProtoMessage()

func (*Profile) ProtoReflect

func (x *Profile) ProtoReflect() protoreflect.Message

func (*Profile) Reset

func (x *Profile) Reset()

func (*Profile) String

func (x *Profile) String() string

type ProfileType

ProfileType is type of profiling data. NOTE: the enumeration member names are used (in lowercase) as unique string identifiers of profile types, so they must not be renamed.

type ProfileType int32
const (
    // Unspecified profile type.
    ProfileType_PROFILE_TYPE_UNSPECIFIED ProfileType = 0
    // Thread CPU time sampling.
    ProfileType_CPU ProfileType = 1
    // Wallclock time sampling. More expensive as stops all threads.
    ProfileType_WALL ProfileType = 2
    // In-use heap profile. Represents a snapshot of the allocations that are
    // live at the time of the profiling.
    ProfileType_HEAP ProfileType = 3
    // Single-shot collection of all thread stacks.
    ProfileType_THREADS ProfileType = 4
    // Synchronization contention profile.
    ProfileType_CONTENTION ProfileType = 5
    // Peak heap profile.
    ProfileType_PEAK_HEAP ProfileType = 6
    // Heap allocation profile. It represents the aggregation of all allocations
    // made over the duration of the profile. All allocations are included,
    // including those that might have been freed by the end of the profiling
    // interval. The profile is in particular useful for garbage collecting
    // languages to understand which parts of the code create most of the garbage
    // collection pressure to see if those can be optimized.
    ProfileType_HEAP_ALLOC ProfileType = 7
)

func (ProfileType) Descriptor

func (ProfileType) Descriptor() protoreflect.EnumDescriptor

func (ProfileType) Enum

func (x ProfileType) Enum() *ProfileType

func (ProfileType) EnumDescriptor

func (ProfileType) EnumDescriptor() ([]byte, []int)

Deprecated: Use ProfileType.Descriptor instead.

func (ProfileType) Number

func (x ProfileType) Number() protoreflect.EnumNumber

func (ProfileType) String

func (x ProfileType) String() string

func (ProfileType) Type

func (ProfileType) Type() protoreflect.EnumType

type ProfilerServiceClient

ProfilerServiceClient is the client API for ProfilerService service.

For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream.

type ProfilerServiceClient interface {
    // CreateProfile creates a new profile resource in the online mode.
    //
    // The server ensures that the new profiles are created at a constant rate per
    // deployment, so the creation request may hang for some time until the next
    // profile session is available.
    //
    // The request may fail with ABORTED error if the creation is not available
    // within ~1m, the response will indicate the duration of the backoff the
    // client should take before attempting creating a profile again. The backoff
    // duration is returned in google.rpc.RetryInfo extension on the response
    // status. To a gRPC client, the extension will be return as a
    // binary-serialized proto in the trailing metadata item named
    // "google.rpc.retryinfo-bin".
    CreateProfile(ctx context.Context, in *CreateProfileRequest, opts ...grpc.CallOption) (*Profile, error)
    // CreateOfflineProfile creates a new profile resource in the offline mode.
    // The client provides the profile to create along with the profile bytes, the
    // server records it.
    CreateOfflineProfile(ctx context.Context, in *CreateOfflineProfileRequest, opts ...grpc.CallOption) (*Profile, error)
    // UpdateProfile updates the profile bytes and labels on the profile resource
    // created in the online mode. Updating the bytes for profiles created in the
    // offline mode is currently not supported: the profile content must be
    // provided at the time of the profile creation.
    UpdateProfile(ctx context.Context, in *UpdateProfileRequest, opts ...grpc.CallOption) (*Profile, error)
}

func NewProfilerServiceClient

func NewProfilerServiceClient(cc grpc.ClientConnInterface) ProfilerServiceClient

type ProfilerServiceServer

ProfilerServiceServer is the server API for ProfilerService service.

type ProfilerServiceServer interface {
    // CreateProfile creates a new profile resource in the online mode.
    //
    // The server ensures that the new profiles are created at a constant rate per
    // deployment, so the creation request may hang for some time until the next
    // profile session is available.
    //
    // The request may fail with ABORTED error if the creation is not available
    // within ~1m, the response will indicate the duration of the backoff the
    // client should take before attempting creating a profile again. The backoff
    // duration is returned in google.rpc.RetryInfo extension on the response
    // status. To a gRPC client, the extension will be return as a
    // binary-serialized proto in the trailing metadata item named
    // "google.rpc.retryinfo-bin".
    CreateProfile(context.Context, *CreateProfileRequest) (*Profile, error)
    // CreateOfflineProfile creates a new profile resource in the offline mode.
    // The client provides the profile to create along with the profile bytes, the
    // server records it.
    CreateOfflineProfile(context.Context, *CreateOfflineProfileRequest) (*Profile, error)
    // UpdateProfile updates the profile bytes and labels on the profile resource
    // created in the online mode. Updating the bytes for profiles created in the
    // offline mode is currently not supported: the profile content must be
    // provided at the time of the profile creation.
    UpdateProfile(context.Context, *UpdateProfileRequest) (*Profile, error)
}

type UnimplementedProfilerServiceServer

UnimplementedProfilerServiceServer can be embedded to have forward compatible implementations.

type UnimplementedProfilerServiceServer struct {
}

func (*UnimplementedProfilerServiceServer) CreateOfflineProfile

func (*UnimplementedProfilerServiceServer) CreateOfflineProfile(context.Context, *CreateOfflineProfileRequest) (*Profile, error)

func (*UnimplementedProfilerServiceServer) CreateProfile

func (*UnimplementedProfilerServiceServer) CreateProfile(context.Context, *CreateProfileRequest) (*Profile, error)

func (*UnimplementedProfilerServiceServer) UpdateProfile

func (*UnimplementedProfilerServiceServer) UpdateProfile(context.Context, *UpdateProfileRequest) (*Profile, error)

type UpdateProfileRequest

UpdateProfileRequest contains the profile to update.

type UpdateProfileRequest struct {

    // Profile to update.
    Profile *Profile `protobuf:"bytes,1,opt,name=profile,proto3" json:"profile,omitempty"`
    // Field mask used to specify the fields to be overwritten. Currently only
    // profile_bytes and labels fields are supported by UpdateProfile, so only
    // those fields can be specified in the mask. When no mask is provided, all
    // fields are overwritten.
    UpdateMask *fieldmaskpb.FieldMask `protobuf:"bytes,2,opt,name=update_mask,json=updateMask,proto3" json:"update_mask,omitempty"`
    // contains filtered or unexported fields
}

func (*UpdateProfileRequest) Descriptor

func (*UpdateProfileRequest) Descriptor() ([]byte, []int)

Deprecated: Use UpdateProfileRequest.ProtoReflect.Descriptor instead.

func (*UpdateProfileRequest) GetProfile

func (x *UpdateProfileRequest) GetProfile() *Profile

func (*UpdateProfileRequest) GetUpdateMask

func (x *UpdateProfileRequest) GetUpdateMask() *fieldmaskpb.FieldMask

func (*UpdateProfileRequest) ProtoMessage

func (*UpdateProfileRequest) ProtoMessage()

func (*UpdateProfileRequest) ProtoReflect

func (x *UpdateProfileRequest) ProtoReflect() protoreflect.Message

func (*UpdateProfileRequest) Reset

func (x *UpdateProfileRequest) Reset()

func (*UpdateProfileRequest) String

func (x *UpdateProfileRequest) String() string