Documentation ¶
Index ¶
- Constants
- Variables
- func GetAddonConfig(cfgStr string) (map[string]interface{}, error)
- func InitCache(ttl time.Duration, size int)
- func IsEncryptedValueByKey(key string) bool
- func IsEncryptedValueByValue(value string) bool
- func Min(x, y int) int
- func SetAddonVolumes(options map[string]string, targetPath string, readOnly bool) diceyml.Volume
- func SetlabelsFromOptions(options, labels map[string]string)
- type Addon
- func (a *Addon) AddonConfigCallback(insId string, response *apistructs.AddonConfigCallBackResponse) error
- func (a *Addon) AddonCreate(req apistructs.AddonDirectCreateRequest) ([]string, error)
- func (a *Addon) AddonDelete(req apistructs.AddonDirectDeleteRequest) error
- func (a *Addon) AddonDeprovisionCallback(insId string) error
- func (a *Addon) AddonProvisionCallback(insId string, response *apistructs.AddonCreateCallBackResponse) error
- func (a *Addon) AddonYmlExport(projectID string) (*diceyml.Object, error)
- func (a *Addon) AddonYmlImport(projectID uint64, yml diceyml.Object, userid string) error
- func (a *Addon) ApacheZookeeperDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) AttachAndCreate(params *apistructs.AddonHandlerCreateItem) (*apistructs.AddonInstanceRes, error)
- func (a *Addon) BatchCreate(req *apistructs.AddonCreateRequest) error
- func (a *Addon) BuildAddonAndTenantMap(projectAddons []dbclient.AddonInstanceRouting, ...) (addonnameMap map[string][]dbclient.AddonInstanceRouting, ...)
- func (a *Addon) BuildAddonRequestGroup(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) (*apistructs.ServiceGroupCreateV2Request, error)
- func (a *Addon) BuildAddonScaleRequestGroup(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) (*apistructs.ServiceGroup, error)
- func (a *Addon) BuildCanalServiceItem(useOperator bool, params *apistructs.AddonHandlerCreateItem, ...) error
- func (a *Addon) BuildCommonServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildConsulServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildESOperatorServiceItem(params *apistructs.AddonHandlerCreateItem, ...) error
- func (a *Addon) BuildEsServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildInfluxDBServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildKafkaServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildMysqlOperatorServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildMysqlServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRabbitmqServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRealZkServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRedisOperatorServiceItem(options map[string]string, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRedisServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRocketMQOperaotrServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildRocketMqServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) BuildZookeeperServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) CanalDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) CheckCustomAddonPermission(userID string, orgID, projecID uint64) (bool, error)
- func (a *Addon) CheckDeployCondition(addonName, addonPlan, workspace string) (bool, error)
- func (a *Addon) CleanRemainingAddonAttachment() (bool, error)
- func (a *Addon) CommonDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, ...) (map[string]string, error)
- func (a *Addon) ConsulDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) CreateAddonProvider(req *apistructs.AddonProviderRequest, addonName, providerDomain, userId string) (int, *apistructs.AddonProviderResponse, error)
- func (a *Addon) CreateAddonTenant(name string, addonInstanceRoutingID string, config map[string]string) (string, error)
- func (a *Addon) CreateCustom(req *apistructs.CustomAddonCreateRequest) (*map[string]string, error)
- func (a *Addon) CreateMysqlTenant(name string, addoninsRouting *dbclient.AddonInstanceRouting, ...) (string, error)
- func (a *Addon) DecryptPassword(kmskey *string, password string) (string, error)
- func (a *Addon) Delete(userID, routingInstanceID string) error
- func (a *Addon) DeleteAddonProvider(req *apistructs.AddonProviderRequest, uuid, addonName, providerDomain string) (*apistructs.AddonProviderDeleteResponse, error)
- func (a *Addon) DeleteTenant(userID, addonTenantID string) error
- func (a *Addon) EsDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) ExportLogInfo(level apistructs.ErrorLogLevel, tp apistructs.ErrorResourceType, ...)
- func (a *Addon) ExportLogInfoDetail(level apistructs.ErrorLogLevel, tp apistructs.ErrorResourceType, id string, ...)
- func (a *Addon) FailAndDelete(addonIns *dbclient.AddonInstance) error
- func (a *Addon) FindNeedCreateAddon(params *apistructs.AddonHandlerCreateItem) (*dbclient.AddonInstanceRouting, error)
- func (a *Addon) Get(userID, orgID, routingInstanceID string, internalcall bool) (*apistructs.AddonFetchResponseData, error)
- func (a *Addon) GetAddonConfig(ins *dbclient.AddonInstance) (*apistructs.AddonConfigRes, error)
- func (a *Addon) GetAddonExtention(params *apistructs.AddonHandlerCreateItem) (*apistructs.AddonExtension, *diceyml.Object, error)
- func (a *Addon) GetAddonResourceStatus(addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) GetAddonTenantConfig(ins *dbclient.AddonInstanceTenant) (map[string]interface{}, error)
- func (a *Addon) GetDeployAndRemoveAddons(runtimeID uint64) ([]dbclient.AddonPrebuild, []dbclient.AddonInstanceRouting, error)
- func (a *Addon) GetMiddleware(orgID uint64, userID, instanceID string) (*apistructs.MiddlewareFetchResponseData, error)
- func (a *Addon) GetMiddlewareAddonClassification(orgID uint64, params *apistructs.MiddlewareListRequest) (*map[string]apistructs.MiddlewareResourceItem, error)
- func (a *Addon) GetMiddlewareAddonDaily(orgID uint64, params *apistructs.MiddlewareListRequest) (*map[string]interface{}, error)
- func (a *Addon) GetMiddlewareResource(instanceID string) ([]apistructs.MiddlewareResourceFetchResponseData, error)
- func (a *Addon) GetRuntimeAddonConfig(runtimeID uint64) (*[]apistructs.AddonConfigRes, error)
- func (a *Addon) GetTenant(userID, orgID, id string, internalcall bool) (*apistructs.AddonFetchResponseData, error)
- func (a *Addon) GetTotalResourceWithTime(orgID uint64, params *apistructs.MiddlewareListRequest) (*apistructs.MiddlewareResourceItem, error)
- func (a *Addon) InfluxDBDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) InitMySQLAccount(addonIns *dbclient.AddonInstance, ...) error
- func (a *Addon) InnerGetMiddleware(instanceID string) (*apistructs.MiddlewareFetchResponseData, error)
- func (a *Addon) KafkaDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, ...) (map[string]string, error)
- func (a *Addon) ListAddonInstanceByOrg(orgid uint64) ([]dbclient.AddonInstance, error)
- func (a *Addon) ListAvailable(orgID, projectID, workspace string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByAddonName(orgID uint64, addonName string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByAddonNameAndProject(projectID, workspace, addonName string) ([]apistructs.AddonNameResultItem, error)
- func (a *Addon) ListByCategory(orgID uint64, category string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByDiceymlEnvs(diceyml_s string, projectid uint64, workspace string, clustername string) ([]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByOrg(orgID uint64) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByProject(orgID, projectID uint64, category string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByRuntime(orgID, runtimeID uint64, projectID, workspace string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListByWorkbench(orgID uint64, userID, category string) (*[]apistructs.AddonFetchResponseData, error)
- func (a *Addon) ListCustomAddon() (*[]map[string]interface{}, error)
- func (a *Addon) ListExtension(extensionType string) (*[]map[string]interface{}, error)
- func (a *Addon) ListInstanceByRuntime(runtimeID uint64) ([]dbclient.AddonInstance, error)
- func (a *Addon) ListInstanceRoutingByRuntime(runtimeID uint64) (*[]dbclient.AddonInstanceRouting, error)
- func (a *Addon) ListMicroServiceMenu(projectID, env string) ([]*apistructs.MicroServiceMenuResponseData, error)
- func (a *Addon) ListMicroServiceProject(projectIDs []string) ([]*apistructs.MicroServiceProjectResponseData, error)
- func (a *Addon) ListMiddleware(orgID uint64, params *apistructs.MiddlewareListRequest) (*apistructs.MiddlewareListResponseData, error)
- func (a *Addon) ListReferencesByInstanceID(orgID uint64, userID, instanceID string) (*[]apistructs.AddonReferenceInfo, error)
- func (a *Addon) ListReferencesByRoutingInstanceID(orgID uint64, userID, routingInstanceID string, internal ...bool) (*[]apistructs.AddonReferenceInfo, error)
- func (a *Addon) MiddlewareListItem(total int, orgID uint64, params *apistructs.MiddlewareListRequest, ...) (*apistructs.MiddlewareListResponseData, error)
- func (a *Addon) MySQLDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, ...) (map[string]string, error)
- func (a *Addon) ParseAddonFullPlan(fullPlan string) (string, string, error)
- func (a *Addon) ParsePreBuild(appID, runtimeID uint64, runtimeName, workspace string, ...) *dbclient.AddonPrebuild
- func (a *Addon) PrepareCheckProjectLastResource(projectID uint64, req *[]apistructs.AddonHandlerCreateItem) error
- func (a *Addon) RabbitmqDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) RedisDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) RocketDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- func (a *Addon) RuntimeAddonRemove(runtimeID, env, operatorId string, projectId uint64) error
- func (a *Addon) RuntimeAddonStatus(runtimeID string) (uint8, error)
- func (a *Addon) Scale(userID, routingInstanceID, action string) error
- func (a *Addon) StructToMap(data interface{}, depth int, tag ...string) map[string]interface{}
- func (a *Addon) SyncAddonResources()
- func (a *Addon) UpdateAddonStatus(addonIns *dbclient.AddonInstance, addonStatus apistructs.AddonStatus) error
- func (a *Addon) UpdateCustom(userID, addonID string, orgID uint64, configReq *map[string]interface{}) error
- func (a *Addon) ZookeeperDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
- type Cache
- type MicroServiceProjectData
- type Option
- func WithBundle(bdl *bundle.Bundle) Option
- func WithCap(cap cap.Cap) Option
- func WithClusterInfoImpl(instanceinfoImpl clusterinfo.ClusterInfo) Option
- func WithClusterSvc(clusterSvc clusterpb.ClusterServiceServer) Option
- func WithDBClient(db *dbclient.DBClient) Option
- func WithEnvEncrypt(encrypt *encryption.EnvEncrypt) Option
- func WithHTTPClient(hc *httpclient.HTTPClient) Option
- func WithInstanceinfoImpl(instanceinfoImpl *instanceinfo.InstanceInfoImpl) Option
- func WithKMSWrapper(kms mysql.KMSWrapper) Option
- func WithOrg(org org.ClientInterface) Option
- func WithResource(resource *resource.Resource) Option
- func WithServiceGroup(serviceGroupImpl servicegroup.ServiceGroup) Option
- func WithTenantSvc(tenantSvc tenantpb.TenantServiceServer) Option
- type SourcecovAddonManagement
- type SourcecovAddonManagementDeps
- type VersionMap
Constants ¶
const ( ConfigCenterAddon = "config-center" RegisterCenterAddon = "registercenter" NacosAddon = "nacos" )
const ( DefaultTtl = 10 * time.Minute DefaultSize = 500 )
const ( AddonTypeDoseNoExist = "AddonTypeDoseNoExist" NoRegisterCenterFound = "NoRegisterCenterFound" AddonVersionDoseNoExist = "AddonVersionDoseNoExist" AddonDefaultVersionDoseNoExist = "AddonDefaultVersionDoseNoExist" AddonPlanIllegal = "AddonPlanIllegal" AddonPlanNotSupport = "AddonPlanNotSupport" AddonDeprecated = "AddonDeprecated" )
const ( InfluxDBDataPath = "/var/lib/influxdb2" InfluxDBConfHost = "INFLUX_HOST" InfluxDBConfUser = "INFLUX_USERNAME" InfluxDBConfPassword = "INFLUX_PASSWORD" InfluxDBConfORG = "INFLUX_ORG" InfluxDBServicePort = "8086" )
const ( InfluxDBInitPrefix = "DOCKER_INFLUXDB_INIT_" InfluxDBInitUserNameKey = InfluxDBInitPrefix + "USERNAME" InfluxDBInitUserName = "influxdb" InfluxDBInitPasswordKey = InfluxDBInitPrefix + "PASSWORD" // InfluxDBInitModeKey default init mode: setup InfluxDBInitModeKey = InfluxDBInitPrefix + "MODE" InfluxDBInitMode = "setup" // InfluxDBInitOrgKey erda project name -> influxdb org InfluxDBInitOrgKey = InfluxDBInitPrefix + "ORG" // InfluxDBInitBucketKey erda application name -> influxdb bucket InfluxDBInitBucketKey = InfluxDBInitPrefix + "BUCKET" InfluxDBInitBucket = "erda" // InfluxDBInitRetentionKey default 1w InfluxDBInitRetentionKey = InfluxDBInitPrefix + "RETENTION" InfluxDBInitRetention = "1w" )
const ( InfluxDBParamsOrg = "org" InfluxDBParamsBucket = "bucket" InfluxDBParamsRetention = "retention" )
const ( CREATE_DB = "CREATE DATABASE IF NOT EXISTS `%s`;" CREATE_USER = "CREATE USER '%s'@'%%' IDENTIFIED by '%s';" GRANT_USER_TO_DB = "GRANT ALL ON %s.* TO '%s'@'%%';" FLUSH = "flush privileges;" )
const ErdaEncryptedValue string = "ERDA_ENCRYPTED"
ErdaEncryptedValue encrypted value
const I18nClusterAddonRedeploy = "ClusterAddonRedeploy"
const (
InfluxDBKMSPasswordKey = "influxdb-password"
)
Variables ¶
var ( // AddonInfos 市场addon全集 key: addonName, value: apistructs.Extension AddonInfos sync.Map // ProjectInfos 项目信息缓存 key: projectId, value: apistructs.ProjectDTO ProjectInfos sync.Map // AppInfos app列表缓存 key: appID, value: apistructs.ApplicationDTO AppInfos sync.Map )
var ( EnvKafkaExporter = "KAFKA_EXPORTER" DefaultKafkaExporterImage = "registry.erda.cloud/retag/kminion:v2.2.0" )
var ExtensionDeployAddon = map[string]string{"mysql": "", "redis": "", "consul": "", "canal": "", "kafka": "", "rabbitmq": "", "rocketmq": "", "terminus-elasticsearch": "", "terminus-zookeeper": ""} // key 为 appID, value 为应用详情
ExtensionDeployAddon .
Functions ¶
func GetAddonConfig ¶
GetAddonConfig return unmarshal config
func IsEncryptedValueByKey ¶
IsEncryptedValueByKey Determine whether it is an encrypted field by key
func IsEncryptedValueByValue ¶
IsEncryptedValueByValue Determine whether it is an encrypted field by value
func SetAddonVolumes ¶
setAddonVolumes set Volumes for diceyml.Service for addon service service: addon service options: 主要获取如下三种 options
"addonDiskType": "SSD" "addonVolumeSize": "10" "addonSnapMaxHistory": "3"
targetPath:容器中卷映射目录 readOnly: 表明卷是否以只读方式挂载
func SetlabelsFromOptions ¶
SetlabelsFromOptions set service labels from addon.Optons
Types ¶
type Addon ¶
type Addon struct {
// contains filtered or unexported fields
}
Addon addon 实例对象封装
func (*Addon) AddonConfigCallback ¶
func (a *Addon) AddonConfigCallback(insId string, response *apistructs.AddonConfigCallBackResponse) error
AddonConfigCallback addon配置回调
func (*Addon) AddonCreate ¶
func (a *Addon) AddonCreate(req apistructs.AddonDirectCreateRequest) ([]string, error)
func (*Addon) AddonDelete ¶
func (a *Addon) AddonDelete(req apistructs.AddonDirectDeleteRequest) error
func (*Addon) AddonDeprovisionCallback ¶
AddonDeprovisionCallback addon删除回调
func (*Addon) AddonProvisionCallback ¶
func (a *Addon) AddonProvisionCallback(insId string, response *apistructs.AddonCreateCallBackResponse) error
AddonProvisionCallback addon创建回调
func (*Addon) AddonYmlExport ¶
func (*Addon) AddonYmlImport ¶
func (*Addon) ApacheZookeeperDeployStatus ¶
func (a *Addon) ApacheZookeeperDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
ApacheZookeeperDeployStatus zk状态拉取
func (*Addon) AttachAndCreate ¶
func (a *Addon) AttachAndCreate(params *apistructs.AddonHandlerCreateItem) (*apistructs.AddonInstanceRes, error)
AttachAndCreate addon创建,runtime建立关系方法
func (*Addon) BatchCreate ¶
func (a *Addon) BatchCreate(req *apistructs.AddonCreateRequest) error
BatchCreate 批量创建 addons
func (*Addon) BuildAddonAndTenantMap ¶
func (a *Addon) BuildAddonAndTenantMap(projectAddons []dbclient.AddonInstanceRouting, projectAddonTenants []dbclient.AddonInstanceTenant) ( addonnameMap map[string][]dbclient.AddonInstanceRouting, addonIDMap map[string]dbclient.AddonInstanceRouting, addonTenantNameMap map[string][]dbclient.AddonInstanceTenant, addonTenantIDMap map[string]dbclient.AddonInstanceTenant)
func (*Addon) BuildAddonRequestGroup ¶
func (a *Addon) BuildAddonRequestGroup(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) (*apistructs.ServiceGroupCreateV2Request, error)
BuildAddonRequestGroup build请求serviceGroup的body信息
func (*Addon) BuildAddonScaleRequestGroup ¶
func (a *Addon) BuildAddonScaleRequestGroup(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, scaleAction string, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) (*apistructs.ServiceGroup, error)
BuildAddonScaleRequestGroup build请求serviceGroup的body信息
func (*Addon) BuildCanalServiceItem ¶
func (a *Addon) BuildCanalServiceItem(useOperator bool, params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) error
buildCanalServiceItem 构造canal的service信息
func (*Addon) BuildCommonServiceItem ¶
func (a *Addon) BuildCommonServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
BuildCommonServiceItem 构造标准化的addon发布service body
func (*Addon) BuildConsulServiceItem ¶
func (a *Addon) BuildConsulServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildConsulServiceItem 构造consul的service信息
func (*Addon) BuildESOperatorServiceItem ¶
func (a *Addon) BuildESOperatorServiceItem(params *apistructs.AddonHandlerCreateItem, addonSpec *apistructs.AddonExtension, addonIns *dbclient.AddonInstance, addonDice *diceyml.Object, version string) error
func (*Addon) BuildEsServiceItem ¶
func (a *Addon) BuildEsServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildEsServiceItem 构造es的service信息
func (*Addon) BuildInfluxDBServiceItem ¶
func (a *Addon) BuildInfluxDBServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) error
BuildInfluxDBServiceItem build influxdb service item
func (*Addon) BuildKafkaServiceItem ¶
func (a *Addon) BuildKafkaServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildKafkaServiceItem 构造kafka的service信息
func (*Addon) BuildMysqlOperatorServiceItem ¶
func (a *Addon) BuildMysqlOperatorServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, operatorSpec *apistructs.AddonExtension, operatorDice, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildMysqlOperatorServiceItem 生成operator发布的格式
func (*Addon) BuildMysqlServiceItem ¶
func (a *Addon) BuildMysqlServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildMysqlServiceItem 构造mysql的service信息
func (*Addon) BuildRabbitmqServiceItem ¶
func (a *Addon) BuildRabbitmqServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) error
BuildRabbitmqServiceItem 构造rabbitmq的service信息
func (*Addon) BuildRealZkServiceItem ¶
func (a *Addon) BuildRealZkServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
BuildRealZkServiceItem 构造zookeeper的service信息
func (*Addon) BuildRedisOperatorServiceItem ¶
func (a *Addon) BuildRedisOperatorServiceItem(options map[string]string, addonIns *dbclient.AddonInstance, addonDice *diceyml.Object) error
buildRedisOperatorServiceItem redis operator build service item
func (*Addon) BuildRedisServiceItem ¶
func (a *Addon) BuildRedisServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object) error
buildRedisServiceItem 构造redis的service信息
func (*Addon) BuildRocketMQOperaotrServiceItem ¶
func (a *Addon) BuildRocketMQOperaotrServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData, version string) error
func (*Addon) BuildRocketMqServiceItem ¶
func (a *Addon) BuildRocketMqServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
func (*Addon) BuildZookeeperServiceItem ¶
func (a *Addon) BuildZookeeperServiceItem(params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, clusterInfo *apistructs.ClusterInfoData) error
buildZookeeperServiceItem 构造zookeeper的service信息
func (*Addon) CanalDeployStatus ¶
func (a *Addon) CanalDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
CanalDeployStatus canal状态拉取
func (*Addon) CheckCustomAddonPermission ¶
CheckCustomAddonPermission 校验 custom addon 权限
func (*Addon) CheckDeployCondition ¶
func (*Addon) CleanRemainingAddonAttachment ¶
CleanRemainingAddonAttachment clean remain addon attachment Deleting the addon before the addon is created will cause the addon to leak Deleting the runtime during deployment will cause this to happen
func (*Addon) CommonDeployStatus ¶
func (a *Addon) CommonDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, addonDice *diceyml.Object, addonSpec *apistructs.AddonExtension) (map[string]string, error)
CommonDeployStatus 通用addon状态拉取
func (*Addon) ConsulDeployStatus ¶
func (a *Addon) ConsulDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
ConsulDeployStatus consul状态拉取
func (*Addon) CreateAddonProvider ¶
func (a *Addon) CreateAddonProvider(req *apistructs.AddonProviderRequest, addonName, providerDomain, userId string) (int, *apistructs.AddonProviderResponse, error)
CreateAddonProvider 请求addon provider,获取新的addon实例
func (*Addon) CreateAddonTenant ¶
func (a *Addon) CreateAddonTenant(name string, addonInstanceRoutingID string, config map[string]string) (string, error)
CreateAddonTenant
func (*Addon) CreateCustom ¶
func (a *Addon) CreateCustom(req *apistructs.CustomAddonCreateRequest) (*map[string]string, error)
CreateCustom 创建自定义 addon
func (*Addon) CreateMysqlTenant ¶
func (a *Addon) CreateMysqlTenant(name string, addoninsRouting *dbclient.AddonInstanceRouting, addonins *dbclient.AddonInstance, config map[string]string) (string, error)
func (*Addon) DecryptPassword ¶
optional: kmskey
func (*Addon) DeleteAddonProvider ¶
func (a *Addon) DeleteAddonProvider(req *apistructs.AddonProviderRequest, uuid, addonName, providerDomain string) (*apistructs.AddonProviderDeleteResponse, error)
DeleteAddonProvider 删除addon provideraddon实例
func (*Addon) DeleteTenant ¶
func (*Addon) EsDeployStatus ¶
func (a *Addon) EsDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
EsDeployStatus es状态拉取
func (*Addon) ExportLogInfo ¶
func (a *Addon) ExportLogInfo(level apistructs.ErrorLogLevel, tp apistructs.ErrorResourceType, id, dedupid string, format string, params ...interface{})
func (*Addon) ExportLogInfoDetail ¶
func (a *Addon) ExportLogInfoDetail(level apistructs.ErrorLogLevel, tp apistructs.ErrorResourceType, id string, humanlog, detaillog string)
func (*Addon) FailAndDelete ¶
func (a *Addon) FailAndDelete(addonIns *dbclient.AddonInstance) error
FailAndDelete addon发布失败后,更新表状态
func (*Addon) FindNeedCreateAddon ¶
func (a *Addon) FindNeedCreateAddon(params *apistructs.AddonHandlerCreateItem) (*dbclient.AddonInstanceRouting, error)
FindNeedCreateAddon 判断是否需要真实创建addon
func (*Addon) Get ¶
func (a *Addon) Get(userID, orgID, routingInstanceID string, internalcall bool) (*apistructs.AddonFetchResponseData, error)
Get 根据 routingInstanceID 获取 addon 实例详情
func (*Addon) GetAddonConfig ¶
func (a *Addon) GetAddonConfig(ins *dbclient.AddonInstance) (*apistructs.AddonConfigRes, error)
func (*Addon) GetAddonExtention ¶
func (a *Addon) GetAddonExtention(params *apistructs.AddonHandlerCreateItem) (*apistructs.AddonExtension, *diceyml.Object, error)
GetAddonExtention 获取addon的spec,dice.yml信息
func (*Addon) GetAddonResourceStatus ¶
func (a *Addon) GetAddonResourceStatus(addonIns *dbclient.AddonInstance, addonInsRouting *dbclient.AddonInstanceRouting, addonDice *diceyml.Object, addonSpec *apistructs.AddonExtension) error
GetAddonResourceStatus 从scheduler获取addon发布状态
func (*Addon) GetAddonTenantConfig ¶
func (a *Addon) GetAddonTenantConfig(ins *dbclient.AddonInstanceTenant) (map[string]interface{}, error)
func (*Addon) GetDeployAndRemoveAddons ¶
func (a *Addon) GetDeployAndRemoveAddons(runtimeID uint64) ([]dbclient.AddonPrebuild, []dbclient.AddonInstanceRouting, error)
GetDeployAndRemoveAddons 获取待部署 addons & 待删除 addons
func (*Addon) GetMiddleware ¶
func (a *Addon) GetMiddleware(orgID uint64, userID, instanceID string) (*apistructs.MiddlewareFetchResponseData, error)
GetMiddleware 获取 middleware 详情
func (*Addon) GetMiddlewareAddonClassification ¶
func (a *Addon) GetMiddlewareAddonClassification(orgID uint64, params *apistructs.MiddlewareListRequest) (*map[string]apistructs.MiddlewareResourceItem, error)
GetMiddlewareAddonClassification 获取 middleware addon分类使用情况
func (*Addon) GetMiddlewareAddonDaily ¶
func (a *Addon) GetMiddlewareAddonDaily(orgID uint64, params *apistructs.MiddlewareListRequest) (*map[string]interface{}, error)
GetMiddlewareAddonDaily 获取 middleware 每日资源使用情况
func (*Addon) GetMiddlewareResource ¶
func (a *Addon) GetMiddlewareResource(instanceID string) ([]apistructs.MiddlewareResourceFetchResponseData, error)
GetMiddlewareResource 获取 middleware 资源详情
func (*Addon) GetRuntimeAddonConfig ¶
func (a *Addon) GetRuntimeAddonConfig(runtimeID uint64) (*[]apistructs.AddonConfigRes, error)
GetRuntimeAddonConfig 根据runtimeID获取addon环境变量
func (*Addon) GetTenant ¶
func (a *Addon) GetTenant(userID, orgID, id string, internalcall bool) (*apistructs.AddonFetchResponseData, error)
func (*Addon) GetTotalResourceWithTime ¶
func (a *Addon) GetTotalResourceWithTime(orgID uint64, params *apistructs.MiddlewareListRequest) (*apistructs.MiddlewareResourceItem, error)
GetTotalResourceWithTime 根据截止时间来查询addon资源占用情况
func (*Addon) InfluxDBDeployStatus ¶
func (a *Addon) InfluxDBDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
func (*Addon) InitMySQLAccount ¶
func (a *Addon) InitMySQLAccount(addonIns *dbclient.AddonInstance, addonInsRouting *dbclient.AddonInstanceRouting, operator string) error
func (*Addon) InnerGetMiddleware ¶
func (a *Addon) InnerGetMiddleware(instanceID string) (*apistructs.MiddlewareFetchResponseData, error)
InnerGetMiddleware 内部获取middleware详情
func (*Addon) KafkaDeployStatus ¶
func (a *Addon) KafkaDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, clusterInfo *apistructs.ClusterInfoData) (map[string]string, error)
KafkaDeployStatus kafka状态拉取
func (*Addon) ListAddonInstanceByOrg ¶
func (a *Addon) ListAddonInstanceByOrg(orgid uint64) ([]dbclient.AddonInstance, error)
func (*Addon) ListAvailable ¶
func (a *Addon) ListAvailable(orgID, projectID, workspace string) (*[]apistructs.AddonFetchResponseData, error)
ListAvailableByProject 根据 orgID & projectID 获取可用的 addon 实例列表
func (*Addon) ListByAddonName ¶
func (a *Addon) ListByAddonName(orgID uint64, addonName string) (*[]apistructs.AddonFetchResponseData, error)
ListByAddonName 根据 addonName 获取 指定企业下 addon 列表
func (*Addon) ListByAddonNameAndProject ¶
func (a *Addon) ListByAddonNameAndProject(projectID, workspace, addonName string) ([]apistructs.AddonNameResultItem, error)
ListByAddonNameAndProject 根据addonName查询数据
func (*Addon) ListByCategory ¶
func (a *Addon) ListByCategory(orgID uint64, category string) (*[]apistructs.AddonFetchResponseData, error)
ListByCategory 根据 category 获取 指定企业下 addon 列表
func (*Addon) ListByDiceymlEnvs ¶
func (a *Addon) ListByDiceymlEnvs(diceyml_s string, projectid uint64, workspace string, clustername string) ([]apistructs.AddonFetchResponseData, error)
func (*Addon) ListByOrg ¶
func (a *Addon) ListByOrg(orgID uint64) (*[]apistructs.AddonFetchResponseData, error)
ListByOrg 根据 orgID 获取 addon 列表
func (*Addon) ListByProject ¶
func (a *Addon) ListByProject(orgID, projectID uint64, category string) (*[]apistructs.AddonFetchResponseData, error)
ListByProject 根据 projectID 获取 addon 列表
func (*Addon) ListByRuntime ¶
func (a *Addon) ListByRuntime(orgID, runtimeID uint64, projectID, workspace string) (*[]apistructs.AddonFetchResponseData, error)
ListByRuntime 根据 runtimeID 获取 addon 列表
func (*Addon) ListByWorkbench ¶
func (a *Addon) ListByWorkbench(orgID uint64, userID, category string) (*[]apistructs.AddonFetchResponseData, error)
ListByWorkbench 获取给定企业下用户有权限的 addon 列表
func (*Addon) ListCustomAddon ¶
ListCustomAddon 包装api/extensions接口,返回第三方addon
func (*Addon) ListExtension ¶
ListExtension 包装api/extensions接口
func (*Addon) ListInstanceByRuntime ¶
func (a *Addon) ListInstanceByRuntime(runtimeID uint64) ([]dbclient.AddonInstance, error)
func (*Addon) ListInstanceRoutingByRuntime ¶
func (a *Addon) ListInstanceRoutingByRuntime(runtimeID uint64) (*[]dbclient.AddonInstanceRouting, error)
ListInstanceRoutingByRuntime 根据 runtimeID 获取已创建 addon 实例列表
func (*Addon) ListMicroServiceMenu ¶
func (a *Addon) ListMicroServiceMenu(projectID, env string) ([]*apistructs.MicroServiceMenuResponseData, error)
ListMicroServiceMenu 获取项目下的微服务菜单
func (*Addon) ListMicroServiceProject ¶
func (a *Addon) ListMicroServiceProject(projectIDs []string) ([]*apistructs.MicroServiceProjectResponseData, error)
ListMicroServiceProject 获取使用微服务的项目列表
func (*Addon) ListMiddleware ¶
func (a *Addon) ListMiddleware(orgID uint64, params *apistructs.MiddlewareListRequest) (*apistructs.MiddlewareListResponseData, error)
ListMiddleware 获取 middleware 列表
func (*Addon) ListReferencesByInstanceID ¶
func (a *Addon) ListReferencesByInstanceID(orgID uint64, userID, instanceID string) (*[]apistructs.AddonReferenceInfo, error)
ListReferencesByInstanceID 根据 instanceID 获取引用列表
func (*Addon) ListReferencesByRoutingInstanceID ¶
func (a *Addon) ListReferencesByRoutingInstanceID(orgID uint64, userID, routingInstanceID string, internal ...bool) (*[]apistructs.AddonReferenceInfo, error)
ListReferencesByRoutingInstanceID 根据 routingInstanceID 获取引用列表
func (*Addon) MiddlewareListItem ¶
func (a *Addon) MiddlewareListItem(total int, orgID uint64, params *apistructs.MiddlewareListRequest, addons []dbclient.AddonInstanceInfoExtra, limited_addonids []string) (*apistructs.MiddlewareListResponseData, error)
MiddlewareListItem item抽取代码,通用
func (*Addon) MySQLDeployStatus ¶
func (a *Addon) MySQLDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup, clusterInfo *apistructs.ClusterInfoData) (map[string]string, error)
MySQLDeployStatus myql状态拉取,以及后续环境变量处理
func (*Addon) ParseAddonFullPlan ¶
func (*Addon) ParsePreBuild ¶
func (a *Addon) ParsePreBuild(appID, runtimeID uint64, runtimeName, workspace string, addon apistructs.AddonCreateItem) *dbclient.AddonPrebuild
ParsePreBuild 根据 addon 信息生成 AddonPreBuild 对象
func (*Addon) PrepareCheckProjectLastResource ¶
func (a *Addon) PrepareCheckProjectLastResource(projectID uint64, req *[]apistructs.AddonHandlerCreateItem) error
PrepareCheckProjectLastResource 计算项目预留资源,是否满足发布徐局
func (*Addon) RabbitmqDeployStatus ¶
func (a *Addon) RabbitmqDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
RabbitmqDeployStatus rabbitmq状态拉取
func (*Addon) RedisDeployStatus ¶
func (a *Addon) RedisDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
RedisDeployStatus redis状态拉取
func (*Addon) RocketDeployStatus ¶
func (a *Addon) RocketDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
RocketDeployStatus rocket状态拉取
func (*Addon) RuntimeAddonRemove ¶
RuntimeAddonRemove runtime addon删除
func (*Addon) RuntimeAddonStatus ¶
RuntimeAddonStatus runtime addo status, ensure that an error will only be returned when the status is 0
func (*Addon) Scale ¶
Scale 根据 routingInstanceID 调整 addon 实例副本数实现: 停止: 副本数设置为 0 启动: 副本数调整为期望值 平台级 addon 只支持扩,不支持缩
func (*Addon) StructToMap ¶
StructToMap
func (*Addon) SyncAddonResources ¶
func (a *Addon) SyncAddonResources()
func (*Addon) UpdateAddonStatus ¶
func (a *Addon) UpdateAddonStatus(addonIns *dbclient.AddonInstance, addonStatus apistructs.AddonStatus) error
updateAddonStatus addon发布失败后,更新表状态 TODO 状态更新不应混杂删除逻辑
func (*Addon) UpdateCustom ¶
func (a *Addon) UpdateCustom(userID, addonID string, orgID uint64, configReq *map[string]interface{}) error
UpdateCustom 更新自定义 addon
func (*Addon) ZookeeperDeployStatus ¶
func (a *Addon) ZookeeperDeployStatus(addonIns *dbclient.AddonInstance, serviceGroup *apistructs.ServiceGroup) (map[string]string, error)
ZookeeperDeployStatus zk状态拉取
type MicroServiceProjectData ¶
type MicroServiceProjectData []*apistructs.MicroServiceProjectResponseData
func (MicroServiceProjectData) Len ¶
func (d MicroServiceProjectData) Len() int
func (MicroServiceProjectData) Less ¶
func (d MicroServiceProjectData) Less(i, j int) bool
func (MicroServiceProjectData) Swap ¶
func (d MicroServiceProjectData) Swap(i, j int)
type Option ¶
type Option func(*Addon)
Option addon 实例对象配置选项
func WithClusterInfoImpl ¶
func WithClusterInfoImpl(instanceinfoImpl clusterinfo.ClusterInfo) Option
func WithClusterSvc ¶
func WithClusterSvc(clusterSvc clusterpb.ClusterServiceServer) Option
func WithEnvEncrypt ¶
func WithEnvEncrypt(encrypt *encryption.EnvEncrypt) Option
WithEnvEncrypt 设置 encrypt service
func WithHTTPClient ¶
func WithHTTPClient(hc *httpclient.HTTPClient) Option
WithHTTPClient 配置 http 客户端对象.
func WithInstanceinfoImpl ¶
func WithInstanceinfoImpl(instanceinfoImpl *instanceinfo.InstanceInfoImpl) Option
WithInstanceinfoImpl 配置 instanceinfoImpl
func WithOrg ¶
func WithOrg(org org.ClientInterface) Option
func WithResource ¶
WithResource 配置 Runtime service
func WithServiceGroup ¶
func WithServiceGroup(serviceGroupImpl servicegroup.ServiceGroup) Option
WithServiceGroup 配置 serviceGroupImpl
func WithTenantSvc ¶
func WithTenantSvc(tenantSvc tenantpb.TenantServiceServer) Option
type SourcecovAddonManagement ¶
type SourcecovAddonManagement struct {
// contains filtered or unexported fields
}
func (*SourcecovAddonManagement) BuildSourceCovServiceItem ¶
func (sam *SourcecovAddonManagement) BuildSourceCovServiceItem( params *apistructs.AddonHandlerCreateItem, addonIns *dbclient.AddonInstance, addonSpec *apistructs.AddonExtension, addonDice *diceyml.Object, _ *apistructs.ClusterInfoData) (err error)
func (*SourcecovAddonManagement) DeployStatus ¶
func (sam *SourcecovAddonManagement) DeployStatus(ins *dbclient.AddonInstance, group *apistructs.ServiceGroup) (map[string]string, error)
type SourcecovAddonManagementDeps ¶
type SourcecovAddonManagementDeps interface { GetProjectNamespaceInfo(projectID uint64) (*apistructs.ProjectNameSpaceInfo, error) GetOrg(idOrName interface{}) (*apistructs.OrgDTO, error) GetOAuth2Token(req apistructs.OAuth2TokenGetRequest) (*apistructs.OAuth2Token, error) }
type VersionMap ¶
type VersionMap map[string]apistructs.ExtensionVersion
VersionMap Version of the corresponding addon
func (*VersionMap) GetDefault ¶
func (v *VersionMap) GetDefault() (apistructs.ExtensionVersion, bool)
func (*VersionMap) List ¶
func (v *VersionMap) List() []apistructs.ExtensionVersion