Слияние кода завершено, страница обновится автоматически
//
// DISCLAIMER
//
// Copyright 2017-2024 ArangoDB GmbH, Cologne, Germany
//
// Licensed 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.
//
// Copyright holder is ArangoDB GmbH, Cologne, Germany
//
package main
import (
"fmt"
"time"
"github.com/arangodb-helper/arangodb/pkg/definitions"
"github.com/arangodb-helper/arangodb/service"
"github.com/arangodb-helper/arangodb/service/options"
)
type starterOptions struct {
cluster struct {
advertisedEndpoint string
agencySize int
startAgent []bool
startDBServer []bool
startCoordinator []bool
}
server struct {
useLocalBin bool
arangodPath string
arangodJSPath string
rrPath string
threads int
storageEngine string
}
log struct {
dir string // Custom log directory (default "")
verbose bool
color bool
console bool
file bool
timeFormat string
rotateFilesToKeep int
rotateInterval time.Duration
}
starter struct {
id string
masterAddresses []string
masterPort int
ownAddress string
startLocalSlaves bool
mode string
dataDir string
bindAddress string
allPortOffsetsUnique bool
disableIPv6 bool
debugCluster bool
instanceUpTimeout time.Duration
}
auth struct {
jwtSecretFile string
}
ssl struct {
keyFile string
autoKeyFile bool
autoServerName string
autoOrganization string
caFile string
}
rocksDB struct {
encryptionKeyFile string
encryptionKeyGenerator string
}
docker struct {
service.DockerConfig
imagePullPolicyRaw string
netHost bool // Deprecated
}
}
func preparePassthroughPrefixes() options.ConfigurationPrefixes {
return options.ConfigurationPrefixes{
// Old methods
"all": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all server instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByProcessTypeAndName(definitions.ServerTypeAgent, key)
},
DeprecatedHintFormat: "use --args.all.%s instead",
},
"coordinators": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all coordinator instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeCoordinator, key)
},
DeprecatedHintFormat: "use --args.coordinators.%s instead",
},
"dbservers": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all dbserver instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeDBServer, key)
},
DeprecatedHintFormat: "use --args.dbservers.%s instead",
},
"agents": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all agent instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeAgent, key)
},
DeprecatedHintFormat: "use --args.agents.%s instead",
},
// New methods for args
"args.all": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all server instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByProcessTypeAndName(definitions.ServerTypeAgent, key)
},
},
"args.coordinators": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all coordinator instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeCoordinator, key)
},
},
"args.dbservers": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all dbserver instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeDBServer, key)
},
},
"args.agents": {
Usage: func(key string) string {
return fmt.Sprintf("Passed through to all agent instances as --%s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.ArgByServerTypeAndName(definitions.ServerTypeAgent, key)
},
},
// New methods for envs
"envs.all": {
Usage: func(key string) string {
return fmt.Sprintf("Env passed to all server instances as %s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.EnvByProcessTypeAndName(definitions.ServerTypeAgent, key)
},
},
"envs.coordinators": {
Usage: func(key string) string {
return fmt.Sprintf("Env passed to all coordinator instances as %s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.EnvByServerTypeAndName(definitions.ServerTypeCoordinator, key)
},
},
"envs.dbservers": {
Usage: func(key string) string {
return fmt.Sprintf("Env passed to all dbserver instances as %s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.EnvByServerTypeAndName(definitions.ServerTypeDBServer, key)
},
},
"envs.agents": {
Usage: func(key string) string {
return fmt.Sprintf("Env passed to all agent instances as %s", key)
},
FieldSelector: func(p *options.Configuration, key string) *[]string {
return p.EnvByServerTypeAndName(definitions.ServerTypeAgent, key)
},
},
}
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )