Documentation ¶
Index ¶
- Constants
- Variables
- func Can(verbs []string, v string) bool
- func CleanseNamespace(ns string) string
- func FQN(ns, n string) string
- func IsAllNamespace(ns string) bool
- func IsAllNamespaces(ns string) bool
- func IsClusterScoped(ns string) bool
- func IsClusterWide(ns string) bool
- func IsNamespaced(ns string) bool
- func MetaFQN(m metav1.ObjectMeta) string
- func Namespaced(p string) (string, string)
- func ResetMetrics()
- func ToMB(v int64) int64
- func ToPercentage(v1, v2 int64) int
- func ToPercentageStr(v1, v2 int64) string
- type APIClient
- func (a *APIClient) ActiveCluster() string
- func (a *APIClient) ActiveNamespace() string
- func (a *APIClient) CachedDiscoveryOrDie() *disk.CachedDiscoveryClient
- func (a *APIClient) CanI(ns, gvr string, verbs []string) (auth bool, err error)
- func (a *APIClient) CheckConnectivity() (status bool)
- func (a *APIClient) Config() *Config
- func (a *APIClient) CurrentNamespaceName() (string, error)
- func (a *APIClient) DialOrDie() kubernetes.Interface
- func (a *APIClient) DynDialOrDie() dynamic.Interface
- func (a *APIClient) HasMetrics() bool
- func (a *APIClient) IsActiveNamespace(ns string) bool
- func (a *APIClient) MXDial() (*versioned.Clientset, error)
- func (a *APIClient) RestConfigOrDie() *restclient.Config
- func (a *APIClient) ServerVersion() (*version.Info, error)
- func (a *APIClient) SwitchContext(ctx string) error
- func (a *APIClient) ValidNamespaces() ([]v1.Namespace, error)
- type Authorizer
- type ClusterMetrics
- type Config
- func (c *Config) ClusterNameFromContext(ctx string) (string, error)
- func (c *Config) ClusterNames() ([]string, error)
- func (c *Config) ConfigAccess() (clientcmd.ConfigAccess, error)
- func (c *Config) ContextNames() ([]string, error)
- func (c *Config) Contexts() (map[string]*clientcmdapi.Context, error)
- func (c *Config) CurrentClusterName() (string, error)
- func (c *Config) CurrentContextName() (string, error)
- func (c *Config) CurrentGroupNames() ([]string, error)
- func (c *Config) CurrentNamespaceName() (string, error)
- func (c *Config) CurrentUserName() (string, error)
- func (c *Config) DelContext(n string) error
- func (c *Config) Flags() *genericclioptions.ConfigFlags
- func (c *Config) GetContext(n string) (*clientcmdapi.Context, error)
- func (c *Config) ImpersonateGroups() (string, error)
- func (c *Config) ImpersonateUser() (string, error)
- func (c *Config) NamespaceNames(nns []v1.Namespace) []string
- func (c *Config) RESTConfig() (*restclient.Config, error)
- func (c *Config) RawConfig() (clientcmdapi.Config, error)
- func (c *Config) SwitchContext(name string) error
- type Connection
- type CurrentMetrics
- type GVR
- func (g GVR) AsResourceName() string
- func (g GVR) G() string
- func (g GVR) GR() *schema.GroupResource
- func (g GVR) GV() schema.GroupVersion
- func (g GVR) GVK() schema.GroupVersionKind
- func (g GVR) GVR() schema.GroupVersionResource
- func (g GVR) R() string
- func (g GVR) RG() (string, string)
- func (g GVR) String() string
- func (g GVR) SubResource() string
- func (g GVR) V() string
- type GVRs
- type MetricsServer
- func (m *MetricsServer) ClusterLoad(nos *v1.NodeList, nmx *mv1beta1.NodeMetricsList, mx *ClusterMetrics) error
- func (m *MetricsServer) FetchNodesMetrics(ctx context.Context) (*mv1beta1.NodeMetricsList, error)
- func (m *MetricsServer) FetchPodMetrics(ctx context.Context, fqn string) (*mv1beta1.PodMetrics, error)
- func (m *MetricsServer) FetchPodsMetrics(ctx context.Context, ns string) (*mv1beta1.PodMetricsList, error)
- func (m *MetricsServer) NodesMetrics(nodes *v1.NodeList, metrics *mv1beta1.NodeMetricsList, mmx NodesMetrics)
- func (m *MetricsServer) PodsMetrics(pods *mv1beta1.PodMetricsList, mmx PodsMetrics)
- type NodeMetrics
- type NodesMetrics
- type PodMetrics
- type PodsMetrics
- type PortTunnel
Constants ¶
const ( // NA Not available NA = "n/a" // NamespaceAll designates the fictional all namespace. NamespaceAll = "all" // AllNamespaces designates all namespaces. AllNamespaces = "" // ClusterScope designates a resource is not namespaced. ClusterScope = "-" // NotNamespaced designates a non resource namespace. NotNamespaced = "*" // CreateVerb represents create access on a resource. CreateVerb = "create" // UpdateVerb represents an update access on a resource. UpdateVerb = "update" // PatchVerb represents a patch access on a resource. PatchVerb = "patch" // DeleteVerb represents a delete access on a resource. DeleteVerb = "delete" // GetVerb represents a get access on a resource. GetVerb = "get" // ListVerb represents a list access on a resource. ListVerb = "list" // WatchVerb represents a watch access on a resource. WatchVerb = "watch" )
const ( // CallTimeout represents default api call timeout. CallTimeout = 5 * time.Second )
Variables ¶
var ( // GetAccess reads a resource. GetAccess = []string{GetVerb} // ListAccess list resources. ListAccess = []string{ListVerb} // MonitorAccess monitors a collection of resources. MonitorAccess = []string{ListVerb, WatchVerb} // ReadAllAccess represents an all read access to a resource. ReadAllAccess = []string{GetVerb, ListVerb, WatchVerb} )
Functions ¶
func CleanseNamespace ¶
CleanseNamespace ensures all ns maps to blank.
func IsAllNamespaces ¶
IsAllNamespaces returns true if all namespaces, false otherwise.
func IsClusterScoped ¶
IsClusterScoped returns true if resource is not namespaced.
func IsClusterWide ¶
IsClusterWide returns true if ns designates cluster scope, false otherwise.
func IsNamespaced ¶
IsNamespaced returns true if a specific ns is given.
func MetaFQN ¶
func MetaFQN(m metav1.ObjectMeta) string
MetaFQN returns a fully qualified resource name.
func Namespaced ¶
Namespaced converts a resource path to namespace and resource name.
func ResetMetrics ¶ added in v0.16.0
func ResetMetrics()
ResetMetrics resets the metric server handle.
func ToPercentage ¶ added in v0.17.4
ToPercentage computes percentage.
func ToPercentageStr ¶ added in v0.19.5
ToPercentageStr computes percentage, but if v2 is 0, it will return NAValue instead of 0
Types ¶
type APIClient ¶
type APIClient struct {
// contains filtered or unexported fields
}
APIClient represents a Kubernetes api client.
func InitConnectionOrDie ¶
InitConnectionOrDie initialize connection from command line args. Checks for connectivity with the api server.
func NewTestClient ¶ added in v0.17.0
func NewTestClient() *APIClient
NewTestClient for testing ONLY!!
func (*APIClient) ActiveCluster ¶ added in v0.19.0
ActiveCluster returns the current cluster name.
func (*APIClient) ActiveNamespace ¶ added in v0.19.0
ActiveNamespace returns the current namespace.
func (*APIClient) CachedDiscoveryOrDie ¶
func (a *APIClient) CachedDiscoveryOrDie() *disk.CachedDiscoveryClient
CachedDiscoveryOrDie returns a cached discovery client.
func (*APIClient) CheckConnectivity ¶ added in v0.13.4
CheckConnectivity return true if api server is cool or false otherwise.
func (*APIClient) CurrentNamespaceName ¶
CurrentNamespaceName return namespace name set via either cli arg or cluster config.
func (*APIClient) DialOrDie ¶
func (a *APIClient) DialOrDie() kubernetes.Interface
DialOrDie returns a handle to api server or die.
func (*APIClient) DynDialOrDie ¶
DynDialOrDie returns a handle to a dynamic interface.
func (*APIClient) HasMetrics ¶
HasMetrics returns true if the cluster supports metrics.
func (*APIClient) IsActiveNamespace ¶ added in v0.19.0
IsActiveNamespace returns true if namespaces matches.
func (*APIClient) RestConfigOrDie ¶
func (a *APIClient) RestConfigOrDie() *restclient.Config
RestConfigOrDie returns a rest api client.
func (*APIClient) ServerVersion ¶
ServerVersion returns the current server version info.
func (*APIClient) SwitchContext ¶ added in v0.14.1
SwitchContext handles kubeconfig context switches.
type Authorizer ¶
type Authorizer interface { // CanI returns true if the user can use these actions for a given resource. CanI(ns, gvr string, verbs []string) (bool, error) }
Authorizer checks what a user can or cannot do to a resource.
type ClusterMetrics ¶
type ClusterMetrics struct {
PercCPU, PercMEM, PercEphemeral int
}
ClusterMetrics summarizes total node metrics as percentages.
type Config ¶
type Config struct {
// contains filtered or unexported fields
}
Config tracks a kubernetes configuration.
func NewConfig ¶
func NewConfig(f *genericclioptions.ConfigFlags) *Config
NewConfig returns a new k8s config or an error if the flags are invalid.
func (*Config) ClusterNameFromContext ¶
ClusterNameFromContext returns the cluster associated with the given context.
func (*Config) ClusterNames ¶
ClusterNames fetch all kubeconfig defined clusters.
func (*Config) ConfigAccess ¶
func (c *Config) ConfigAccess() (clientcmd.ConfigAccess, error)
ConfigAccess return the current kubeconfig api server access configuration.
func (*Config) ContextNames ¶
ContextNames fetch all available contexts.
func (*Config) Contexts ¶
func (c *Config) Contexts() (map[string]*clientcmdapi.Context, error)
Contexts fetch all available contexts.
func (*Config) CurrentClusterName ¶
CurrentClusterName returns the active cluster name.
func (*Config) CurrentContextName ¶
CurrentContextName returns the currently active config context.
func (*Config) CurrentGroupNames ¶
CurrentGroupNames retrieves the active group names.
func (*Config) CurrentNamespaceName ¶
CurrentNamespaceName retrieves the active namespace.
func (*Config) CurrentUserName ¶
CurrentUserName retrieves the active user name.
func (*Config) DelContext ¶
DelContext remove a given context from the configuration.
func (*Config) Flags ¶
func (c *Config) Flags() *genericclioptions.ConfigFlags
Flags returns configuration flags.
func (*Config) GetContext ¶
func (c *Config) GetContext(n string) (*clientcmdapi.Context, error)
GetContext fetch a given context or error if it does not exists.
func (*Config) ImpersonateGroups ¶ added in v0.16.0
ImpersonateGroups retrieves the active groupsif set on the CLI.
func (*Config) ImpersonateUser ¶ added in v0.16.0
ImpersonateUser retrieves the active user name if set on the CLI.
func (*Config) NamespaceNames ¶
NamespaceNames fetch all available namespaces on current cluster.
func (*Config) RESTConfig ¶
func (c *Config) RESTConfig() (*restclient.Config, error)
RESTConfig fetch the current REST api service connection.
func (*Config) RawConfig ¶
func (c *Config) RawConfig() (clientcmdapi.Config, error)
RawConfig fetch the current kubeconfig with no overrides.
func (*Config) SwitchContext ¶
SwitchContext changes the kubeconfig context to a new cluster.
type Connection ¶
type Connection interface { Authorizer // Config returns current config. Config() *Config // DialOrDie connects to api server. DialOrDie() kubernetes.Interface // SwitchContext switches cluster based on context. SwitchContext(ctx string) error // CachedDiscoveryOrDie connects to discovery client. CachedDiscoveryOrDie() *disk.CachedDiscoveryClient // RestConfigOrDie connects to rest client. RestConfigOrDie() *restclient.Config // MXDial connects to metrics server. MXDial() (*versioned.Clientset, error) // DynDialOrDie connects to dynamic client. DynDialOrDie() dynamic.Interface // HasMetrics checks if metrics server is available. HasMetrics() bool // ValidNamespaces returns all available namespaces. ValidNamespaces() ([]v1.Namespace, error) // ServerVersion returns current server version. ServerVersion() (*version.Info, error) // CheckConnectivity checks if api server connection is happy or not. CheckConnectivity() bool // ActiveCluster returns the current cluster name. ActiveCluster() string // ActiveNamespace returns the current namespace. ActiveNamespace() string // IsActiveNamespace checks if given ns is active. IsActiveNamespace(string) bool }
Connection represents a Kubenetes apiserver connection.
type CurrentMetrics ¶ added in v0.13.3
type CurrentMetrics struct {
CurrentCPU, CurrentMEM, CurrentEphemeral int64
}
CurrentMetrics tracks current cpu/mem.
type GVR ¶
type GVR struct {
// contains filtered or unexported fields
}
GVR represents a kubernetes resource schema as a string. Format is group/version/resources:subresource
func FromGVAndR ¶
FromGVAndR builds a gvr from a group/version and resource.
func NewGVRFromMeta ¶
func NewGVRFromMeta(a metav1.APIResource) GVR
NewGVRFromMeta builds a gvr from resource metadata.
func (GVR) AsResourceName ¶
AsResourceName returns a resource . separated descriptor in the shape of kind.version.group.
func (GVR) GR ¶ added in v0.13.1
func (g GVR) GR() *schema.GroupResource
GR returns a full schema representation.
func (GVR) GV ¶ added in v0.13.1
func (g GVR) GV() schema.GroupVersion
GV returns the group version scheme representation.
func (GVR) GVK ¶ added in v0.17.6
func (g GVR) GVK() schema.GroupVersionKind
GVK returns a full schema representation.
func (GVR) GVR ¶ added in v0.13.1
func (g GVR) GVR() schema.GroupVersionResource
GVR returns a full schema representation.
func (GVR) SubResource ¶
SubResource returns a sub resource if available.
type MetricsServer ¶
type MetricsServer struct { Connection // contains filtered or unexported fields }
MetricsServer serves cluster metrics for nodes and pods.
var MetricsDial *MetricsServer
MetricsDial tracks global metric server handle.
func DialMetrics ¶ added in v0.16.0
func DialMetrics(c Connection) *MetricsServer
DialMetrics dials the metrics server.
func NewMetricsServer ¶
func NewMetricsServer(c Connection) *MetricsServer
NewMetricsServer return a metric server instance.
func (*MetricsServer) ClusterLoad ¶
func (m *MetricsServer) ClusterLoad(nos *v1.NodeList, nmx *mv1beta1.NodeMetricsList, mx *ClusterMetrics) error
ClusterLoad retrieves all cluster nodes metrics.
func (*MetricsServer) FetchNodesMetrics ¶
func (m *MetricsServer) FetchNodesMetrics(ctx context.Context) (*mv1beta1.NodeMetricsList, error)
FetchNodesMetrics return all metrics for nodes.
func (*MetricsServer) FetchPodMetrics ¶
func (m *MetricsServer) FetchPodMetrics(ctx context.Context, fqn string) (*mv1beta1.PodMetrics, error)
FetchPodMetrics return all metrics for pods in a given namespace.
func (*MetricsServer) FetchPodsMetrics ¶
func (m *MetricsServer) FetchPodsMetrics(ctx context.Context, ns string) (*mv1beta1.PodMetricsList, error)
FetchPodsMetrics return all metrics for pods in a given namespace.
func (*MetricsServer) NodesMetrics ¶
func (m *MetricsServer) NodesMetrics(nodes *v1.NodeList, metrics *mv1beta1.NodeMetricsList, mmx NodesMetrics)
NodesMetrics retrieves metrics for a given set of nodes.
func (*MetricsServer) PodsMetrics ¶
func (m *MetricsServer) PodsMetrics(pods *mv1beta1.PodMetricsList, mmx PodsMetrics)
PodsMetrics retrieves metrics for all pods in a given namespace.
type NodeMetrics ¶
type NodeMetrics struct { CurrentMetrics AllocatableCPU, AllocatableMEM, AllocatableEphemeral int64 AvailableCPU, AvailableMEM, AvailableEphemeral int64 TotalCPU, TotalMEM, TotalEphemeral int64 }
NodeMetrics describes raw node metrics.
type NodesMetrics ¶
type NodesMetrics map[string]NodeMetrics
NodesMetrics tracks usage metrics per nodes.
type PodMetrics ¶
type PodMetrics CurrentMetrics
PodMetrics represent an aggregation of all pod containers metrics.
type PodsMetrics ¶
type PodsMetrics map[string]PodMetrics
PodsMetrics tracks usage metrics per pods.
type PortTunnel ¶ added in v0.15.2
type PortTunnel struct {
Address, LocalPort, ContainerPort string
}
PortTunnel represents a host tunnel port mapper.
func (PortTunnel) PortMap ¶ added in v0.15.2
func (t PortTunnel) PortMap() string
PortMap returns a port mapping.