common

package
v1.6.65 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 23, 2024 License: Apache-2.0 Imports: 28 Imported by: 5

Documentation

Index

Constants

View Source
const (
	DEFAULT_ORG_ID    = 1
	DEFAULT_USER_TYPE = 1
	DEFAULT_USER_ID   = 1
	DEFAULT_TEAM_ID   = 1
	DEFAULT_APP_KEY   = "8c434f9a48bf1b7e729bde006e0409f8"
	ORG_ID_MAX        = 1024
)
View Source
const (
	REMOTE_API_TIMEOUT = 30
	INGESTER_API_PORT  = 30106
)
View Source
const (
	LOCALHOST                    = "127.0.0.1"
	MASTER_CONTROLLER_CHECK_PORT = 4040
)
View Source
const (
	HEALTH_CHECK_INTERVAL = 60 * time.Second
	HEALTH_CHECK_URL      = "http://%s:%d/v1/health/"
)
View Source
const (
	HOST_STATE_COMPLETE    = 2
	HOST_STATE_EXCEPTION   = 4
	HOST_STATE_MAINTENANCE = 5

	HOST_TYPE_VM  = 1
	HOST_TYPE_NSP = 3
	HOST_TYPE_DFI = 4

	HOST_HTYPE_ESXI    = 2
	HOST_HTYPE_KVM     = 3
	HOST_HTYPE_HYPER_V = 5
	HOST_HTYPE_GATEWAY = 6
)
View Source
const (
	HOST_VCPUS     = 8
	HOST_MEMORY_MB = 16384
)
View Source
const (
	HOST_TYPE_CONTROLLER = "controller"
	HOST_TYPE_ANALYZER   = "analyzer"
)
View Source
const (
	CONTROLLER_NODE_TYPE_MASTER = 1
	CONTROLLER_NODE_TYPE_SLAVE  = 2

	CONTROLLER_STATE_NORMAL    = 2
	CONTROLLER_STATE_EXCEPTION = 4
)
View Source
const (
	ARCH_X86 = 1
	ARCH_ARM = 2
)
View Source
const (
	OS_CENTOS  = 1
	OS_REDHAT  = 2
	OS_UBUNTU  = 3
	OS_SUSE    = 4
	OS_WINDOWS = 5
	OS_ANDROID = 6
)
View Source
const (
	VTAP_ENABLE_FALSE = 0
	VTAP_ENABLE_TRUE  = 1
)
View Source
const (
	VTAP_STATE_NOT_CONNECTED = iota
	VTAP_STATE_NORMAL
	VTAP_STATE_DISABLE
	VTAP_STATE_PENDING
)
View Source
const (
	VTAP_STATE_NOT_CONNECTED_STR = "LOST"
	VTAP_STATE_NORMAL_STR        = "RUNNING"
	VTAP_STATE_DISABLE_STR       = "DISABLE"
	VTAP_STATE_PENDING_STR       = "PENDING"
)
View Source
const (
	VTAP_TYPE_KVM = 1 + iota
	VTAP_TYPE_ESXI
	VTAP_TYPE_WORKLOAD_V

	VTAP_TYPE_WORKLOAD_P
	VTAP_TYPE_DEDICATED
	VTAP_TYPE_POD_HOST
	VTAP_TYPE_POD_VM
	VTAP_TYPE_TUNNEL_DECAPSULATION
	VTAP_TYPE_HYPER_V

	VTAP_TYPE_K8S_SIDECAR
)
View Source
const (
	VTAP_EXCEPTION_LICENSE_NOT_ENGOUTH     = 0x10000000
	VTAP_EXCEPTION_ALLOC_ANALYZER_FAILED   = 0x40000000
	VTAP_EXCEPTION_ALLOC_CONTROLLER_FAILED = 0x80000000
)

need synchronized update with the cli

