blob: 74043702448139cc6241a501b215f68ea47f82bb [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package v1alpha1
import (
v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// EDIT THIS FILE! THIS IS SCAFFOLDING FOR YOU TO OWN!
// NOTE: json tags are required. Any new fields you add must have json tags for the fields to be serialized.
//ServiceType defines the Service in Kubernetes of ShardingSphere-Proxy
type ServiceType struct {
// +kubebuilder:validation:Enum=ClusterIP;NodePort;LoadBalancer;ExternalName
Type v1.ServiceType `json:"type"`
// +kubebuilder:validation:Minimum=0
// The port on each node on which this service is exposed when type is
// NodePort or LoadBalancer. Usually assigned by the system. If a value is
// specified, in-range, and not in use it will be used, otherwise the
// operation will fail. If not specified, a port will be allocated if this
// Service requires one. If this field is specified when creating a
// Service which does not need it, creation will fail. This field will be
// wiped when updating a Service to no longer need it (e.g. changing type
// from NodePort to ClusterIP).
// More info: https://kubernetes.io/docs/concepts/services-networking/service/#type-nodeport
// +optional
NodePort int32 `json:"nodePort"`
}
//MySQLDriver Defines the mysql-driven version in ShardingSphere-proxy
type MySQLDriver struct {
// +kubebuilder:validation:Pattern=`^([1-9]\d|[1-9])(\.([1-9]\d|\d)){2}$`
// mysql-driven version,must be x.y.z
Version string `json:"version"`
}
// AutomaticScaling HPA configuration
type AutomaticScaling struct {
// +optional
Enable bool `json:"enable,omitempty"`
// +optional
ScaleUpWindows int32 `json:"scaleUpWindows,omitempty"`
// +optional
ScaleDownWindows int32 `json:"scaleDownWindows,omitempty"`
// +optional
Target int32 `json:"target,omitempty"`
// +optional
MaxInstance int32 `json:"maxInstance,omitempty"`
// +optional
MinInstance int32 `json:"minInstance,omitempty"`
}
// ProxySpec defines the desired state of ShardingSphereProxy
type ProxySpec struct {
// INSERT ADDITIONAL SPEC FIELDS - desired state of cluster
// Important: Run "make" to regenerate code after modifying this file
// Version is the version of ShardingSphere-Proxy
Version string `json:"version"`
ServiceType ServiceType `json:"serviceType"`
//Replicas is the expected number of replicas of ShardingSphere-Proxy
Replicas int32 `json:"replicas"`
// +optional
AutomaticScaling *AutomaticScaling `json:"automaticScaling,omitempty"`
// +optional
ImagePullSecrets []v1.LocalObjectReference `json:"imagePullSecrets,omitempty"`
// +kubebuilder:validation:MinLength=0
// +kubebuilder:validation:Pattern=`^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$`
//ProxyConfigName is the name of the ShardingSphereProxyServerConfig CRD
ProxyConfigName string `json:"proxyConfigName"`
// +kubebuilder:validation:Minimum=0
//Port is ShardingSphere-Proxy startup port
Port int32 `json:"port"`
// +optional
MySQLDriver *MySQLDriver `json:"mySQLDriver,omitempty"`
// +optional
Resources *v1.ResourceRequirements `json:"resources,omitempty"`
// Probes are not allowed for ephemeral containers.
// +optional
LivenessProbe *v1.Probe `json:"livenessProbe,omitempty"`
// Probes are not allowed for ephemeral containers.
// +optional
ReadinessProbe *v1.Probe `json:"readinessProbe,omitempty" `
// Probes are not allowed for ephemeral containers.
// +optional
StartupProbe *v1.Probe `json:"startupProbe,omitempty"`
}
//+kubebuilder:printcolumn:JSONPath=".status.readyNodes",name=ReadyNodes,type=integer
//+kubebuilder:printcolumn:JSONPath=".status.phase",name=Phase,type=string
//+kubebuilder:object:root=true
//+kubebuilder:subresource:status
// ShardingSphereProxy is the Schema for the proxies API
type ShardingSphereProxy struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec ProxySpec `json:"spec,omitempty"`
Status ProxyStatus `json:"status,omitempty"`
}
//+kubebuilder:object:root=true
// ShardingSphereProxyList contains a list of ShardingSphereProxy
type ShardingSphereProxyList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []ShardingSphereProxy `json:"items"`
}
func init() {
SchemeBuilder.Register(&ShardingSphereProxy{}, &ShardingSphereProxyList{})
}