Skip to content

Commit

Permalink
support streaming-node
Browse files Browse the repository at this point in the history
Signed-off-by: haorenfsa <[email protected]>
  • Loading branch information
haorenfsa committed Dec 4, 2024
1 parent ea9cd59 commit 24f4ef4
Show file tree
Hide file tree
Showing 22 changed files with 4,556 additions and 1,413 deletions.
8 changes: 4 additions & 4 deletions apis/milvus.io/v1alpha1/milvus_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -111,9 +111,9 @@ type MilvusReplicas struct {

// +genclient
// +genclient:noStatus
//+kubebuilder:object:root=true
//+kubebuilder:subresource:status
//+kubebuilder:resource:path=milvuses,singular=milvus,shortName=mi
// +kubebuilder:object:root=true
// +kubebuilder:subresource:status
// +kubebuilder:resource:path=milvuses,singular=milvus,shortName=mi
// Milvus is the Schema for the milvus API
type Milvus struct {
metav1.TypeMeta `json:",inline"`
Expand All @@ -123,7 +123,7 @@ type Milvus struct {
Status v1beta1.MilvusStatus `json:"status,omitempty"`
}

//+kubebuilder:object:root=true
// +kubebuilder:object:root=true
// MilvusList contains a list of Milvus
type MilvusList struct {
metav1.TypeMeta `json:",inline"`
Expand Down
47 changes: 28 additions & 19 deletions apis/milvus.io/v1beta1/components_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,25 +7,27 @@ import (
type ComponentType string

const (
RootCoord ComponentType = "rootCoord"
DataCoord ComponentType = "dataCoord"
QueryCoord ComponentType = "queryCoord"
IndexCoord ComponentType = "indexCoord"
DataNode ComponentType = "dataNode"
QueryNode ComponentType = "queryNode"
IndexNode ComponentType = "indexNode"
Proxy ComponentType = "proxy"

MixCoordName = "mixcoord"
RootCoordName = "rootcoord"
DataCoordName = "datacoord"
QueryCoordName = "querycoord"
IndexCoordName = "indexcoord"
DataNodeName = "datanode"
QueryNodeName = "querynode"
IndexNodeName = "indexnode"
ProxyName = "proxy"
StandaloneName = "standalone"
RootCoord ComponentType = "rootCoord"
DataCoord ComponentType = "dataCoord"
QueryCoord ComponentType = "queryCoord"
IndexCoord ComponentType = "indexCoord"
DataNode ComponentType = "dataNode"
QueryNode ComponentType = "queryNode"
IndexNode ComponentType = "indexNode"
StreamingNode ComponentType = "streamingNode"
Proxy ComponentType = "proxy"

MixCoordName = "mixcoord"
RootCoordName = "rootcoord"
DataCoordName = "datacoord"
QueryCoordName = "querycoord"
IndexCoordName = "indexcoord"
DataNodeName = "datanode"
QueryNodeName = "querynode"
IndexNodeName = "indexnode"
ProxyName = "proxy"
StandaloneName = "standalone"
StreamingNodeName = "streamingnode"
)

var (
Expand Down Expand Up @@ -220,6 +222,9 @@ type MilvusComponents struct {
// +kubebuilder:validation:Optional
QueryNode *MilvusQueryNode `json:"queryNode,omitempty"`

// +kubebuilder:validation:Optional
StreamingNode *MilvusStreamingNode `json:"streamingNode,omitempty"`

// +kubebuilder:validation:Optional
Standalone *MilvusStandalone `json:"standalone,omitempty"`
}
Expand Down Expand Up @@ -280,6 +285,10 @@ type MilvusIndexCoord struct {
Component `json:",inline"`
}

type MilvusStreamingNode struct {
Component `json:",inline"`
}

type MilvusStandalone struct {
ServiceComponent `json:",inline"`
}
Expand Down
15 changes: 10 additions & 5 deletions apis/milvus.io/v1beta1/milvus_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,14 @@ func (ms *MilvusSpec) GetPersistenceConfig() *Persistence {
return nil
}

func (ms *MilvusSpec) UseMixCoord() bool {
return ms.Com.MixCoord != nil
}

func (ms *MilvusSpec) UseStreamingNode() bool {
return ms.Com.StreamingNode != nil
}

// MilvusMode defines the mode of Milvus deployment
type MilvusMode string

Expand Down Expand Up @@ -159,11 +167,6 @@ type MilvusStatus struct {
// IngressStatus of the ingress created by milvus
IngressStatus networkv1.IngressStatus `json:"ingress,omitempty"`

// DeprecatedReplicas is deprecated, will be removed in next major version, use ComponentsDeployStatus instead
// DeprecatedReplicas is the number of updated replicas in ready status
// +kubebuilder:validation:Optional
DeprecatedReplicas MilvusReplicas `json:"replicas,omitempty"`

// ComponentsDeployStatus contains the map of component's name to the status of each component deployment
// it is used to check the status of rolling update of each component
// +optional
Expand Down Expand Up @@ -286,6 +289,8 @@ type MilvusReplicas struct {
//+kubebuilder:validation:Optional
QueryNode int `json:"queryNode,omitempty"`
//+kubebuilder:validation:Optional
StreamingNode int `json:"streamingNode,omitempty"`
//+kubebuilder:validation:Optional
Standalone int `json:"standalone,omitempty"`
}

Expand Down
7 changes: 6 additions & 1 deletion apis/milvus.io/v1beta1/milvus_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ func (r *Milvus) DefaultComponents() {
if spec.Com.Proxy == nil {
spec.Com.Proxy = &MilvusProxy{}
}
if spec.Com.MixCoord == nil {
if !r.Spec.UseMixCoord() {
if r.noCoordSpecifiedByUser() {
// default to use mixcoord
spec.Com.MixCoord = &MilvusMixCoord{}
Expand Down Expand Up @@ -301,6 +301,11 @@ func (r *Milvus) defaultComponentsReplicas() {
if spec.Com.Standalone.Replicas == nil {
spec.Com.Standalone.Replicas = &defaultNoReplicas
}
if r.Spec.UseStreamingNode() {
if spec.Com.StreamingNode.Replicas == nil {
spec.Com.StreamingNode.Replicas = &defaultReplicas
}
}
if spec.Com.MixCoord != nil {
if spec.Com.MixCoord.Replicas == nil {
spec.Com.MixCoord.Replicas = &defaultReplicas
Expand Down
22 changes: 21 additions & 1 deletion apis/milvus.io/v1beta1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit 24f4ef4

Please sign in to comment.