View Source
const (
	VTAP_LICENSE_TYPE_NONE = iota
	VTAP_LICENSE_TYPE_A
	VTAP_LICENSE_TYPE_B
	VTAP_LICENSE_TYPE_C
	VTAP_LICENSE_TYPE_DEDICATED
	VTAP_LICENSE_TYPE_MAX
)
View Source
const (
	VTAP_LICENSE_FUNCTION_NONE = iota
	VTAP_LICENSE_FUNCTION_TRAFFIC_DISTRIBUTION
	VTAP_LICENSE_FUNCTION_NETWORK_MONITORING
	VTAP_LICENSE_FUNCTION_CALL_MONITORING
	VTAP_LICENSE_FUNCTION_FUNCTION_MONITORING
	VTAP_LICENSE_FUNCTION_APPLICATION_MONITORING
	VTAP_LICENSE_FUNCTION_INDICATOR_MONITORING
	VTAP_LICENSE_FUNCTION_DATABASE_MONITORING
	VTAP_LICENSE_FUNCTION_LOG_MONITORING
	VTAP_LICENSE_FUNCTION_MAX
)
View Source
const (
	DEFAULT_DOMAIN        = "ffffffff-ffff-ffff-ffff-ffffffffffff"
	DEFAULT_REGION        = "ffffffff-ffff-ffff-ffff-ffffffffffff"
	DEFAULT_AZ            = "ffffffff-ffff-ffff-ffff-ffffffffffff"
	DEFAULT_VTAP_GROUP_ID = 1
	DEFAULT_DOMAIN_ICON   = -3
	DEFAULT_REGION_NAME   = "系统默认"
)
View Source
const (
	DOMAIN_ENABLED_FALSE = 0
	DOMAIN_ENABLED_TRUE  = 1

	DOMAIN_STATE_NORMAL = 1
)
View Source
const (
	NPB_POLICY_FLOW_DROP       = 0
	NPB_POLICY_FLOW_DISTRIBUTE = 1
)
View Source
const (
	DEFAULT_ENCRYPTION_PASSWORD = "******"
	DEFAULT_ALL_MATCH_REGEX     = ".*"
	DEFAULT_NOT_MATCH_REGEX     = "^$"
	DEFAULT_PORT_NAME_REGEX     = "^(cni|flannel|vxlan.calico|tunl|en[ospx])"

	OPENSTACK         = 1
	VSPHERE           = 2
	NSP               = 3
	TENCENT           = 4
	FILEREADER        = 5
	AWS               = 6
	ZSTACK            = 8
	ALIYUN            = 9
	HUAWEI_PRIVATE    = 10
	KUBERNETES        = 11
	SIMULATION        = 12
	HUAWEI            = 13
	QINGCLOUD         = 14
	QINGCLOUD_PRIVATE = 15
	F5                = 16
	CMB_CMDB          = 17
	AZURE             = 18
	APSARA_STACK      = 19
	TENCENT_TCE       = 20
	KINGSOFT_PRIVATE  = 22
	AGENT_SYNC        = 23
	MICROSOFT_ACS     = 24
	BAIDU_BCE         = 25
	ESHORE            = 26
	CLOUD_TOWER       = 27
	NFVO              = 28
	SUGON             = 29
	VOLCENGINE        = 30
	H3C               = 31

	OPENSTACK_EN         = "openstack"
	VSPHERE_EN           = "vsphere"
	NSP_EN               = "nsp"
	TENCENT_EN           = "tencent"
	FILEREADER_EN        = "filereader"
	AWS_EN               = "aws"
	ZSTACK_EN            = "zstack"
	ALIYUN_EN            = "aliyun"
	HUAWEI_PRIVATE_EN    = "huawei_private"
	KUBERNETES_EN        = "kubernetes"
	SIMULATION_EN        = "simulation"
	HUAWEI_EN            = "huawei"
	QINGCLOUD_EN         = "qingcloud"
	QINGCLOUD_PRIVATE_EN = "qingcloud_private"
	F5_EN                = "f5"
	CMB_CMDB_EN          = "cmb_cmdb"
	AZURE_EN             = "azure"
	APSARA_STACK_EN      = "apsara_stack"
	TENCENT_TCE_EN       = "tencent_tce"
	ESHORE_EN            = "eshore"
	QINGCLOUD_K8S_EN     = "qingcloud_k8s"
	KINGSOFT_PRIVATE_EN  = "kingsoft_private"
	AGENT_SYNC_EN        = "genesis"
	MICROSOFT_ACS_EN     = "microsoft_acs"
	BAIDU_BCE_EN         = "baidu_bce"
	CLOUD_TOWER_EN       = "cloudtower"
	NFVO_EN              = "nfvo"
	SUGON_EN             = "sugon"
	VOLCENGINE_EN        = "volcengine"
	H3C_EN               = "h3c"

	TENCENT_CH          = "腾讯云"
	ALIYUN_CH           = "阿里云"
	HUAWEI_CH           = "华为云"
	QINGCLOUD_CH        = "青云"
	KINGSOFT_PRIVATE_CH = "金山银河云"
	MICROSOFT_CH        = "微软云"
	BAIDU_BCE_CH        = "百度云"
	ESHORE_CH           = "亿迅云"
	NFVO_CH             = "华为NFVO+"
	SUGON_CH            = "曙光云"
	VOLCENGINE_CH       = "火山云"
	H3C_CH              = "华三云"

	OPENSTACK_CH   = "OpenStack"
	VSPHERE_CH     = "vSphere"
	NSP_CH         = "NSP"
	AWS_CH         = "AWS"
	ZSTACK_CH      = "ZStack"
	KUBERNETES_CH  = "Kubernetes"
	CLOUD_TOWER_CH = "CloudTower"
)
View Source
const (
	NETWORK_ISP_LCUUID = "ffffffff-ffff-ffff-ffff-ffffffffffff"
	NETWORK_TYPE_WAN   = 3
	NETWORK_TYPE_LAN   = 4

	SUBNET_ISP_LCUUID = "ffffffff-ffff-ffff-ffff-ffffffffffff"
)
View Source
const (
	VM_STATE_RUNNING   = 4
	VM_STATE_STOPPED   = 9
	VM_STATE_EXCEPTION = 11

	VM_HTYPE_VM_C = 1
	VM_HTYPE_BM_C = 2
	VM_HTYPE_VM_N = 3
	VM_HTYPE_BM_N = 4
	VM_HTYPE_VM_S = 5
	VM_HTYPE_BM_S = 6
)
View Source
const (
	VIF_DEFAULT_MAC = "00:00:00:00:00:00"

	VIF_TYPE_WAN = 3
	VIF_TYPE_LAN = 4

	VIF_DEVICE_TYPE_VM             = 1
	VIF_DEVICE_TYPE_VROUTER        = 5
	VIF_DEVICE_TYPE_HOST           = 6
	VIF_DEVICE_TYPE_DHCP_PORT      = 9
	VIF_DEVICE_TYPE_POD            = 10
	VIF_DEVICE_TYPE_POD_SERVICE    = 11
	VIF_DEVICE_TYPE_REDIS_INSTANCE = 12
	VIF_DEVICE_TYPE_RDS_INSTANCE   = 13
	VIF_DEVICE_TYPE_POD_NODE       = 14
	VIF_DEVICE_TYPE_LB             = 15
	VIF_DEVICE_TYPE_NAT_GATEWAY    = 16

	VIF_DEVICE_TYPE_INTERNET                        = 0
	VIF_DEVICE_TYPE_POD_GROUP                       = 101
	VIF_DEVICE_TYPE_SERVICE                         = 102
	VIF_DEVICE_TYPE_POD_CLUSTER                     = 103
	VIF_DEVICE_TYPE_GPROCESS                        = 120
	VIF_DEVICE_TYPE_POD_GROUP_DEPLOYMENT            = 130
	VIF_DEVICE_TYPE_POD_GROUP_STATEFULSET           = 131
	VIF_DEVICE_TYPE_POD_GROUP_RC                    = 132
	VIF_DEVICE_TYPE_POD_GROUP_DAEMON_SET            = 133
	VIF_DEVICE_TYPE_POD_GROUP_REPLICASET_CONTROLLER = 134
	VIF_DEVICE_TYPE_POD_GROUP_CLONESET              = 135
	VIF_DEVICE_TYPE_IP                              = 255
)
View Source
const (
	CREATE_METHOD_LEARN         = 0
	CREATE_METHOD_USER_DEFINE   = 1
	CONTACT_CREATE_METHOD_LEARN = 1 // TODO 修改与其他统一
)
View Source
const (
	ROUTING_TABLE_TYPE_VPN             = "vpn"
	ROUTING_TABLE_TYPE_LOCAL           = "local"
	ROUTING_TABLE_TYPE_ROUTER          = "router"
	ROUTING_TABLE_TYPE_NAT_GATEWAY     = "nat-gateway"
	ROUTING_TABLE_TYPE_PEER_CONNECTION = "peer-connection"
	ROUTING_TABLE_TYPE_INSTANCE        = "Instance"
	ROUTING_TABLE_TYPE_IP              = "IP"
)
View Source
const (
	LB_MODEL_INTERNAL = 1
	LB_MODEL_EXTERNAL = 2

	LB_SERVER_TYPE_VM = 1
	LB_SERVER_TYPE_IP = 2
)
View Source
const (
	RDS_UNKNOWN = 0

	RDS_TYPE_MYSQL      = 1
	RDS_TYPE_SQL_SERVER = 2
	RDS_TYPE_PPAS       = 3
	RDS_TYPE_PSQL       = 4 // PostgreSQL
	RDS_TYPE_MARIADB    = 5

	RDS_STATE_RUNNING   = 1
	RDS_STATE_RESTORING = 2

	RDS_SERIES_BASIC = 1
	RDS_SERIES_HA    = 2

	RDS_MODEL_PRIMARY   = 1
	RDS_MODEL_READONLY  = 2
	RDS_MODEL_TEMPORARY = 3
	RDS_MODEL_GUARD     = 4
	RDS_MODEL_SHARE     = 5
)
View Source
const (
	INTERVAL_1MINUTE = 60
	INTERVAL_1HOUR   = 3600
	INTERVAL_1DAY    = 86400
	INTERVAL_1WEEK   = 604800
	INTERVAL_1MONTH  = 2678400
	INTERVAL_1YEAR   = 31536000
)
View Source
const (
	DATA_SOURCE_NETWORK        = "flow_metrics.network*"
	DATA_SOURCE_APPLICATION    = "flow_metrics.application*"
	DATA_SOURCE_TRAFFIC_POLICY = "flow_metrics.traffic_policy"

	DATA_SOURCE_STATE_EXCEPTION = 0
	DATA_SOURCE_STATE_NORMAL    = 1
)
View Source
const (
	IPV4_MAX_MASK = 32
	IPV6_MAX_MASK = 128

	IPV4_DEFAULT_NETMASK = 24
	IPV6_DEFAULT_NETMASK = 64
)
View Source
const (
	POD_NODE_TYPE_MASTER = 1
	POD_NODE_TYPE_NODE   = 2

	POD_NODE_STATE_EXCEPTION = 0
	POD_NODE_STATE_NORMAL    = 1

	POD_NODE_SERVER_TYPE_HOST = 1
	POD_NODE_SERVER_TYPE_VM   = 2
)
View Source
const (
	POD_SERVICE_TYPE_CLUSTERIP    = 1
	POD_SERVICE_TYPE_NODEPORT     = 2
	POD_SERVICE_TYPE_LOADBALANCER = 3
)
View Source
const (
	POD_GROUP_DEPLOYMENT            = 1
	POD_GROUP_STATEFULSET           = 2
	POD_GROUP_RC                    = 3
	POD_GROUP_DAEMON_SET            = 4
	POD_GROUP_REPLICASET_CONTROLLER = 5
	POD_GROUP_CLONESET              = 6
)
View Source
const (
	POD_STATE_EXCEPTION = 0
	POD_STATE_RUNNING   = 1
)
View Source
const (
	K8S_POD_IPV4_NETMASK = 16
	K8S_POD_IPV6_NETMASK = 64
)
View Source
const (
	RESOURCE_STATE_CODE_SUCCESS   = 1
	RESOURCE_STATE_CODE_DELETING  = 2
	RESOURCE_STATE_CODE_EXCEPTION = 3
	RESOURCE_STATE_CODE_WARNING   = 4
)
View Source
const (
	NODE_NAME_KEY    = "K8S_NODE_NAME_FOR_DEEPFLOW"
	NODE_IP_KEY      = "K8S_NODE_IP_FOR_DEEPFLOW"
	POD_NAME_KEY     = "K8S_POD_NAME_FOR_DEEPFLOW"
	POD_IP_KEY       = "K8S_POD_IP_FOR_DEEPFLOW"
	NAME_SPACE_KEY   = "K8S_NAMESPACE_FOR_DEEPFLOW"
	RUNNING_MODE_KEY = "DEEPFLOW_SERVER_RUNNING_MODE"
)
View Source
const (
	CLOUD_METRIC_NAME_TASK_COST       = "controller_cloud_task_cost"
	CLOUD_METRIC_NAME_INFO_COUNT      = "controller_cloud_info_count"
	CLOUD_METRIC_NAME_API_COUNT       = "controller_cloud_api_count"
	CLOUD_METRIC_NAME_API_COST        = "controller_cloud_api_cost"
	GENESIS_METRIC_NAME_K8SINFO_DELAY = "controller_genesis_k8sinfo_delay"
)
View Source
const (
	TAPMODE_LOCAL    = 0
	TAPMODE_MIRROR   = 1
	TAPMODE_ANALYZER = 2
	TAPMODE_DECAP    = 3
)
View Source
const (
	AGENT_IDENTIFIE_IP_AND_MAC = 1
	AGENT_IDENTIFIE_IP         = 2
)
View Source
const (
	BILLING_METHOD_LICENSE = "license"
	BILLING_METHOD_VOUCHER = "voucher"
)
View Source
const (
	PLUGIN_TYPE_WASM = 1
	PLUGIN_TYPE_SO   = 2
	PLUGIN_TYPE_LUA  = 3
)

