Documentation ¶
Index ¶
- func HeadServiceName(name string) string
- func HeadlessServiceName(name string) string
- func HorizontalPodAutoscalerObjectMeta(sc *dcv1alpha1.SparkCluster) metav1.ObjectMeta
- func InstanceObjectName(instance string, comp Component) string
- func MetadataLabels(sc *dcv1alpha1.SparkCluster) map[string]string
- func MetadataLabelsWithComponent(sc *dcv1alpha1.SparkCluster, comp Component) map[string]string
- func NewClusterNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
- func NewHeadClientNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
- func NewHeadDashboardNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
- func NewHeadlessService(sc *dcv1alpha1.SparkCluster) *corev1.Service
- func NewHorizontalPodAutoscaler(sc *dcv1alpha1.SparkCluster) (*autoscalingv2beta2.HorizontalPodAutoscaler, error)
- func NewMasterService(sc *dcv1alpha1.SparkCluster) *corev1.Service
- func NewPodSecurityPolicyRBAC(sc *dcv1alpha1.SparkCluster) (*rbacv1.Role, *rbacv1.RoleBinding)
- func NewServiceAccount(sc *dcv1alpha1.SparkCluster) *corev1.ServiceAccount
- func NewStatefulSet(sc *dcv1alpha1.SparkCluster, comp Component) (*appsv1.StatefulSet, error)
- func SelectorLabels(sc *dcv1alpha1.SparkCluster) map[string]string
- func SelectorLabelsWithComponent(sc *dcv1alpha1.SparkCluster, comp Component) map[string]string
- type Component
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func HeadServiceName ¶
HeadServiceName returns the name of the service that points to the spark head pod.
func HeadlessServiceName ¶
func HorizontalPodAutoscalerObjectMeta ¶
func HorizontalPodAutoscalerObjectMeta(sc *dcv1alpha1.SparkCluster) metav1.ObjectMeta
HorizontalPodAutoscalerObjectMeta returns the ObjectMeta object used to identify new HPA objects.
func InstanceObjectName ¶
InstanceObjectName returns the name that will be used to create most owned cluster resources.
func MetadataLabels ¶
func MetadataLabels(sc *dcv1alpha1.SparkCluster) map[string]string
MetadataLabels returns standard metadata for spark resources.
func MetadataLabelsWithComponent ¶
func MetadataLabelsWithComponent(sc *dcv1alpha1.SparkCluster, comp Component) map[string]string
MetadataLabelsWithComponent returns standard component metadata for spark resources.
func NewClusterNetworkPolicy ¶
func NewClusterNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
NewClusterNetworkPolicy generates a network policy that allows all nodes within a single cluster to communicate on all ports.
func NewHeadClientNetworkPolicy ¶
func NewHeadClientNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
NewHeadClientNetworkPolicy generates a network policy that allows client access to any pods that have been appointed with the configured client server labels.
func NewHeadDashboardNetworkPolicy ¶
func NewHeadDashboardNetworkPolicy(sc *dcv1alpha1.SparkCluster) *networkingv1.NetworkPolicy
NewHeadDashboardNetworkPolicy generates a network policy that allows dashboard access to any pods that have been appointed with configured dashboard labels.
func NewHeadlessService ¶
func NewHeadlessService(sc *dcv1alpha1.SparkCluster) *corev1.Service
NewHeadlessService creates a headless service that points to worker nodes
func NewHorizontalPodAutoscaler ¶
func NewHorizontalPodAutoscaler(sc *dcv1alpha1.SparkCluster) (*autoscalingv2beta2.HorizontalPodAutoscaler, error)
NewHorizontalPodAutoscaler generates an HPA that targets a SparkCluster resource.
The metrics-server needs to be launched separately and the worker deployment requires cpu resource requests in order for this object to have any effect.
func NewMasterService ¶
func NewMasterService(sc *dcv1alpha1.SparkCluster) *corev1.Service
NewMasterService creates a ClusterIP service that points to the head node. Dashboard port is exposed when enabled.
func NewPodSecurityPolicyRBAC ¶
func NewPodSecurityPolicyRBAC(sc *dcv1alpha1.SparkCluster) (*rbacv1.Role, *rbacv1.RoleBinding)
NewPodSecurityPolicyRBAC generates the role and role binding required to use a pod security policy. The role is bound to the service account used by the spark cluster pods.
func NewServiceAccount ¶
func NewServiceAccount(sc *dcv1alpha1.SparkCluster) *corev1.ServiceAccount
NewServiceAccount generates a service account resource without API access.
func NewStatefulSet ¶
func NewStatefulSet(sc *dcv1alpha1.SparkCluster, comp Component) (*appsv1.StatefulSet, error)
NewStatefulSet generates a Deployment configured to manage Spark cluster nodes. The configuration is based the provided spec and the desired Component workload.
func SelectorLabels ¶
func SelectorLabels(sc *dcv1alpha1.SparkCluster) map[string]string
SelectorLabels returns a resource selector clause for spark resources.
func SelectorLabelsWithComponent ¶
func SelectorLabelsWithComponent(sc *dcv1alpha1.SparkCluster, comp Component) map[string]string
SelectorLabelsWithComponent returns a resource component selector clause for spark resources.
Types ¶
type Component ¶
type Component string
Component is used to drive Kubernetes object generation for different spark types.
const ( // ComponentNone indicates a generic spark resource. ComponentNone Component = "none" // ComponentMaster indicates a spark master resource. ComponentMaster Component = "master" // ComponentWorker indicates a spark worker resource. ComponentWorker Component = "worker" // ApplicationName defines the static name used to generate spark object metadata. ApplicationName = "spark" )