Documentation ¶
Index ¶
- Constants
- Variables
- func CheckAndSetDefault(attribute interface{}, defaultValue interface{})
- func ConfigFilePaths() []string
- func Execute() error
- func InitConfigurationFiles()
- func InitFlags(version, commit string)
- func LoadPropertiesFromFile(cfg string) error
- func RegisterConfigFile(dynamicConfFilePath string, confFileName string, confPaths ...string) (string, error)
- func RegisterFlags()
- func RegisterRunner(r func(cmd *cobra.Command, args []string))
- func SeekConfigFileInPaths(configName string, searchPaths ...string) (string, error)
- func SetDefaults()
- func SetVersion(version, commit string)
- func UpdateAgentConfig(systemId string, updateTags []string, updateFeatures []string) (bool, error)
- type AgentAPI
- type AgentMetrics
- type Backoff
- type BoolFlag
- type Config
- func (c *Config) AllowedDirectories() []string
- func (c *Config) GetMetricsBackoffSettings() backoff.BackoffSettings
- func (c *Config) GetServerBackoffSettings() backoff.BackoffSettings
- func (c *Config) IsExtensionEnabled(extension string) bool
- func (c *Config) IsFeatureEnabled(feature string) bool
- func (c *Config) IsGrpcServerConfigured() bool
- type Dataplane
- type DurationFlag
- type IntFlag
- type LogConfig
- type Nginx
- type Registrable
- type Server
- type Status
- type StringFlag
- type StringMapFlag
- type StringSliceFlag
- type TLSConfig
Constants ¶
View Source
const ( MODULE = "NGINX-AGENT" DynamicConfigFileName = "agent-dynamic.conf" DynamicConfigFileAbsPath = "/var/lib/nginx-agent/agent-dynamic.conf" DynamicConfigFileAbsFreeBsdPath = "/var/db/nginx-agent/agent-dynamic.conf" ConfigFileName = "nginx-agent.conf" ConfigFileType = "yaml" LegacyEnvPrefix = "nms" EnvPrefix = "nginx_agent" ConfigPathKey = "path" DynamicConfigPathKey = "dynamic_config_path" VersionKey = "version" CloudAccountIdKey = "cloudaccountid" LocationKey = "location" DisplayNameKey = "display_name" InstanceGroupKey = "instance_group" ConfigDirsKey = "config_dirs" TagsKey = "tags" IgnoreDirectivesKey = "ignore_directives" QueueSizeKey = "queue_size" // viper keys used in config LogKey = "log" LogLevel = LogKey + agent_config.KeyDelimiter + "level" LogPath = LogKey + agent_config.KeyDelimiter + "path" // viper keys used in config ServerKey = "server" ServerHost = ServerKey + agent_config.KeyDelimiter + "host" ServerGrpcPort = ServerKey + agent_config.KeyDelimiter + "grpcport" ServerToken = ServerKey + agent_config.KeyDelimiter + "token" ServerMetrics = ServerKey + agent_config.KeyDelimiter + "metrics" ServerCommand = ServerKey + agent_config.KeyDelimiter + "command" ServerBackoff = ServerKey + agent_config.KeyDelimiter + "backoff" // viper keys used in config BackoffKey = "backoff" BackoffInitialInterval = ServerKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "initial_interval" BackoffRandomizationFactor = ServerKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "randomization_factor" BackoffMultiplier = ServerKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "multiplier" BackoffMaxInterval = ServerKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "max_interval" BackoffMaxElapsedTime = ServerKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "max_elapsed_time" // viper keys used in config APIKey = "api" AgentAPIHost = APIKey + agent_config.KeyDelimiter + "host" AgentAPIPort = APIKey + agent_config.KeyDelimiter + "port" AgentAPICert = APIKey + agent_config.KeyDelimiter + "cert" AgentAPIKey = APIKey + agent_config.KeyDelimiter + "key" // viper keys used in config TlsKey = "tls" TlsEnable = TlsKey + agent_config.KeyDelimiter + "enable" TlsCert = TlsKey + agent_config.KeyDelimiter + "cert" TlsPrivateKey = TlsKey + agent_config.KeyDelimiter + "key" TlsCa = TlsKey + agent_config.KeyDelimiter + "ca" TlsSkipVerify = TlsKey + agent_config.KeyDelimiter + "skip_verify" // viper keys used in config NginxKey = "nginx" NginxExcludeLogs = NginxKey + agent_config.KeyDelimiter + "exclude_logs" NginxDebug = NginxKey + agent_config.KeyDelimiter + "debug" NginxCountingSocket = NginxKey + agent_config.KeyDelimiter + "socket" NginxClientVersion = NginxKey + agent_config.KeyDelimiter + "client_version" NginxConfigReloadMonitoringPeriod = NginxKey + agent_config.KeyDelimiter + "config_reload_monitoring_period" NginxTreatWarningsAsErrors = NginxKey + agent_config.KeyDelimiter + "treat_warnings_as_errors" // viper keys used in config DataplaneKey = "dataplane" DataplaneEventsEnable = DataplaneKey + agent_config.KeyDelimiter + "events_enable" DataplaneSyncEnable = DataplaneKey + agent_config.KeyDelimiter + "sync_enable" DataplaneStatusPoll = DataplaneKey + agent_config.KeyDelimiter + "status_poll_interval" DataplaneStatusReportInterval = DataplaneKey + agent_config.KeyDelimiter + "report_interval" // viper keys used in config MetricsKey = "metrics" MetricsBulkSize = MetricsKey + agent_config.KeyDelimiter + "bulk_size" MetricsReportInterval = MetricsKey + agent_config.KeyDelimiter + "report_interval" MetricsCollectionInterval = MetricsKey + agent_config.KeyDelimiter + "collection_interval" MetricsMode = MetricsKey + agent_config.KeyDelimiter + "mode" MetricsBackoff = MetricsKey + agent_config.KeyDelimiter + "backoff" // metrics backoff settings BackoffMetricsInitialInterval = MetricsKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "initial_interval" BackoffMetricsRandomizationFactor = MetricsKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "randomization_factor" BackoffMetricsMultiplier = MetricsKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "multiplier" BackoffMetricsMaxInterval = MetricsKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "max_interval" BackoffMetricsMaxElapsedTime = MetricsKey + agent_config.KeyDelimiter + BackoffKey + agent_config.KeyDelimiter + "max_elapsed_time" // DEPRECATED KEYS AdvancedMetricsKey = "advanced_metrics" AdvancedMetricsSocketPath = AdvancedMetricsKey + agent_config.KeyDelimiter + "socket_path" AdvancedMetricsAggregationPeriod = AdvancedMetricsKey + agent_config.KeyDelimiter + "aggregation_period" AdvancedMetricsPublishPeriod = AdvancedMetricsKey + agent_config.KeyDelimiter + "publishing_period" AdvancedMetricsTableSizesLimits = AdvancedMetricsKey + agent_config.KeyDelimiter + "table_sizes_limits" AdvancedMetricsTableSizesLimitsSTMS = AdvancedMetricsTableSizesLimits + agent_config.KeyDelimiter + "staging_table_max_size" AdvancedMetricsTableSizesLimitsSTT = AdvancedMetricsTableSizesLimits + agent_config.KeyDelimiter + "staging_table_threshold" AdvancedMetricsTableSizesLimitsPTMS = AdvancedMetricsTableSizesLimits + agent_config.KeyDelimiter + "priority_table_max_size" AdvancedMetricsTableSizesLimitsPTT = AdvancedMetricsTableSizesLimits + agent_config.KeyDelimiter + "priority_table_threshold" NginxAppProtectKey = "nginx_app_protect" NginxAppProtectReportInterval = NginxAppProtectKey + agent_config.KeyDelimiter + "report_interval" NginxAppProtectPrecompiledPublication = NginxAppProtectKey + agent_config.KeyDelimiter + "precompiled_publication" NAPMonitoringKey = "nap_monitoring" NAPMonitoringCollectorBufferSize = NAPMonitoringKey + agent_config.KeyDelimiter + "collector_buffer_size" NAPMonitoringProcessorBufferSize = NAPMonitoringKey + agent_config.KeyDelimiter + "processor_buffer_size" NAPMonitoringSyslogIP = NAPMonitoringKey + agent_config.KeyDelimiter + "syslog_ip" NAPMonitoringSyslogPort = NAPMonitoringKey + agent_config.KeyDelimiter + "syslog_port" NAPMonitoringReportInterval = NAPMonitoringKey + agent_config.KeyDelimiter + "report_interval" NAPMonitoringReportCount = NAPMonitoringKey + agent_config.KeyDelimiter + "report_count" )
Variables ¶
View Source
var ( Viper = viper.NewWithOptions(viper.KeyDelimiter(agent_config.KeyDelimiter)) MigratedEnv = false )
View Source
var ( Defaults = &Config{ DynamicConfigPath: getDefaultDynamicConfPath(), CloudAccountID: uuid.New().String(), Log: LogConfig{ Level: "info", Path: "/var/log/nginx-agent", }, Server: Server{ Command: "", Metrics: "", Token: uuid.New().String(), Backoff: Backoff{ InitialInterval: client.DefaultBackoffSettings.InitialInterval, RandomizationFactor: client.DefaultBackoffSettings.Jitter, Multiplier: client.DefaultBackoffSettings.Multiplier, MaxInterval: client.DefaultBackoffSettings.MaxInterval, MaxElapsedTime: client.DefaultBackoffSettings.MaxElapsedTime, }, }, Nginx: Nginx{ Debug: false, NginxCountingSocket: "unix:/var/run/nginx-agent/nginx.sock", NginxClientVersion: 7, ConfigReloadMonitoringPeriod: 10 * time.Second, TreatWarningsAsErrors: false, }, ConfigDirs: "/etc/nginx:/usr/local/etc/nginx:/usr/share/nginx/modules:/etc/nms", IgnoreDirectives: []string{}, AllowedDirectoriesMap: map[string]struct{}{}, TLS: TLSConfig{ Enable: false, SkipVerify: false, }, Dataplane: Dataplane{ Status: Status{ PollInterval: 30 * time.Second, ReportInterval: 24 * time.Hour, }, }, AgentMetrics: AgentMetrics{ BulkSize: 20, ReportInterval: 1 * time.Minute, CollectionInterval: 15 * time.Second, Mode: "aggregated", Backoff: Backoff{ InitialInterval: client.DefaultBackoffSettings.InitialInterval, RandomizationFactor: client.DefaultBackoffSettings.Jitter, Multiplier: client.DefaultBackoffSettings.Multiplier, MaxInterval: client.DefaultBackoffSettings.MaxInterval, MaxElapsedTime: client.DefaultBackoffSettings.MaxElapsedTime, }, }, AgentAPI: AgentAPI{ Host: "127.0.0.1", }, Features: agent_config.GetDefaultFeatures(), QueueSize: 100, } AllowedDirectoriesMap map[string]struct{} )
View Source
var COMPLETION_COMMAND = &cobra.Command{ Use: "completion [bash|zsh|fish]", Short: "Generate completion script.", Long: `To load completions: Bash: $ source <(nginx-agent completion bash) # To load completions for each session, execute once: Linux: $ nginx-agent completion bash > /etc/bash_completion.d/nginx-agent MacOS: $ nginx-agent completion bash > /usr/local/etc/bash_completion.d/nginx-agent Zsh: # If shell completion is not already enabled in your environment you will need # to enable it. You can execute the following once: $ echo "autoload -U compinit; compinit" >> ~/.zshrc # To load completions for each session, execute once: $ nginx-agent completion zsh > "${fpath[1]}/_nginx-agent" # You will need to start a new shell for this setup to take effect. Fish: $ nginx-agent completion fish | source # To load completions for each session, execute once: $ nginx-agent completion fish > ~/.config/fish/completions/nginx-agent.fish `, DisableFlagsInUseLine: true, ValidArgs: []string{"bash", "zsh", "fish"}, Args: cobra.MatchAll(cobra.ExactArgs(1), cobra.OnlyValidArgs), Run: func(cmd *cobra.Command, args []string) { var err error switch args[0] { case "bash": err = cmd.Root().GenBashCompletion(os.Stdout) case "zsh": err = cmd.Root().GenZshCompletion(os.Stdout) case "fish": err = cmd.Root().GenFishCompletion(os.Stdout, true) } if err != nil { log.Warnf("Error sending command: %v", err) } }, }
View Source
var ROOT_COMMAND = &cobra.Command{
Use: "nginx-agent [flags]",
Short: "nginx-agent",
}
Functions ¶
func CheckAndSetDefault ¶
func CheckAndSetDefault(attribute interface{}, defaultValue interface{})
func ConfigFilePaths ¶
func ConfigFilePaths() []string
func InitConfigurationFiles ¶ added in v2.31.0
func InitConfigurationFiles()
func LoadPropertiesFromFile ¶
func RegisterConfigFile ¶
func RegisterFlags ¶
func RegisterFlags()
func RegisterRunner ¶
func SeekConfigFileInPaths ¶
func SetDefaults ¶
func SetDefaults()
func SetVersion ¶
func SetVersion(version, commit string)
func UpdateAgentConfig ¶
UpdateAgentConfig updates the Agent config on disk with the tags and features that are passed into it. A bool is returned indicating if the Agent config was overwritten or not.
Types ¶
type AgentMetrics ¶
type AgentMetrics struct { BulkSize int `mapstructure:"bulk_size" yaml:"-"` ReportInterval time.Duration `mapstructure:"report_interval" yaml:"-"` CollectionInterval time.Duration `mapstructure:"collection_interval" yaml:"-"` Mode string `mapstructure:"mode" yaml:"-"` Backoff Backoff `mapstructure:"backoff" yaml:"-"` }
AgentMetrics for system/agent metrics
type Backoff ¶ added in v2.26.0
type Backoff struct { InitialInterval time.Duration `mapstructure:"initial_interval" yaml:"-"` RandomizationFactor float64 `mapstructure:"randomization_factor" yaml:"-"` Multiplier float64 `mapstructure:"multiplier" yaml:"-"` MaxInterval time.Duration `mapstructure:"max_interval" yaml:"-"` MaxElapsedTime time.Duration `mapstructure:"max_elapsed_time" yaml:"-"` }
type Config ¶
type Config struct { Version string Path string `yaml:"-"` DynamicConfigPath string `mapstructure:"dynamic_config_path" yaml:"-"` ClientID string `mapstructure:"agent_id" yaml:"-"` CloudAccountID string `mapstructure:"cloud_account" yaml:"-"` Server Server `mapstructure:"server" yaml:"-"` AgentAPI AgentAPI `mapstructure:"api" yaml:"-"` ConfigDirs string `mapstructure:"config-dirs" yaml:"-"` Log LogConfig `mapstructure:"log" yaml:"-"` TLS TLSConfig `mapstructure:"tls" yaml:"-"` Nginx Nginx `mapstructure:"nginx" yaml:"-"` Dataplane Dataplane `mapstructure:"dataplane" yaml:"-"` AgentMetrics AgentMetrics `mapstructure:"metrics" yaml:"-"` Tags []string `mapstructure:"tags" yaml:"tags,omitempty"` Features []string `mapstructure:"features" yaml:"features,omitempty"` Extensions []string `mapstructure:"extensions" yaml:"extensions,omitempty"` Updated time.Time `yaml:"-"` // update time of the config file AllowedDirectoriesMap map[string]struct{} `yaml:"-"` DisplayName string `mapstructure:"display_name" yaml:"display_name,omitempty"` InstanceGroup string `mapstructure:"instance_group" yaml:"instance_group,omitempty"` IgnoreDirectives []string `mapstructure:"ignore_directives" yaml:"ignore_directives,omitempty"` QueueSize int `mapstructure:"queue_size" yaml:"queue_size,omitempty"` }
func (*Config) AllowedDirectories ¶ added in v2.37.0
func (*Config) GetMetricsBackoffSettings ¶ added in v2.37.0
func (c *Config) GetMetricsBackoffSettings() backoff.BackoffSettings
func (*Config) GetServerBackoffSettings ¶ added in v2.27.0
func (c *Config) GetServerBackoffSettings() backoff.BackoffSettings
func (*Config) IsExtensionEnabled ¶ added in v2.24.0
func (*Config) IsFeatureEnabled ¶ added in v2.21.0
func (*Config) IsGrpcServerConfigured ¶ added in v2.21.0
type DurationFlag ¶
type LogConfig ¶
type LogConfig struct { Level string `mapstructure:"level" yaml:"-"` Path string `mapstructure:"path" yaml:"-"` }
LogConfig for logging
type Nginx ¶
type Nginx struct { ExcludeLogs string `mapstructure:"exclude_logs" yaml:"-"` Debug bool `mapstructure:"debug" yaml:"-"` NginxCountingSocket string `mapstructure:"socket" yaml:"-"` NginxClientVersion int `mapstructure:"client_version" yaml:"-"` ConfigReloadMonitoringPeriod time.Duration `mapstructure:"config_reload_monitoring_period" yaml:"-"` TreatWarningsAsErrors bool `mapstructure:"treat_warnings_as_errors" yaml:"-"` }
Nginx settings
type Registrable ¶
type Registrable interface {
// contains filtered or unexported methods
}
Registrable registers a pflag
type Server ¶
type Server struct { Host string `mapstructure:"host" yaml:"-"` GrpcPort int `mapstructure:"grpcPort" yaml:"-"` Token string `mapstructure:"token" yaml:"-"` Metrics string `mapstructure:"metrics" yaml:"-"` Command string `mapstructure:"command" yaml:"-"` // This is internal and shouldn't be exposed as a flag Target string `mapstructure:"target" yaml:"-"` Backoff Backoff `mapstructure:"backoff" yaml:"-"` }
type Status ¶
type Status struct { PollInterval time.Duration `mapstructure:"poll_interval" yaml:"-"` ReportInterval time.Duration `mapstructure:"report_interval" yaml:"-"` }
Status polling for heartbeat settings
type StringFlag ¶
type StringMapFlag ¶
type StringSliceFlag ¶
type TLSConfig ¶
type TLSConfig struct { Enable bool `mapstructure:"enable" yaml:"-"` Cert string `mapstructure:"cert" yaml:"-"` Key string `mapstructure:"key" yaml:"-"` Ca string `mapstructure:"ca" yaml:"-"` SkipVerify bool `mapstructure:"skip_verify" yaml:"-"` }
TLSConfig for securing communications
Click to show internal directories.
Click to hide internal directories.