plugin

View Source
const (
	PROMETHEUS_TARGET_CREATE_METHOD_RECORDER   = 1
	PROMETHEUS_TARGET_CREATE_METHOD_PROMETHEUS = 2
)
View Source
const (
	ANALYZER_ALLOC_BY_INGESTED_DATA = "by-ingested-data"
	ANALYZER_ALLOC_BY_AGENT_COUNT   = "by-agent-count"
)
View Source
const (
	HEADER_KEY_CONTENT_TYPE = "Content-Type"
	HEADER_KEY_ACCEPT       = "Accept"
	CONTENT_TYPE_JSON       = "application/json"
	CONTEXT_TYPE_FORM       = "application/x-www-form-urlencoded"
	ACCEPT_JSON             = "application/json, text/plain"

	HEADER_KEY_X_ORG_ID    = "X-Org-Id"
	HEADER_KEY_X_USER_TYPE = "X-User-Type"
	HEADER_KEY_X_USER_ID   = "X-User-Id"
	HEADER_KEY_X_APP_KEY   = "X-App-Key"

	USER_TYPE_SUPER_ADMIN = 1
	USER_TYPE_ADMIN       = 2
	USER_ID_SUPER_ADMIN   = 1

	INGESTER_BODY_ORG_ID = "org-id"
)
View Source
const (
	SET_RESOURCE_TYPE_DOMAIN             = "domain"
	SET_RESOURCE_TYPE_SUB_DOMAIN         = "sub_domain"
	SET_RESOURCE_TYPE_AGENT              = "agent"
	SET_RESOURCE_TYPE_AGENT_GROUP        = "agent_group"
	SET_RESOURCE_TYPE_AGENT_GROUP_CONFIG = "agent_group_config"
	SET_RESOURCE_TYPE_DATA_SOURCE        = "datasource"
)
View Source
const (
	RESOURCE_TYPE_REGION_EN                   = "region"
	RESOURCE_TYPE_AZ_EN                       = "az"
	RESOURCE_TYPE_SUB_DOMAIN_EN               = "sub_domain"
	RESOURCE_TYPE_HOST_EN                     = "host"
	RESOURCE_TYPE_VM_EN                       = "vm"
	RESOURCE_TYPE_VPC_EN                      = "vpc"
	RESOURCE_TYPE_NETWORK_EN                  = "network"
	RESOURCE_TYPE_SUBNET_EN                   = "subnet"
	RESOURCE_TYPE_VROUTER_EN                  = "vrouter"
	RESOURCE_TYPE_ROUTING_TABLE_EN            = "routing_table"
	RESOURCE_TYPE_DHCP_PORT_EN                = "dhcp_port"
	RESOURCE_TYPE_VINTERFACE_EN               = "vinterface"
	RESOURCE_TYPE_WAN_IP_EN                   = "wan_ip"
	RESOURCE_TYPE_LAN_IP_EN                   = "lan_ip"
	RESOURCE_TYPE_FLOATING_IP_EN              = "floating_ip"
	RESOURCE_TYPE_NAT_GATEWAY_EN              = "nat_gateway"
	RESOURCE_TYPE_NAT_RULE_EN                 = "nat_rule"
	RESOURCE_TYPE_NAT_VM_CONNECTION_EN        = "nat_vm_connection"
	RESOURCE_TYPE_LB_EN                       = "lb"
	RESOURCE_TYPE_LB_VM_CONNECTION_EN         = "lb_vm_connection"
	RESOURCE_TYPE_LB_LISTENER_EN              = "lb_listener"
	RESOURCE_TYPE_LB_TARGET_SERVER_EN         = "lb_target_server"
	RESOURCE_TYPE_PEER_CONNECTION_EN          = "peer_connection"
	RESOURCE_TYPE_CEN_EN                      = "cen"
	RESOURCE_TYPE_RDS_INSTANCE_EN             = "rds_instance"
	RESOURCE_TYPE_REDIS_INSTANCE_EN           = "redis_instance"
	RESOURCE_TYPE_POD_CLUSTER_EN              = "pod_cluster"
	RESOURCE_TYPE_POD_NODE_EN                 = "pod_node"
	RESOURCE_TYPE_VM_POD_NODE_CONNECTION_EN   = "vm_pod_node_connection"
	RESOURCE_TYPE_POD_NAMESPACE_EN            = "pod_namespace"
	RESOURCE_TYPE_POD_INGRESS_EN              = "pod_ingress"
	RESOURCE_TYPE_POD_INGRESS_RULE_EN         = "pod_ingress_rule"
	RESOURCE_TYPE_POD_INGRESS_RULE_BACKEND_EN = "pod_ingress_rule_backend"
	RESOURCE_TYPE_POD_SERVICE_EN              = "pod_service"
	RESOURCE_TYPE_POD_SERVICE_PORT_EN         = "pod_service_port"
	RESOURCE_TYPE_POD_GROUP_EN                = "pod_group"
	RESOURCE_TYPE_POD_GROUP_PORT_EN           = "pod_group_port"
	RESOURCE_TYPE_POD_REPLICA_SET_EN          = "pod_replica_set"
	RESOURCE_TYPE_POD_EN                      = "pod"
	RESOURCE_TYPE_PROCESS_EN                  = "process"
	RESOURCE_TYPE_PROMETHEUS_TARGET_EN        = "prometheus_target"
	RESOURCE_TYPE_VIP_EN                      = "vip"
	RESOURCE_TYPE_VTAP_EN                     = "vtap"
	RESOURCE_TYPE_ORG_EN                      = "org"

	// http api resource type
	RESOURCE_TYPE_IP_EN      = "ip"
	RESOURCE_TYPE_ALL_IP_EN  = "all_ip"
	RESOURCE_TYPE_LB_RULE_EN = "lb_rule"
)
View Source
const (
	ACL_STATE_ENABLE = 1
)
View Source
const (
	DATA_SOURCE_DEEPFLOW_SYSTEM_INTERVAL = 10
)
View Source
const GO_BIRTHDAY = "2006-01-02 15:04:05"
View Source
const K8S_CA_CRT_PATH = "/run/secrets/kubernetes.io/serviceaccount/ca.crt"
View Source
const (
	PROCESS_INSTANCE_TYPE = 120 // used in process event
)
View Source
const (
	REDIS_STATE_RUNNING = 1
)
View Source
const (
	RUNNING_MODE_STANDALONE = "STANDALONE"
)
View Source
const SHORT_UUID_LENGTH int = 10
View Source
const (
	STRINGS_JOIN_COMMA = ","
)
View Source
const (
	SUB_DOMAIN_ERROR_DISPLAY_NUM = 10
)
View Source
const TRISOLARIS_NODE_TYPE_MASTER = "master"
View Source
const VTAP_ALL_LICENSE_FUNCTIONS = "1,2,3,4,5,6,7,8"
View Source
const VTAP_LICENSE_CHECK_INTERVAL = time.Minute

