dragonfly/cdn/config/config.go

246 lines
7.4 KiB
Go

/*
* Copyright 2020 The Dragonfly Authors
*
* 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.
*/
package config
import (
"time"
"gopkg.in/yaml.v3"
"d7y.io/dragonfly/v2/cdn/constants"
"d7y.io/dragonfly/v2/cdn/plugins"
"d7y.io/dragonfly/v2/cdn/storedriver"
"d7y.io/dragonfly/v2/cmd/dependency/base"
"d7y.io/dragonfly/v2/pkg/unit"
"d7y.io/dragonfly/v2/pkg/util/net/iputils"
)
// New creates an instant with default values.
func New() *Config {
return &Config{
BaseProperties: NewDefaultBaseProperties(),
Plugins: NewDefaultPlugins(),
}
}
// Config contains all configuration of cdn node.
type Config struct {
base.Options `yaml:",inline" mapstructure:",squash"`
*BaseProperties `yaml:"base" mapstructure:"base"`
Plugins map[plugins.PluginType][]*plugins.PluginProperties `yaml:"plugins" mapstructure:"plugins"`
}
func (c *Config) String() string {
if out, err := yaml.Marshal(c); err == nil {
return string(out)
}
return ""
}
// NewDefaultPlugins creates plugin instants with default values.
func NewDefaultPlugins() map[plugins.PluginType][]*plugins.PluginProperties {
return map[plugins.PluginType][]*plugins.PluginProperties{
plugins.StorageDriverPlugin: {
{
Name: "disk",
Enable: true,
Config: &storedriver.Config{
BaseDir: DefaultDiskBaseDir,
},
}, {
Name: "memory",
Enable: false,
Config: &storedriver.Config{
BaseDir: DefaultMemoryBaseDir,
},
},
}, plugins.StorageManagerPlugin: {
{
Name: "disk",
Enable: true,
Config: &StorageConfig{
GCInitialDelay: 0 * time.Second,
GCInterval: 15 * time.Second,
DriverConfigs: map[string]*DriverConfig{
"disk": {
GCConfig: &GCConfig{
YoungGCThreshold: 100 * unit.GB,
FullGCThreshold: 5 * unit.GB,
CleanRatio: 1,
IntervalThreshold: 2 * time.Hour,
}},
},
},
}, {
Name: "hybrid",
Enable: false,
Config: &StorageConfig{
GCInitialDelay: 0 * time.Second,
GCInterval: 15 * time.Second,
DriverConfigs: map[string]*DriverConfig{
"disk": {
GCConfig: &GCConfig{
YoungGCThreshold: 100 * unit.GB,
FullGCThreshold: 5 * unit.GB,
CleanRatio: 1,
IntervalThreshold: 2 * time.Hour,
},
},
"memory": {
GCConfig: &GCConfig{
YoungGCThreshold: 100 * unit.GB,
FullGCThreshold: 5 * unit.GB,
CleanRatio: 3,
IntervalThreshold: 2 * time.Hour,
},
},
},
},
},
},
}
}
// NewDefaultBaseProperties creates an base properties instant with default values.
func NewDefaultBaseProperties() *BaseProperties {
return &BaseProperties{
ListenPort: constants.DefaultListenPort,
DownloadPort: constants.DefaultDownloadPort,
SystemReservedBandwidth: constants.DefaultSystemReservedBandwidth,
MaxBandwidth: constants.DefaultMaxBandwidth,
AdvertiseIP: iputils.IPv4,
FailAccessInterval: constants.DefaultFailAccessInterval,
GCInitialDelay: constants.DefaultGCInitialDelay,
GCMetaInterval: constants.DefaultGCMetaInterval,
TaskExpireTime: constants.DefaultTaskExpireTime,
StorageMode: constants.DefaultStorageMode,
Manager: ManagerConfig{
KeepAlive: KeepAliveConfig{
Interval: constants.DefaultKeepAliveInterval,
},
},
Host: HostConfig{},
Metrics: &RestConfig{
Addr: ":8080",
},
}
}
type StorageConfig struct {
GCInitialDelay time.Duration `yaml:"gcInitialDelay"`
GCInterval time.Duration `yaml:"gcInterval"`
DriverConfigs map[string]*DriverConfig `yaml:"driverConfigs"`
}
type DriverConfig struct {
GCConfig *GCConfig `yaml:"gcConfig"`
}
// GCConfig gc config
type GCConfig struct {
YoungGCThreshold unit.Bytes `yaml:"youngGCThreshold"`
FullGCThreshold unit.Bytes `yaml:"fullGCThreshold"`
CleanRatio int `yaml:"cleanRatio"`
IntervalThreshold time.Duration `yaml:"intervalThreshold"`
}
// BaseProperties contains all basic properties of cdn system.
type BaseProperties struct {
// ListenPort is the port cdn server listens on.
// default: 8002
ListenPort int `yaml:"listenPort" mapstructure:"listenPort"`
// DownloadPort is the port for download files from cdn.
// default: 8001
DownloadPort int `yaml:"downloadPort" mapstructure:"downloadPort"`
// SystemReservedBandwidth is the network bandwidth reserved for system software.
// default: 20 MB, in format of G(B)/g/M(B)/m/K(B)/k/B, pure number will also be parsed as Byte.
SystemReservedBandwidth unit.Bytes `yaml:"systemReservedBandwidth" mapstructure:"systemReservedBandwidth"`
// MaxBandwidth is the network bandwidth that cdn system can use.
// default: 200 MB, in format of G(B)/g/M(B)/m/K(B)/k/B, pure number will also be parsed as Byte.
MaxBandwidth unit.Bytes `yaml:"maxBandwidth" mapstructure:"maxBandwidth"`
// AdvertiseIP is used to set the ip that we advertise to other peer in the p2p-network.
// By default, the first non-loop address is advertised.
AdvertiseIP string `yaml:"advertiseIP" mapstructure:"advertiseIP"`
// FailAccessInterval is the interval time after failed to access the URL.
// unit: minutes
// default: 3
FailAccessInterval time.Duration `yaml:"failAccessInterval" mapstructure:"failAccessInterval"`
// gc related
// GCInitialDelay is the delay time from the start to the first GC execution.
// default: 6s
GCInitialDelay time.Duration `yaml:"gcInitialDelay" mapstructure:"gcInitialDelay"`
// GCMetaInterval is the interval time to execute GC meta.
// default: 2min
GCMetaInterval time.Duration `yaml:"gcMetaInterval" mapstructure:"gcMetaInterval"`
// TaskExpireTime when a task is not accessed within the taskExpireTime,
// and it will be treated to be expired.
// default: 3min
TaskExpireTime time.Duration `yaml:"taskExpireTime" mapstructure:"taskExpireTime"`
// StorageMode disk/hybrid/memory
StorageMode string `yaml:"storageMode" mapstructure:"storageMode"`
// Log directory
LogDir string `yaml:"logDir" mapstructure:"logDir"`
// Manager configuration
Manager ManagerConfig `yaml:"manager" mapstructure:"manager"`
// Host configuration
Host HostConfig `yaml:"host" mapstructure:"host"`
// Metrics configuration
Metrics *RestConfig `yaml:"metrics" mapstructure:"metrics"`
}
type ManagerConfig struct {
// NetAddr is manager address.
Addr string `yaml:"addr" mapstructure:"addr"`
// CDNClusterID is cdn cluster id.
CDNClusterID uint `yaml:"cdnClusterID" mapstructure:"cdnClusterID"`
// KeepAlive configuration
KeepAlive KeepAliveConfig `yaml:"keepAlive" mapstructure:"keepAlive"`
}
type KeepAliveConfig struct {
// Keep alive interval
Interval time.Duration `yaml:"interval" mapstructure:"interval"`
}
type HostConfig struct {
// Location for scheduler
Location string `mapstructure:"location" yaml:"location"`
// IDC for scheduler
IDC string `mapstructure:"idc" yaml:"idc"`
}
type RestConfig struct {
Addr string `yaml:"addr" mapstructure:"addr"`
}