Documentation ¶
Index ¶
- Constants
- func ExecCmd(command string) error
- func ExecCmdWithContext(ctx context.Context, command string) error
- func ExecCmdWithOptions(ctx context.Context, command string, outputFunction func(string)) error
- func GetLocalK8sDeps() (*kubernetes.Clientset, *rest.Config, error)
- type Chaos
- type ChaosState
- type ConnectionInfo
- type ConnectionMode
- type Forwarder
- type K8sClient
- func (m *K8sClient) AddLabel(namespace string, selector string, label string) error
- func (m *K8sClient) AddPodAnnotation(namespace string, pod v1.Pod, key, value string) error
- func (m *K8sClient) AddPodLabel(namespace string, pod v1.Pod, key, value string) error
- func (m *K8sClient) AddPodsAnnotations(namespace string, podList *v1.PodList, annotations map[string]string) error
- func (m *K8sClient) AddPodsLabels(namespace string, podList *v1.PodList, labels map[string]string) error
- func (m *K8sClient) Apply(ctx context.Context, manifest, namespace string, waitForDeployment bool) error
- func (m *K8sClient) CopyFromPod(ctx context.Context, ...) error
- func (m *K8sClient) CopyToPod(namespace, src, destination, containername string) (*bytes.Buffer, *bytes.Buffer, *bytes.Buffer, error)
- func (m *K8sClient) Create(manifest string) error
- func (m *K8sClient) DeleteResource(namespace string, resource string, instance string) error
- func (m *K8sClient) DryRun(manifest string) error
- func (m *K8sClient) EnumerateInstances(namespace string, selector string) error
- func (m *K8sClient) ExecuteInPod(namespace, podName, containerName string, command []string) ([]byte, []byte, error)
- func (m *K8sClient) LabelChaosGroup(namespace string, labelPrefix string, startInstance int, endInstance int, ...) error
- func (m *K8sClient) LabelChaosGroupByLabels(namespace string, labels map[string]string, group string) error
- func (m *K8sClient) ListNamespaces(selector string) (*v1.NamespaceList, error)
- func (m *K8sClient) ListPods(namespace, selector string) (*v1.PodList, error)
- func (m *K8sClient) ListServices(namespace, selector string) (*v1.ServiceList, error)
- func (m *K8sClient) NamespaceExists(namespace string) bool
- func (m *K8sClient) RemoveNamespace(namespace string) error
- func (m *K8sClient) RolloutRestartBySelector(ctx context.Context, namespace, resource, selector string) error
- func (m *K8sClient) RolloutStatefulSets(ctx context.Context, namespace string) error
- func (m *K8sClient) UniqueLabels(namespace string, selector string) ([]string, error)
- func (m *K8sClient) WaitForDeploymentsAvailable(ctx context.Context, namespace string) error
- func (m *K8sClient) WaitForJob(namespaceName string, jobName string, fundReturnStatus func(string)) error
- func (m *K8sClient) WaitPodsReady(ns string, rcd *ReadyCheckData, expectedPodCount int) error
- type Protocol
- type ReadyCheckData
- type URLConverter
Constants ¶
const ( TempDebugManifest = "tmp-manifest-%s.yaml" K8sStatePollInterval = 10 * time.Second JobFinalizedTimeout = 2 * time.Minute AppLabel = "app" )
Variables ¶
This section is empty.
Functions ¶
func ExecCmdWithOptions ¶
func GetLocalK8sDeps ¶
func GetLocalK8sDeps() (*kubernetes.Clientset, *rest.Config, error)
GetLocalK8sDeps get local k8s context config
Types ¶
type Chaos ¶
Chaos is controller that manages Chaosmesh CRD instances to run experiments
type ChaosState ¶
type ChaosState struct {
ChaosDetails v1alpha1.ChaosStatus `json:"status"`
}
type ConnectionInfo ¶
type ConnectionInfo struct { Ports portforward.ForwardedPort Host string }
type ConnectionMode ¶
type ConnectionMode int
const ( LocalConnection ConnectionMode = iota RemoteConnection )
type Forwarder ¶
type Forwarder struct { Client *K8sClient KeepConnection bool Info map[string]interface{} // contains filtered or unexported fields }
func NewForwarder ¶
func (*Forwarder) FindPort ¶
func (m *Forwarder) FindPort(ks ...string) *URLConverter
func (*Forwarder) PrintLocalPorts ¶
func (m *Forwarder) PrintLocalPorts()
PrintLocalPorts prints all local forwarded ports
type K8sClient ¶
type K8sClient struct { ClientSet *kubernetes.Clientset RESTConfig *rest.Config }
K8sClient high level k8s client
func NewK8sClient ¶
NewK8sClient creates a new k8s client with a REST config
func (*K8sClient) AddPodAnnotation ¶
AddPodAnnotation adds an annotation to a pod
func (*K8sClient) AddPodLabel ¶
AddPodLabel adds a label to a pod
func (*K8sClient) AddPodsAnnotations ¶
func (m *K8sClient) AddPodsAnnotations(namespace string, podList *v1.PodList, annotations map[string]string) error
AddPodsAnnotations adds map of annotations to all pods in list
func (*K8sClient) AddPodsLabels ¶
func (m *K8sClient) AddPodsLabels(namespace string, podList *v1.PodList, labels map[string]string) error
AddPodsLabels adds map of labels to all pods in list
func (*K8sClient) Apply ¶
func (m *K8sClient) Apply(ctx context.Context, manifest, namespace string, waitForDeployment bool) error
Apply applying a manifest to a currently connected k8s context
func (*K8sClient) CopyFromPod ¶ added in v1.28.3
func (m *K8sClient) CopyFromPod(ctx context.Context, namespace, podName, containername, srcPath, destPath string) error
CopyFromPod copies src from a particular namespace:pod:container to local.
func (*K8sClient) CopyToPod ¶
func (m *K8sClient) CopyToPod(namespace, src, destination, containername string) (*bytes.Buffer, *bytes.Buffer, *bytes.Buffer, error)
CopyToPod copies src to a particular container. Destination should be in the form of a proper K8s destination path NAMESPACE/POD_NAME:folder/FILE_NAME
func (*K8sClient) DeleteResource ¶
DeleteResource deletes resource
func (*K8sClient) EnumerateInstances ¶
EnumerateInstances enumerate pods with instance label
func (*K8sClient) ExecuteInPod ¶
func (m *K8sClient) ExecuteInPod(namespace, podName, containerName string, command []string) ([]byte, []byte, error)
ExecuteInPod is similar to kubectl exec
func (*K8sClient) LabelChaosGroup ¶
func (*K8sClient) LabelChaosGroupByLabels ¶
func (*K8sClient) ListNamespaces ¶
func (m *K8sClient) ListNamespaces(selector string) (*v1.NamespaceList, error)
ListNamespaces lists k8s namespaces
func (*K8sClient) ListServices ¶
func (m *K8sClient) ListServices(namespace, selector string) (*v1.ServiceList, error)
ListPods lists services for a namespace and selector
func (*K8sClient) NamespaceExists ¶
NamespaceExists check if namespace exists
func (*K8sClient) RemoveNamespace ¶
RemoveNamespace removes namespace
func (*K8sClient) RolloutRestartBySelector ¶
func (m *K8sClient) RolloutRestartBySelector(ctx context.Context, namespace, resource, selector string) error
RolloutRestartBySelector rollouts and restarts object by selector
func (*K8sClient) RolloutStatefulSets ¶
RolloutStatefulSets applies "rollout statefulset" to all existing statefulsets in that namespace
func (*K8sClient) UniqueLabels ¶
UniqueLabels gets all unique application labels
func (*K8sClient) WaitForDeploymentsAvailable ¶
func (*K8sClient) WaitForJob ¶
func (m *K8sClient) WaitForJob(namespaceName string, jobName string, fundReturnStatus func(string)) error
WaitForJob wait for job execution, follow logs and returns an error if job failed
func (*K8sClient) WaitPodsReady ¶
func (m *K8sClient) WaitPodsReady(ns string, rcd *ReadyCheckData, expectedPodCount int) error
WaitPodsReady waits until all pods are ready
type Protocol ¶
type Protocol int
Protocol represents a URL scheme to use when fetching connection details
type ReadyCheckData ¶
ReadyCheckData data to check if selected pods are running and all containers are ready ( readiness check ) are ready
type URLConverter ¶
type URLConverter struct {
// contains filtered or unexported fields
}
URLConverter converts ports to URLs
func NewURLConverter ¶
func NewURLConverter(fp ConnectionInfo, err error) *URLConverter
NewURLConverter creates new URLConverter instance
func (*URLConverter) As ¶
func (m *URLConverter) As(conn ConnectionMode, proto Protocol) (string, error)
As converts host/port to an URL