Variables

View Source
var (
	TCP = 6
	UDP = 17
)
View Source
var (
	SUCCESS = "SUCCESS"

	ErrorFail    = errors.New("FAIL")
	ErrorPending = errors.New("PENDING")
)
View Source
var (
	DefaultMaxCollectPps                 = 200000
	DefaultMaxNpbBps                     = int64(1000000000)
	DefaultMaxCPUs                       = 1
	DefaultMaxMilliCPUs                  = 1000
	DefaultMaxMemory                     = 768
	DefaultPlatformSyncInterval          = 10
	DefaultSyncInterval                  = 60
	DefaultStatsInterval                 = 10
	DefaultRsyslogEnabled                = 1
	DefaultMaxTxBandwidth                = int64(0)
	DefaultBandwidthProbeInterval        = 10
	DefaultTapInterfaceRegex             = "^(tap.*|cali.*|veth.*|eth.*|en[osipx].*|lxc.*|lo|[0-9a-f]+_h)$"
	DefaultMaxEscapeSeconds              = 3600
	DefaultMtu                           = 1500
	DefaultOutputVlan                    = 0
	DefaultCollectorSocketType           = "TCP"
	DefaultCompressorSocketType          = "TCP"
	DefaultNpbSocketType                 = "RAW_UDP"
	DefaultNpbVlanMode                   = 0
	DefaultCollectorEnabled              = 1
	DefaultVTapFlow1sEnabled             = 1
	DefaultL4LogTapTypes                 = "0"
	DefaultL4LogIgnoreTapSides           = ""
	DefaultL7LogIgnoreTapSides           = ""
	DefaultNpbDedupEnabled               = 1
	DefaultPlatformEnabled               = 0
	DefaultIfMacSource                   = 0
	DefaultVMXMLPath                     = "/etc/libvirt/qemu/"
	DefaultExtraNetnsRegex               = ""
	DefaultNatIPEnabled                  = 0
	DefaultCapturePacketSize             = 65535
	DefaultInactiveServerPortEnabled     = 1
	DefaultInactiveIPEnabled             = 1
	DefaultLogThreshold                  = 300
	DefaultLogLevel                      = "INFO"
	DefaultLogRetention                  = 30
	DefaultHTTPLogProxyClient            = "X-Forwarded-For"
	DefaultHTTPLogTraceID                = "traceparent, sw8"
	DefaultL7LogPacketSize               = 1024
	DefaultL4LogCollectNpsThreshold      = 10000
	DefaultL7LogCollectNpsThreshold      = 10000
	DefaultL7MetricsEnabled              = 1
	DefaultL7LogStoreTapTypes            = "0"
	DefaultCaptureSocketType             = 0
	DefaultCaptureBpf                    = ""
	DefaultTapMode                       = TAPMODE_LOCAL
	DefaultThreadThreshold               = 500
	DefaultProcessThreshold              = 10
	DefaultNtpEnabled                    = 0
	DefaultL4PerformanceEnabled          = 1
	DefaultPodClusterInternalIP          = 0
	DefaultDomains                       = "0"
	DefaultDecapType                     = "1,2"
	DefaultHTTPLogSpanID                 = "traceparent, sw8"
	DefaultSysFreeMemoryLimit            = 0
	DefaultLogFileSize                   = 1000
	DefaultHTTPLogXRequestID             = "X-Request-ID"
	DefaultExternalAgentHTTPProxyEnabled = 1 // 外部Agent数据HTTP代理开关
	DefaultExternalAgentHTTPProxyPort    = 38086
	DefaultAnalyzerPort                  = 30033
	DefaultProxyControllerPort           = 30035
	DefaultProxyControllerIP             = ""
	DefaultAnalyzerIP                    = ""
	DefaultWasmPlugins                   = ""
	DefaultSoPlugins                     = ""

	DefaultSystemLoadCircuitBreakerThreshold = float32(1.0)
	DefaultSystemLoadCircuitBreakerRecover   = float32(0.9)
	DefaultSystemLoadCircuitBreakerMetric    = "load15"
)
View Source
var CAMD5 string
View Source
var CloudMonitorExceptionAPI = map[string]string{
	ALIYUN_EN:            "NetworkInterfaceSet,ListenerPortAndProtocol,BackendServer,SnatTableEntry,ForwardTableEntry,KVStoreZone,RouteEntry,Permission",
	TENCENT_EN:           "Listeners,NetworkInterfaceSet",
	OPENSTACK_EN:         "services,users",
	QINGCLOUD_EN:         "DescribeSecurityGroupIPSets,DescribeSecurityGroupRules,DescribeLoadBalancerListeners,DescribeLoadBalancerBackends,DescribeNics,DescribeEips",
	APSARA_STACK_EN:      "NetworkInterfaceSet,ListenerPortAndProtocol,BackendServer,SnatTableEntry,ForwardTableEntry,RouteEntry,Permission",
	TENCENT_TCE_EN:       "DescribeNetworkInterfacesEx,DescribeSecurityGroupPolicy",
	QINGCLOUD_PRIVATE_EN: "DescribeSecurityGroupIPSets,DescribeSecurityGroupRules,DescribeLoadBalancerListeners,DescribeLoadBalancerBackends,DescribeNics,DescribeEips",
}
View Source
var DefaultVTapGroupConfig = &agent_config.AgentGroupConfigModel{
	MaxCollectPps:                 &DefaultMaxCollectPps,
	MaxNpbBps:                     &DefaultMaxNpbBps,
	MaxCPUs:                       &DefaultMaxCPUs,
	MaxMilliCPUs:                  &DefaultMaxMilliCPUs,
	MaxMemory:                     &DefaultMaxMemory,
	PlatformSyncInterval:          &DefaultPlatformSyncInterval,
	SyncInterval:                  &DefaultSyncInterval,
	StatsInterval:                 &DefaultStatsInterval,
	RsyslogEnabled:                &DefaultRsyslogEnabled,
	MaxTxBandwidth:                &DefaultMaxTxBandwidth,
	BandwidthProbeInterval:        &DefaultBandwidthProbeInterval,
	TapInterfaceRegex:             &DefaultTapInterfaceRegex,
	MaxEscapeSeconds:              &DefaultMaxEscapeSeconds,
	Mtu:                           &DefaultMtu,
	OutputVlan:                    &DefaultOutputVlan,
	CollectorSocketType:           &DefaultCollectorSocketType,
	CompressorSocketType:          &DefaultCompressorSocketType,
	NpbSocketType:                 &DefaultNpbSocketType,
	NpbVlanMode:                   &DefaultNpbVlanMode,
	CollectorEnabled:              &DefaultCollectorEnabled,
	VTapFlow1sEnabled:             &DefaultVTapFlow1sEnabled,
	L4LogTapTypes:                 &DefaultL4LogTapTypes,
	L4LogIgnoreTapSides:           &DefaultL4LogIgnoreTapSides,
	L7LogIgnoreTapSides:           &DefaultL7LogIgnoreTapSides,
	NpbDedupEnabled:               &DefaultNpbDedupEnabled,
	PlatformEnabled:               &DefaultPlatformEnabled,
	IfMacSource:                   &DefaultIfMacSource,
	VMXMLPath:                     &DefaultVMXMLPath,
	NatIPEnabled:                  &DefaultNatIPEnabled,
	CapturePacketSize:             &DefaultCapturePacketSize,
	InactiveServerPortEnabled:     &DefaultInactiveServerPortEnabled,
	InactiveIPEnabled:             &DefaultInactiveIPEnabled,
	LogThreshold:                  &DefaultLogThreshold,
	LogLevel:                      &DefaultLogLevel,
	LogRetention:                  &DefaultLogRetention,
	HTTPLogProxyClient:            &DefaultHTTPLogProxyClient,
	HTTPLogTraceID:                &DefaultHTTPLogTraceID,
	L7LogPacketSize:               &DefaultL7LogPacketSize,
	L4LogCollectNpsThreshold:      &DefaultL4LogCollectNpsThreshold,
	L7LogCollectNpsThreshold:      &DefaultL7LogCollectNpsThreshold,
	L7MetricsEnabled:              &DefaultL7MetricsEnabled,
	L7LogStoreTapTypes:            &DefaultL7LogStoreTapTypes,
	CaptureSocketType:             &DefaultCaptureSocketType,
	CaptureBpf:                    &DefaultCaptureBpf,
	TapMode:                       &DefaultTapMode,
	ThreadThreshold:               &DefaultThreadThreshold,
	ProcessThreshold:              &DefaultProcessThreshold,
	NtpEnabled:                    &DefaultNtpEnabled,
	L4PerformanceEnabled:          &DefaultL4PerformanceEnabled,
	PodClusterInternalIP:          &DefaultPodClusterInternalIP,
	Domains:                       &DefaultDomains,
	DecapType:                     &DefaultDecapType,
	HTTPLogSpanID:                 &DefaultHTTPLogSpanID,
	SysFreeMemoryLimit:            &DefaultSysFreeMemoryLimit,
	LogFileSize:                   &DefaultLogFileSize,
	HTTPLogXRequestID:             &DefaultHTTPLogXRequestID,
	ExternalAgentHTTPProxyEnabled: &DefaultExternalAgentHTTPProxyEnabled,
	ExternalAgentHTTPProxyPort:    &DefaultExternalAgentHTTPProxyPort,
	AnalyzerPort:                  &DefaultAnalyzerPort,
	ProxyControllerPort:           &DefaultProxyControllerPort,
	ProxyControllerIP:             &DefaultProxyControllerIP,
	AnalyzerIP:                    &DefaultAnalyzerIP,
	WasmPlugins:                   &DefaultWasmPlugins,
	SoPlugins:                     &DefaultSoPlugins,

	SystemLoadCircuitBreakerThreshold: &DefaultSystemLoadCircuitBreakerThreshold,
	SystemLoadCircuitBreakerRecover:   &DefaultSystemLoadCircuitBreakerRecover,
	SystemLoadCircuitBreakerMetric:    &DefaultSystemLoadCircuitBreakerMetric,
}
View Source
var DomainTypeToIconID = map[int]int{
	KUBERNETES: 14,
}
View Source
var NodeName, NodeIP, PodName, PodIP, NameSpace string
View Source
var (
	PluginTypeName = map[int]string{
		PLUGIN_TYPE_WASM: "wasm",
		PLUGIN_TYPE_SO:   "so",
	}
)
View Source
var ProtocolMap = map[string]int{
	"TCP": TCP,
	"UDP": UDP,
}
View Source
var VIF_DEVICE_TYPE_TO_RESOURCE_TYPE = map[int]string{
	VIF_DEVICE_TYPE_HOST:           RESOURCE_TYPE_HOST_EN,
	VIF_DEVICE_TYPE_VM:             RESOURCE_TYPE_VM_EN,
	VIF_DEVICE_TYPE_VROUTER:        RESOURCE_TYPE_VROUTER_EN,
	VIF_DEVICE_TYPE_DHCP_PORT:      RESOURCE_TYPE_DHCP_PORT_EN,
	VIF_DEVICE_TYPE_NAT_GATEWAY:    RESOURCE_TYPE_NAT_GATEWAY_EN,
	VIF_DEVICE_TYPE_LB:             RESOURCE_TYPE_LB_EN,
	VIF_DEVICE_TYPE_RDS_INSTANCE:   RESOURCE_TYPE_RDS_INSTANCE_EN,
	VIF_DEVICE_TYPE_REDIS_INSTANCE: RESOURCE_TYPE_REDIS_INSTANCE_EN,
	VIF_DEVICE_TYPE_POD_NODE:       RESOURCE_TYPE_POD_NODE_EN,
	VIF_DEVICE_TYPE_POD_SERVICE:    RESOURCE_TYPE_POD_SERVICE_EN,
	VIF_DEVICE_TYPE_POD:            RESOURCE_TYPE_POD_EN,
}
View Source
var VTapExceptionChinese = map[int64]string{
	2 << 0:                                 "自检失败:日志所在磁盘剩余空间不足100MB",
	2 << 1:                                 "自检失败:可用内存不足",
	2 << 2:                                 "自检失败:Coredump文件过多",
	2 << 3:                                 "分发熔断",
	2 << 4:                                 "分发流量达到限速",
	2 << 5:                                 "到分发点的网关ARP无法找到",
	2 << 6:                                 "采集包速率达到限速",
	2 << 7:                                 "到数据节点的网关ARP无法找到",
	2 << 8:                                 "控制器下发的配置信息校验不通过",
	2 << 9:                                 "采集器线程数超限",
	2 << 10:                                "采集器进程数超限",
	2 << 11:                                "采集器编译生成的分发和PCAP策略数量超限",
	2 << 12:                                "空闲内存超限",
	2 << 13:                                "日志文件大小超限",
	2 << 14:                                "控制SOCKET错误",
	2 << 15:                                "数据SOCKET错误",
	2 << 16:                                "分发SOCKET错误",
	2 << 17:                                "集成SOCKET错误",
	2 << 18:                                "CGROUPS配置错误",
	VTAP_EXCEPTION_LICENSE_NOT_ENGOUTH:     "采集器授权个数不足",
	VTAP_EXCEPTION_ALLOC_ANALYZER_FAILED:   "分配数据节点失败",
	VTAP_EXCEPTION_ALLOC_CONTROLLER_FAILED: "分配控制器失败",
}
View Source
var (
	VTapStateToChinese = map[int]string{
		VTAP_STATE_NOT_CONNECTED: "失联",
		VTAP_STATE_NORMAL:        "运行",
		VTAP_STATE_DISABLE:       "禁用",
		VTAP_STATE_PENDING:       "未注册",
	}
)
View Source
var VTapTypeChinese = map[int]string{
	VTAP_TYPE_KVM:                  "KVM",
	VTAP_TYPE_ESXI:                 "ESXI",
	VTAP_TYPE_WORKLOAD_V:           "云服务器-V",
	VTAP_TYPE_WORKLOAD_P:           "云服务器-P",
	VTAP_TYPE_DEDICATED:            "专属服务器",
	VTAP_TYPE_POD_HOST:             "容器-P",
	VTAP_TYPE_POD_VM:               "容器-V",
	VTAP_TYPE_TUNNEL_DECAPSULATION: "隧道解封装",
	VTAP_TYPE_HYPER_V:              "Hyper-V",
	VTAP_TYPE_K8S_SIDECAR:          "K8s-Sidecar",
}
View Source
var VTapTypeName = map[int]string{
	VTAP_TYPE_KVM:                  "KVM",
	VTAP_TYPE_ESXI:                 "ESXI",
	VTAP_TYPE_WORKLOAD_V:           "CHOST_VM",
	VTAP_TYPE_WORKLOAD_P:           "CHOST_BM",
	VTAP_TYPE_DEDICATED:            "DEDICATED",
	VTAP_TYPE_POD_HOST:             "K8S_BM",
	VTAP_TYPE_POD_VM:               "K8S_VM",
	VTAP_TYPE_TUNNEL_DECAPSULATION: "TUN_DECAP",
	VTAP_TYPE_HYPER_V:              "HYPER_V",
	VTAP_TYPE_K8S_SIDECAR:          "K8S_SIDECAR",
}
View Source
var VtapTapModeName = map[int]string{
	TAPMODE_LOCAL:    "本地",
	TAPMODE_MIRROR:   "镜像",
	TAPMODE_ANALYZER: "专属",
	TAPMODE_DECAP:    "隧道解封装",
}

