mirror of https://github.com/milvus-io/milvus.git
380 lines
13 KiB
Go
380 lines
13 KiB
Go
// Licensed to the LF AI & Data foundation 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.
|
|
|
|
// This file is not used for now.
|
|
package configs
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"sync/atomic"
|
|
|
|
"github.com/BurntSushi/toml"
|
|
"github.com/milvus-io/milvus/internal/log"
|
|
"github.com/milvus-io/milvus/internal/util/metricsinfo"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
const MinToleranceTime = 3600
|
|
|
|
type Config struct {
|
|
Etcd Etcd `toml:"etcd" json:"etcd"`
|
|
Minio Minio `toml:"minio" json:"minio"`
|
|
Pulsar Pulsar `toml:"pulsar" json:"pulsar"`
|
|
RocksMq RocksMq `toml:"rocksmq" json:"rocksmq"`
|
|
Grpc Grpc `toml:"grpc" json:"grpc"`
|
|
FlowGraph FlowGraph `toml:"flowgraph" json:"flowgrph"`
|
|
RootCoord RootCoord `toml:"rootcoord" json:"rootcoord"`
|
|
Proxy Proxy `toml:"proxy" json:"proxy"`
|
|
QueryCoord QueryCoord `toml:"querycoord" json:"querycoord"`
|
|
QueryNode QueryNode `toml:"querynode" json:"querynode"`
|
|
IndexCoord IndexCoord `toml:"indexcoord" json:"indexcoord"`
|
|
IndexNode IndexNode `toml:"indexnode" json:"indexnode"`
|
|
DataCoord DataCoord `toml:"datacoord" json:"datacoord"`
|
|
DataNode DataNode `toml:"datanode" json:"datanode"`
|
|
TimeTickInterval uint64 `toml:"timetick-interval" json:"timetick-interval"`
|
|
TimeTickBufferSize uint32 `toml:"timetick-buffer-size" json:"timetick-buffer-size"`
|
|
NameLengthLimit uint32 `toml:"name-length-limit" json:"name-length-limit"`
|
|
FieldCountLimit uint32 `toml:"field-count-limit" json:"field-count-limit"`
|
|
DimensionLimit uint32 `toml:"dimension-limit" json:"dimension-limit"`
|
|
ShardCountLimit uint32 `toml:"shard-count-limit" json:"shard-count-limit"`
|
|
DMLChannelCount uint32 `toml:"dml-channel-count" json:"dml-channel-count"`
|
|
PartitionCountLimit uint32 `toml:"partition-count-limit" json:"partition-count-limit"`
|
|
EnableIndexMinSegmentSize uint32 `toml:"enable-index-min-segment-size" json:"enable-index-min-segment-size"`
|
|
SIMDType string `toml:"simd-type" json:"simd-type"`
|
|
Compaction Compaction `toml:"compaction" json:"compaction"`
|
|
Log Log `toml:"log" json:"log"`
|
|
LocalStorage LocalStorage `toml:"localstorage" json:"localstorage"`
|
|
SkipQueryChannelRecover bool `toml:"skip-query-channel-recover" json:"skip-query-channel-recover"`
|
|
Metrics Metrics `toml:"" json:"metrics"`
|
|
GarbageCollector GarbageCollector `toml:"gc" json:"gc"`
|
|
}
|
|
|
|
type Etcd struct {
|
|
Endpoints []string `toml:"endpoints" json:"endpoints"`
|
|
UseEmbed bool `toml:"use-embed" json:"use-embed"`
|
|
ConfigPath string `toml:"config-path" json:"config-path"`
|
|
DataPath string `toml:"data-path" json:"data-path"`
|
|
}
|
|
|
|
type Minio struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
AccessKeyID string `toml:"access-key-id" json:"access-key-id"`
|
|
SecretAccessKey string `toml:"secret-access-key" json:"secret-access-key"`
|
|
UseSSL bool `toml:"use-ssl" json:"use-ssl"`
|
|
BucketName string `toml:"bucket-name" json:"bucket-name"`
|
|
RootPath string `toml:"root-path" json:"root-path"`
|
|
}
|
|
|
|
type Pulsar struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
MaxMessageSize uint64 `toml:"max-message-size" json:"max-message-size"`
|
|
}
|
|
|
|
type RocksMq struct {
|
|
Path string `toml:"path" json:"path"`
|
|
PageSize uint32 `toml:"page-size" json:"page-size"`
|
|
RetentionDuration uint32 `toml:"retention-duration" json:"retention-duration"`
|
|
RetentionSize uint32 `toml:"retention-size" json:"retention-size"`
|
|
}
|
|
|
|
type Grpc struct {
|
|
ServerMaxReceiveSize uint64 `toml:"server-max-receive-size" json:"server-max-receive-size"`
|
|
ServerMaxSendSize uint64 `toml:"server-max-send-size" json:"server-max-send-size"`
|
|
ClientMaxReceiveSize uint64 `toml:"client-max-receive-size" json:"client-max-receive-size"`
|
|
ClientMaxSendSize uint64 `toml:"client-max-send-size" json:"client-max-send-size"`
|
|
}
|
|
|
|
type RootCoord struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
}
|
|
|
|
type Proxy struct {
|
|
Port int `toml:"port" json:"port"`
|
|
MaxTaskCount uint32 `toml:"max-task-count" json:"max-task-count"`
|
|
}
|
|
|
|
type QueryCoord struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
AutoHandOff bool `toml:"auto-handoff" json:"auto-handoff"`
|
|
AutoBalance bool `toml:"auto-balance" json:"auto-balance"`
|
|
BalanceInterval uint32 `toml:"balance-interval" json:"balance-interval"`
|
|
MemoryUsageLimitRatio uint32 `toml:"memory-usage-limit-ratio" json:"memory-usage-limit-ratio"`
|
|
AutoBalanceMemoryUsageGapRatio uint32 `toml:"auto-balance-memory-usage-gap-ratio" json:"auto-balance-memory-usage-gap-ratio"`
|
|
}
|
|
|
|
type FlowGraph struct {
|
|
QueueLengthLimit uint32 `toml:"queue-length-limit" json:"queue-length-limit"`
|
|
ParallelismLimit uint32 `toml:"parallelism-limit" json:"parallelism-limit"`
|
|
}
|
|
|
|
type QueryNode struct {
|
|
Port int `toml:"port" json:"port"`
|
|
GracefulTime uint32 `toml:"graceful-time" json:"graceful-time"`
|
|
StatsPublishInterval uint32 `toml:"stats-publish-interval" json:"stats-publish-interval"`
|
|
SegcoreChunkRows uint32 `toml:"segcore-chunk-rows" json:"segcore-chunk-rows"`
|
|
}
|
|
|
|
type IndexCoord struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
}
|
|
|
|
type IndexNode struct {
|
|
Port int `toml:"port" json:"port"`
|
|
}
|
|
|
|
type DataCoord struct {
|
|
Address string `toml:"address" json:"address"`
|
|
Port int `toml:"port" json:"port"`
|
|
}
|
|
|
|
type GarbageCollector struct {
|
|
Interval uint32 `toml:"interval" json:"interval"`
|
|
MissedFileTolerance uint32 `toml:"missed-files-tolerance" json:"missed-files-tolerance"`
|
|
DroppedFileTolerance uint32 `toml:"dropped-files-tolerance" json:"dropped-files-tolerance"`
|
|
}
|
|
|
|
type Compaction struct {
|
|
EnableCompaction bool `toml:"enable-compaction" json:"enable-compaction"`
|
|
}
|
|
|
|
type DataNode struct {
|
|
Port int `toml:"port" json:"port"`
|
|
InsertBufferSizeLimit uint32 `toml:"insert-buffer-size-limit" json:"insert-buffer-size-limit"`
|
|
}
|
|
|
|
type LocalStorage struct {
|
|
Enable bool `toml:"enable" json:"enable"`
|
|
Path string `toml:"path" json:"path"`
|
|
}
|
|
|
|
type Log struct {
|
|
Level string `toml:"level" json:"level"`
|
|
Format string `toml:"format" json:"format"`
|
|
File LogFileCfg `toml:"file" json:"file"`
|
|
}
|
|
|
|
type LogFileCfg struct {
|
|
RootPath string `toml:"root-path" json:"root-path"`
|
|
MaxSize uint32 `toml:"max-size" json:"max-size"`
|
|
MaxAge uint32 `toml:"max-age" json:"max-age"`
|
|
MaxBackups uint32 `toml:"max-backups" json:"max-backups"`
|
|
}
|
|
|
|
type Metrics struct {
|
|
GitCommit string `toml:"" json:"git-commit-key"`
|
|
DeployMode string `toml:"" json:"deploy-mode"`
|
|
GitBuildTags string `toml:"" json:"git-build-tags"`
|
|
BuildTime string `toml:"" json:"build-time"`
|
|
GoVersion string `toml:"" json:"go-version"`
|
|
}
|
|
|
|
var defaultCfg = Config{
|
|
Etcd: Etcd{
|
|
Endpoints: []string{"localhost:2379"},
|
|
UseEmbed: false,
|
|
},
|
|
Minio: Minio{
|
|
Address: "localhost",
|
|
Port: 9000,
|
|
AccessKeyID: "minioadmin",
|
|
SecretAccessKey: "minioadmin",
|
|
UseSSL: false,
|
|
BucketName: "a-bucket",
|
|
RootPath: "files",
|
|
},
|
|
Pulsar: Pulsar{
|
|
Address: "localhost",
|
|
Port: 6650,
|
|
MaxMessageSize: 5242880,
|
|
},
|
|
RocksMq: RocksMq{
|
|
Path: "/var/lib/milvus/rdb_data",
|
|
PageSize: 2147483648,
|
|
RetentionDuration: 10080,
|
|
RetentionSize: 8192,
|
|
},
|
|
Grpc: Grpc{
|
|
ServerMaxReceiveSize: 2147483647,
|
|
ServerMaxSendSize: 2147483647,
|
|
ClientMaxReceiveSize: 104857600,
|
|
ClientMaxSendSize: 104857600,
|
|
},
|
|
FlowGraph: FlowGraph{
|
|
QueueLengthLimit: 1024,
|
|
ParallelismLimit: 1024,
|
|
},
|
|
RootCoord: RootCoord{
|
|
Address: "localhost",
|
|
Port: 53100,
|
|
},
|
|
Proxy: Proxy{
|
|
Port: 53100,
|
|
MaxTaskCount: 1024,
|
|
},
|
|
QueryCoord: QueryCoord{
|
|
Address: "localhost",
|
|
Port: 19531,
|
|
AutoHandOff: true,
|
|
AutoBalance: true,
|
|
BalanceInterval: 60,
|
|
MemoryUsageLimitRatio: 90,
|
|
AutoBalanceMemoryUsageGapRatio: 30,
|
|
},
|
|
QueryNode: QueryNode{
|
|
Port: 21123,
|
|
GracefulTime: 0,
|
|
StatsPublishInterval: 1000,
|
|
SegcoreChunkRows: 32768,
|
|
},
|
|
IndexCoord: IndexCoord{
|
|
Address: "localhost",
|
|
Port: 31000,
|
|
},
|
|
IndexNode: IndexNode{
|
|
Port: 21121,
|
|
},
|
|
DataCoord: DataCoord{
|
|
Address: "localhost",
|
|
Port: 13333,
|
|
},
|
|
DataNode: DataNode{
|
|
Port: 21124,
|
|
InsertBufferSizeLimit: 16777216,
|
|
},
|
|
TimeTickInterval: 200,
|
|
TimeTickBufferSize: 512,
|
|
NameLengthLimit: 255,
|
|
FieldCountLimit: 256,
|
|
DimensionLimit: 32768,
|
|
ShardCountLimit: 256,
|
|
DMLChannelCount: 256,
|
|
PartitionCountLimit: 4096,
|
|
EnableIndexMinSegmentSize: 1024,
|
|
SIMDType: "auto",
|
|
Compaction: Compaction{
|
|
EnableCompaction: true,
|
|
},
|
|
Log: Log{
|
|
Level: "debug",
|
|
Format: "text",
|
|
File: LogFileCfg{
|
|
RootPath: "",
|
|
MaxSize: 300,
|
|
MaxAge: 10,
|
|
MaxBackups: 20,
|
|
},
|
|
},
|
|
LocalStorage: LocalStorage{
|
|
Enable: true,
|
|
Path: "/var/lib/milvus/data/",
|
|
},
|
|
SkipQueryChannelRecover: false,
|
|
Metrics: Metrics{
|
|
GitCommit: "",
|
|
DeployMode: "CLUSTER",
|
|
GitBuildTags: "",
|
|
GoVersion: "",
|
|
BuildTime: "",
|
|
},
|
|
GarbageCollector: GarbageCollector{
|
|
Interval: 3600,
|
|
MissedFileTolerance: 86400,
|
|
DroppedFileTolerance: 86400,
|
|
},
|
|
}
|
|
|
|
var globalConfig atomic.Value
|
|
|
|
func init() {
|
|
cfg := defaultCfg
|
|
SetGlobalConfig(&cfg)
|
|
}
|
|
|
|
func SetGlobalConfig(cfg *Config) {
|
|
globalConfig.Store(cfg)
|
|
}
|
|
|
|
func GetGlobalConfig() *Config {
|
|
return globalConfig.Load().(*Config)
|
|
}
|
|
|
|
func InitializeConfig(path string, enforceEnvCfg func(c *Config), enforceCmdCfg func(c *Config)) {
|
|
cfg := GetGlobalConfig()
|
|
if path != "" {
|
|
err := cfg.Load(path)
|
|
if err != nil {
|
|
if _, ok := err.(*ErrUndecodedConfig); ok {
|
|
log.Warn(err.Error())
|
|
} else {
|
|
log.Fatal("failed to load config", zap.String("filePath", path), zap.Error(err))
|
|
}
|
|
}
|
|
}
|
|
if enforceEnvCfg != nil {
|
|
enforceEnvCfg(cfg)
|
|
}
|
|
if enforceCmdCfg != nil {
|
|
enforceCmdCfg(cfg)
|
|
}
|
|
|
|
if err := cfg.Validate(); err != nil {
|
|
log.Fatal("config is not valid, please check the config file, environment variables and command options", zap.Error(err))
|
|
}
|
|
}
|
|
|
|
func (c *Config) Load(path string) error {
|
|
meta, err := toml.DecodeFile(path, c)
|
|
|
|
undecodedKeys := meta.Undecoded()
|
|
if len(undecodedKeys) > 0 && err == nil {
|
|
undecoded := make([]string, 0, len(undecodedKeys))
|
|
for _, k := range undecodedKeys {
|
|
undecoded = append(undecoded, k.String())
|
|
}
|
|
return &ErrUndecodedConfig{ConfigFile: path, Undecoded: undecoded}
|
|
}
|
|
|
|
return err
|
|
}
|
|
|
|
func (c *Config) Validate() error {
|
|
if c.Etcd.UseEmbed && c.Metrics.DeployMode != metricsinfo.StandaloneDeployMode {
|
|
return fmt.Errorf("can not use embed etcd in mode %s", c.Metrics.DeployMode)
|
|
}
|
|
if c.GarbageCollector.MissedFileTolerance < MinToleranceTime {
|
|
return fmt.Errorf("gc: missed file tolerance time can not be less than %d", MinToleranceTime)
|
|
}
|
|
if c.GarbageCollector.DroppedFileTolerance < MinToleranceTime {
|
|
return fmt.Errorf("gc: dropped file tolerance time can not be less than %d", MinToleranceTime)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type ErrUndecodedConfig struct {
|
|
ConfigFile string
|
|
Undecoded []string
|
|
}
|
|
|
|
func (e *ErrUndecodedConfig) Error() string {
|
|
return fmt.Sprintf("config file %s contains invalid configuration options: %s", e.ConfigFile, strings.Join(e.Undecoded, ","))
|
|
}
|