Functions

func AesDecrypt

func AesDecrypt(cryptedStr, keyStr string) (string, error)

func AesEncrypt

func AesEncrypt(origDataStr, keyStr string) (string, error)

func CURLForm

func CURLForm(method string, url string, values url.Values, options ...HeaderOption) (*simplejson.Json, error)

TODO optimize CURLForm 调用 deepflow 其他服务 API 并获取返回结果,Content-Type 为 application/x-www-form-urlencoded

func CURLPerform

func CURLPerform(method string, url string, body map[string]interface{}, options ...HeaderOption) (*simplejson.Json, error)

CURLPerform 调用 deepflow 其他服务 API 并获取返回结果,Content-Type 为 application/json

func CheckSelfAndGetMasterControllerHostPort

func CheckSelfAndGetMasterControllerHostPort() (ok bool, masterCtrlIP string, httpPort, grpcPort int, err error)

func Contains

func Contains[T Comparable](slice []T, val T) bool

func DecryptSecretKey

func DecryptSecretKey(secretKey string) (string, error)

func EncryptSecretKey

func EncryptSecretKey(secretKey string) (string, error)

func GenerateAesKey

func GenerateAesKey(input []byte) string

func GenerateKuberneteClusterIDByMD5

func GenerateKuberneteClusterIDByMD5(md5 string) (string, error)

func GenerateShortUUID

func GenerateShortUUID() string

func GenerateUUID

func GenerateUUID(str string) string

func GenerateUUIDByOrgID

func GenerateUUIDByOrgID(orgID int, s string) string

func GetArchType

func GetArchType(arch string) int

func GetCAMD5

func GetCAMD5() string

func GetCURLIP

func GetCURLIP(ip string) string

功能:获取用于API调用的IP地址

func GetEncryptKey

func GetEncryptKey(controllerIP, grpcServerPort, key string) (string, error)

func GetLocalClusterID

func GetLocalClusterID() (string, error)

func GetMasterControllerHostPort

func GetMasterControllerHostPort() (masterIP string, httpPort, grpcPort int, err error)

func GetNameSpace

func GetNameSpace() string

func GetNodeIP

func GetNodeIP() string

func GetNodeName

func GetNodeName() string

func GetOsType

func GetOsType(os string) int

func GetPodIP

func GetPodIP() string

func GetPodName

func GetPodName() string

func GetSelfController

func GetSelfController() (*mysqlmodel.Controller, error)

func GetUUID

func GetUUID(str string, namespace uuid.UUID) string

通过字符串获取UUID

func GetUUIDByOrgID

func GetUUIDByOrgID(orgID int, s string) string

func GetUUIDByOrgIDAndNamespaceDNS

func GetUUIDByOrgIDAndNamespaceDNS(orgID int, s string) string

func IDGenerateUUID

func IDGenerateUUID(orgID int, s string) string

func InitEnvData

func InitEnvData()

func IsStandaloneRunningMode

func IsStandaloneRunningMode() bool

func IsTCPActive

func IsTCPActive(ip string, port int) error

func PKCS7Padding

func PKCS7Padding(ciphertext []byte, blockSize int) []byte

func PKCS7UnPadding

func PKCS7UnPadding(origData []byte) []byte

func StrToJsonAndMap

func StrToJsonAndMap(str string) (resJson string, resMap map[string]string)

a:b,c:d -> {"a":"b","c":"d"}, map[string]string{"a":"b","c":"d"}

Types

type Comparable

type Comparable interface {
	~int | ~string
}

type DataChanged

type DataChanged string
const (
	DATA_CHANGED_VTAP          DataChanged = "vtap"
	DATA_CHANGED_ANALYZER      DataChanged = "analyzer"
	DATA_CHANGED_PLATFORM_DATA DataChanged = "platform_data"
	DATA_CHANGED_FLOW_ACL      DataChanged = "flow_acl"
	DATA_CHANGED_GROUP         DataChanged = "group"
	DATA_CHANGED_TAP_TYPE      DataChanged = "tap_type"
	DATA_CHANGED_SERVICE       DataChanged = "service"
)

type FPermit

type FPermit struct {
	Enabled bool   `default:"false" yaml:"enabled"`
	Host    string `default:"fpermit" yaml:"host"`
	Port    int    `default:"20823" yaml:"port"`
	Timeout int    `default:"30" yaml:"timeout"`
}

type GlobalConfig

type GlobalConfig struct {
	HTTPPort     int
	HTTPNodePort int
	GRPCPort     int
	GRPCNodePort int
}
var GConfig *GlobalConfig

type HeaderOption

type HeaderOption func(req *http.Request)

func WithHeader

func WithHeader(key, value string) HeaderOption

func WithORGHeader

func WithORGHeader(value string) HeaderOption

type IngesterApi

type IngesterApi struct {
	Port     int `default:"20106" yaml:"port"`
	NodePort int `default:"30106" yaml:"node-port"`
	Timeout  int `default:"60" yaml:"timeout"`
}

type KVPair

type KVPair struct {
	Key   string
	Value int
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL