host

package
v0.0.0-...-c2c008b Latest Latest
Warning

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

Go to latest
Published: Aug 3, 2022 License: LGPL-2.1 Imports: 19 Imported by: 0

README

主机录入模块

资源的统一搜索表结构

img.png

资源标签管理

应用标签

应用在部署时 需要申请对应的资源, 申请完成后 需要补充标签:

比如 deploy

  • deploy = "app1-v1"
  • deploy = "app2-v1"
监控标签

我们使用2个标签:

  • prometheus.io/node/enabled = "true"

  • prometheus.io/node/endpoint = "9100:/metrics"

  • prometheus.io/node/endpoint = "9200:/metrics"

  • prometheus.io/appv1/enabled = "true"

  • prometheus.io/appv1/endpoint = "9100:/metrics"

  • prometheus.io/appv1/endpoint = "9200:/metrics"

比如搜索 prometheus.io/%/enabled = "true"

[
    {
        "targets": ["10.0.10.2:9100", "10.0.10.3:9100", "10.0.10.4:9100", "10.0.10.5:9100"],
        "labels": {
            "domain": "admin",
            "namespace": "default",
            "env": "prod",
            "accout": "acount11",
            "vendor": "ali_yun",
            "region": "hangzou",
            "instance_id":"ins-xxxxx"
        }
    },
    ...
]

资源生命周期管理

资源申请
资源释放逻辑

create cluster app-v1 devcloud.com/deploy = app-v1 [h1, h2, bucket1, mysql01, dba]

资源状态

  • 3天的 滞留期, 资源无人使用的最大窗口,
  • 超过3天都未使用, 将进入待观察期(4天), 资源会停止服务
  • 当资源超过观察期都还未有人处理,会直接释放, 并记录资源状态 (记录保存期,365天)

Documentation

Index

Constants

View Source
const (
	AppName = "host"
)

Variables

View Source
var (
	DescribeBy_name = map[int32]string{
		0: "HOST_ID",
	}
	DescribeBy_value = map[string]int32{
		"HOST_ID": 0,
	}
)

Enum value maps for DescribeBy.

View Source
var File_apps_host_pb_host_proto protoreflect.FileDescriptor
View Source
var Service_ServiceDesc = grpc.ServiceDesc{
	ServiceName: "course.cmdb.host.Service",
	HandlerType: (*ServiceServer)(nil),
	Methods: []grpc.MethodDesc{
		{
			MethodName: "SyncHost",
			Handler:    _Service_SyncHost_Handler,
		},
		{
			MethodName: "QueryHost",
			Handler:    _Service_QueryHost_Handler,
		},
		{
			MethodName: "DescribeHost",
			Handler:    _Service_DescribeHost_Handler,
		},
		{
			MethodName: "UpdateHost",
			Handler:    _Service_UpdateHost_Handler,
		},
		{
			MethodName: "ReleaseHost",
			Handler:    _Service_ReleaseHost_Handler,
		},
	},
	Streams:  []grpc.StreamDesc{},
	Metadata: "apps/host/pb/host.proto",
}

Service_ServiceDesc is the grpc.ServiceDesc for Service service. It's only intended for direct use with grpc.RegisterService, and not to be introspected or modified (even as a copy)

Functions

func RegisterServiceServer

func RegisterServiceServer(s grpc.ServiceRegistrar, srv ServiceServer)

Types

type Describe

type Describe struct {

	// 核数
	// @gotags: json:"cpu"
	Cpu int64 `protobuf:"varint,1,opt,name=cpu,proto3" json:"cpu"`
	// 内存
	// @gotags: json:"memory"
	Memory int64 `protobuf:"varint,2,opt,name=memory,proto3" json:"memory"`
	// GPU数量
	// @gotags: json:"gpu_amount"
	GpuAmount int32 `protobuf:"varint,3,opt,name=gpu_amount,json=gpuAmount,proto3" json:"gpu_amount"`
	// GPU类型
	// @gotags: json:"gpu_spec"
	GpuSpec string `protobuf:"bytes,4,opt,name=gpu_spec,json=gpuSpec,proto3" json:"gpu_spec"`
	// 操作系统类型,分为Windows和Linux
	// @gotags: json:"os_type"
	OsType string `protobuf:"bytes,5,opt,name=os_type,json=osType,proto3" json:"os_type"`
	// 操作系统名称
	// @gotags: json:"os_name"
	OsName string `protobuf:"bytes,6,opt,name=os_name,json=osName,proto3" json:"os_name"`
	// 序列号
	// @gotags: json:"serial_number"
	SerialNumber string `protobuf:"bytes,7,opt,name=serial_number,json=serialNumber,proto3" json:"serial_number"`
	// 镜像ID
	// @gotags: json:"image_id"
	ImageId string `protobuf:"bytes,8,opt,name=image_id,json=imageId,proto3" json:"image_id"`
	// 公网出带宽最大值,单位为 Mbps
	// @gotags: json:"internet_max_bandwidth_out"
	InternetMaxBandwidthOut int64 `protobuf:"varint,9,opt,name=internet_max_bandwidth_out,json=internetMaxBandwidthOut,proto3" json:"internet_max_bandwidth_out"`
	// 公网入带宽最大值,单位为 Mbps
	// @gotags: json:"internet_max_bandwidth_in"
	InternetMaxBandwidthIn int64 `protobuf:"varint,10,opt,name=internet_max_bandwidth_in,json=internetMaxBandwidthIn,proto3" json:"internet_max_bandwidth_in"`
	// 秘钥对名称
	// @gotags: json:"key_pair_name"
	KeyPairName []string `protobuf:"bytes,11,rep,name=key_pair_name,json=keyPairName,proto3" json:"key_pair_name"`
	// 安全组  采用逗号分隔
	// @gotags: json:"security_groups"
	SecurityGroups []string `protobuf:"bytes,12,rep,name=security_groups,json=securityGroups,proto3" json:"security_groups"`
	// 额外的无法通用的一些属性, 比如只有腾讯云独有的一些属性
	// @gotags: json:"extra"
	Extra map[string]string `` /* 142-byte string literal not displayed */
	// contains filtered or unexported fields
}

func (*Describe) Descriptor deprecated

func (*Describe) Descriptor() ([]byte, []int)

Deprecated: Use Describe.ProtoReflect.Descriptor instead.

func (*Describe) GetCpu

func (x *Describe) GetCpu() int64

func (*Describe) GetExtra

func (x *Describe) GetExtra() map[string]string

func (*Describe) GetGpuAmount

func (x *Describe) GetGpuAmount() int32

func (*Describe) GetGpuSpec

func (x *Describe) GetGpuSpec() string

func (*Describe) GetImageId

func (x *Describe) GetImageId() string

func (*Describe) GetInternetMaxBandwidthIn

func (x *Describe) GetInternetMaxBandwidthIn() int64

func (*Describe) GetInternetMaxBandwidthOut

func (x *Describe) GetInternetMaxBandwidthOut() int64

func (*Describe) GetKeyPairName

func (x *Describe) GetKeyPairName() []string

func (*Describe) GetMemory

func (x *Describe) GetMemory() int64

func (*Describe) GetOsName

func (x *Describe) GetOsName() string

func (*Describe) GetOsType

func (x *Describe) GetOsType() string

func (*Describe) GetSecurityGroups

func (x *Describe) GetSecurityGroups() []string

func (*Describe) GetSerialNumber

func (x *Describe) GetSerialNumber() string

func (*Describe) KeyPairNameToString

func (d *Describe) KeyPairNameToString() string

入库就用,逗号链接

func (*Describe) LoadKeyPairNameString

func (d *Describe) LoadKeyPairNameString(s string)

加载就用逗号分开

func (*Describe) LoadSecurityGroupsString

func (d *Describe) LoadSecurityGroupsString(s string)

func (*Describe) ProtoMessage

func (*Describe) ProtoMessage()

func (*Describe) ProtoReflect

func (x *Describe) ProtoReflect() protoreflect.Message

func (*Describe) Reset

func (x *Describe) Reset()

func (*Describe) SecurityGroupsToString

func (d *Describe) SecurityGroupsToString() string

func (*Describe) String

func (x *Describe) String() string

type DescribeBy

type DescribeBy int32
const (
	DescribeBy_HOST_ID DescribeBy = 0
)

func ParseDescribeByFromString

func ParseDescribeByFromString(str string) (DescribeBy, error)

ParseDescribeByFromString Parse DescribeBy from string

func (DescribeBy) Descriptor

func (DescribeBy) Descriptor() protoreflect.EnumDescriptor

func (DescribeBy) Enum

func (x DescribeBy) Enum() *DescribeBy

func (DescribeBy) EnumDescriptor deprecated

func (DescribeBy) EnumDescriptor() ([]byte, []int)

Deprecated: Use DescribeBy.Descriptor instead.

func (DescribeBy) Equal

func (t DescribeBy) Equal(target DescribeBy) bool

Equal type compare

func (DescribeBy) IsIn

func (t DescribeBy) IsIn(targets ...DescribeBy) bool

IsIn todo

func (DescribeBy) MarshalJSON

func (t DescribeBy) MarshalJSON() ([]byte, error)

MarshalJSON todo

func (DescribeBy) Number

func (x DescribeBy) Number() protoreflect.EnumNumber

func (DescribeBy) String

func (x DescribeBy) String() string

func (DescribeBy) Type

func (*DescribeBy) UnmarshalJSON

func (t *DescribeBy) UnmarshalJSON(b []byte) error

UnmarshalJSON todo

type DescribeHostRequest

type DescribeHostRequest struct {

	// @gotags: json:"describe_by"
	DescribeBy DescribeBy `protobuf:"varint,1,opt,name=describe_by,json=describeBy,proto3,enum=course.cmdb.host.DescribeBy" json:"describe_by"`
	// @gotags: json:"value" validate:"required"
	Value string `protobuf:"bytes,2,opt,name=value,proto3" json:"value" validate:"required"`
	// contains filtered or unexported fields
}

func NewDescribeHostRequestWithID

func NewDescribeHostRequestWithID(id string) *DescribeHostRequest

func (*DescribeHostRequest) Descriptor deprecated

func (*DescribeHostRequest) Descriptor() ([]byte, []int)

Deprecated: Use DescribeHostRequest.ProtoReflect.Descriptor instead.

func (*DescribeHostRequest) GetDescribeBy

func (x *DescribeHostRequest) GetDescribeBy() DescribeBy

func (*DescribeHostRequest) GetValue

func (x *DescribeHostRequest) GetValue() string

func (*DescribeHostRequest) ProtoMessage

func (*DescribeHostRequest) ProtoMessage()

func (*DescribeHostRequest) ProtoReflect

func (x *DescribeHostRequest) ProtoReflect() protoreflect.Message

func (*DescribeHostRequest) Reset

func (x *DescribeHostRequest) Reset()

func (*DescribeHostRequest) String

func (x *DescribeHostRequest) String() string

func (*DescribeHostRequest) Where

func (req *DescribeHostRequest) Where() (string, interface{})

type Host

type Host struct {

	// 固有基础属性,保存在resource表里面
	// @gotags: json:"base"
	Base *resource.Base `protobuf:"bytes,1,opt,name=base,proto3" json:"base"`
	// 非固有的基础属性,保存在resource表里面
	// @gotags: json:"information"
	Information *resource.Information `protobuf:"bytes,2,opt,name=information,proto3" json:"information"`
	// 主机资源 固有的属性,host独有的信息保存在resource——host表里
	// @gotags: json:"describe"
	Describe *Describe `protobuf:"bytes,3,opt,name=describe,proto3" json:"describe"`
	// contains filtered or unexported fields
}

func NewDefaultHost

func NewDefaultHost() *Host

func (*Host) Descriptor deprecated

func (*Host) Descriptor() ([]byte, []int)

Deprecated: Use Host.ProtoReflect.Descriptor instead.

func (*Host) GenHash

func (h *Host) GenHash() error

把对象进行hash实现方法

func (*Host) GetBase

func (x *Host) GetBase() *resource.Base

func (*Host) GetDescribe

func (x *Host) GetDescribe() *Describe

func (*Host) GetInformation

func (x *Host) GetInformation() *resource.Information

func (*Host) ProtoMessage

func (*Host) ProtoMessage()

func (*Host) ProtoReflect

func (x *Host) ProtoReflect() protoreflect.Message

func (*Host) Put

func (h *Host) Put(req *UpdateHostData)

func (*Host) Reset

func (x *Host) Reset()

func (*Host) ShortDesc

func (h *Host) ShortDesc() string

func (*Host) String

func (x *Host) String() string

type HostSet

type HostSet struct {

	// @gotags: json:"total"
	Total int64 `protobuf:"varint,1,opt,name=total,proto3" json:"total"`
	// @gotags: json:"items"
	Items []*Host `protobuf:"bytes,2,rep,name=items,proto3" json:"items"`
	// contains filtered or unexported fields
}

func NewHostSet

func NewHostSet() *HostSet

func (*HostSet) Add

func (s *HostSet) Add(item *Host)

func (*HostSet) Clone

func (s *HostSet) Clone() *HostSet

func (*HostSet) Descriptor deprecated

func (*HostSet) Descriptor() ([]byte, []int)

Deprecated: Use HostSet.ProtoReflect.Descriptor instead.

func (*HostSet) GetItems

func (x *HostSet) GetItems() []*Host

func (*HostSet) GetTotal

func (x *HostSet) GetTotal() int64

func (*HostSet) Length

func (s *HostSet) Length() int64

func (*HostSet) ProtoMessage

func (*HostSet) ProtoMessage()

func (*HostSet) ProtoReflect

func (x *HostSet) ProtoReflect() protoreflect.Message

func (*HostSet) Reset

func (x *HostSet) Reset()

func (*HostSet) ResourceIds

func (s *HostSet) ResourceIds() (ids []string)

func (*HostSet) String

func (x *HostSet) String() string

func (*HostSet) UpdateTag

func (s *HostSet) UpdateTag(tags []*resource.Tag)

type Pagger

type Pagger interface {
	Next() bool
	SetPageSize(ps int64)
	Scan(context.Context, *HostSet) error
}

分页器

for p.Next() {
	if err := p.Scan(set); err != nil {
		...
	}
}

type QueryHostRequest

type QueryHostRequest struct {

	// 分页参数
	// @gotags: json:"page"
	Page *request.PageRequest `protobuf:"bytes,1,opt,name=page,proto3" json:"page"`
	// 关键字参数
	// @gotags: json:"keywords"
	Keywords string `protobuf:"bytes,2,opt,name=keywords,proto3" json:"keywords"`
	// contains filtered or unexported fields
}

func NewQueryHostRequestFromHTTP

func NewQueryHostRequestFromHTTP(r *http.Request) *QueryHostRequest

func (*QueryHostRequest) Descriptor deprecated

func (*QueryHostRequest) Descriptor() ([]byte, []int)

Deprecated: Use QueryHostRequest.ProtoReflect.Descriptor instead.

func (*QueryHostRequest) GetKeywords

func (x *QueryHostRequest) GetKeywords() string

func (*QueryHostRequest) GetPage

func (x *QueryHostRequest) GetPage() *request.PageRequest

func (*QueryHostRequest) ProtoMessage

func (*QueryHostRequest) ProtoMessage()

func (*QueryHostRequest) ProtoReflect

func (x *QueryHostRequest) ProtoReflect() protoreflect.Message

func (*QueryHostRequest) Reset

func (x *QueryHostRequest) Reset()

func (*QueryHostRequest) String

func (x *QueryHostRequest) String() string

type ReleaseHostRequest

type ReleaseHostRequest struct {

	// 主机Id
	// @gotags: json:"id" validate:"required"
	Id string `protobuf:"bytes,1,opt,name=id,proto3" json:"id" validate:"required"`
	// contains filtered or unexported fields
}

释放计划,资源释放

func NewDeleteHostRequestWithID

func NewDeleteHostRequestWithID(id string) *ReleaseHostRequest

func (*ReleaseHostRequest) Descriptor deprecated

func (*ReleaseHostRequest) Descriptor() ([]byte, []int)

Deprecated: Use ReleaseHostRequest.ProtoReflect.Descriptor instead.

func (*ReleaseHostRequest) GetId

func (x *ReleaseHostRequest) GetId() string

func (*ReleaseHostRequest) ProtoMessage

func (*ReleaseHostRequest) ProtoMessage()

func (*ReleaseHostRequest) ProtoReflect

func (x *ReleaseHostRequest) ProtoReflect() protoreflect.Message

func (*ReleaseHostRequest) Reset

func (x *ReleaseHostRequest) Reset()

func (*ReleaseHostRequest) String

func (x *ReleaseHostRequest) String() string

type ServiceClient

type ServiceClient interface {
	// 同步云商的主机资源
	SyncHost(ctx context.Context, in *Host, opts ...grpc.CallOption) (*Host, error)
	// 查询本地同步后的主机资源列表
	QueryHost(ctx context.Context, in *QueryHostRequest, opts ...grpc.CallOption) (*HostSet, error)
	// 查询主机详情信息,查询单个
	DescribeHost(ctx context.Context, in *DescribeHostRequest, opts ...grpc.CallOption) (*Host, error)
	// 更新主机信息, 同步更新云商资源信息
	UpdateHost(ctx context.Context, in *UpdateHostRequest, opts ...grpc.CallOption) (*Host, error)
	// 释放主机, 按计划释放后, 信息会保留一段时间
	ReleaseHost(ctx context.Context, in *ReleaseHostRequest, opts ...grpc.CallOption) (*Host, error)
}

ServiceClient is the client API for Service service.

For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.

func NewServiceClient

func NewServiceClient(cc grpc.ClientConnInterface) ServiceClient

type ServiceServer

type ServiceServer interface {
	// 同步云商的主机资源
	SyncHost(context.Context, *Host) (*Host, error)
	// 查询本地同步后的主机资源列表
	QueryHost(context.Context, *QueryHostRequest) (*HostSet, error)
	// 查询主机详情信息,查询单个
	DescribeHost(context.Context, *DescribeHostRequest) (*Host, error)
	// 更新主机信息, 同步更新云商资源信息
	UpdateHost(context.Context, *UpdateHostRequest) (*Host, error)
	// 释放主机, 按计划释放后, 信息会保留一段时间
	ReleaseHost(context.Context, *ReleaseHostRequest) (*Host, error)
	// contains filtered or unexported methods
}

ServiceServer is the server API for Service service. All implementations must embed UnimplementedServiceServer for forward compatibility

type UnimplementedServiceServer

type UnimplementedServiceServer struct {
}

UnimplementedServiceServer must be embedded to have forward compatible implementations.

func (UnimplementedServiceServer) DescribeHost

func (UnimplementedServiceServer) QueryHost

func (UnimplementedServiceServer) ReleaseHost

func (UnimplementedServiceServer) SyncHost

func (UnimplementedServiceServer) UpdateHost

type UnsafeServiceServer

type UnsafeServiceServer interface {
	// contains filtered or unexported methods
}

UnsafeServiceServer may be embedded to opt out of forward compatibility for this service. Use of this interface is not recommended, as added methods to ServiceServer will result in compilation errors.

type UpdateHostData

type UpdateHostData struct {

	// @gotags: json:"information"
	Information *resource.Information `protobuf:"bytes,1,opt,name=information,proto3" json:"information"`
	// @gotags: json:"describe"
	Describe *Describe `protobuf:"bytes,2,opt,name=describe,proto3" json:"describe"`
	// contains filtered or unexported fields
}

一次updat需要update 两张表

func NewUpdateHostDataByIns

func NewUpdateHostDataByIns(ins *Host) *UpdateHostData

func (*UpdateHostData) Descriptor deprecated

func (*UpdateHostData) Descriptor() ([]byte, []int)

Deprecated: Use UpdateHostData.ProtoReflect.Descriptor instead.

func (*UpdateHostData) GetDescribe

func (x *UpdateHostData) GetDescribe() *Describe

func (*UpdateHostData) GetInformation

func (x *UpdateHostData) GetInformation() *resource.Information

func (*UpdateHostData) ProtoMessage

func (*UpdateHostData) ProtoMessage()

func (*UpdateHostData) ProtoReflect

func (x *UpdateHostData) ProtoReflect() protoreflect.Message

func (*UpdateHostData) Reset

func (x *UpdateHostData) Reset()

func (*UpdateHostData) String

func (x *UpdateHostData) String() string

type UpdateHostRequest

type UpdateHostRequest struct {

	// @gotags: json:"id" validate:"required"
	Id string `protobuf:"bytes,1,opt,name=id,proto3" json:"id" validate:"required"`
	// 更新模式
	// @gotags: json:"update_mode"
	UpdateMode request1.UpdateMode `protobuf:"varint,2,opt,name=update_mode,json=updateMode,proto3,enum=infraboard.mcube.request.UpdateMode" json:"update_mode"`
	// @gotags: json:"data" validate:"required"
	UpdateHostData *UpdateHostData `protobuf:"bytes,3,opt,name=update_host_data,json=updateHostData,proto3" json:"data" validate:"required"`
	// contains filtered or unexported fields
}

func NewUpdateHostRequest

func NewUpdateHostRequest(id string) *UpdateHostRequest

func (*UpdateHostRequest) Descriptor deprecated

func (*UpdateHostRequest) Descriptor() ([]byte, []int)

Deprecated: Use UpdateHostRequest.ProtoReflect.Descriptor instead.

func (*UpdateHostRequest) GetId

func (x *UpdateHostRequest) GetId() string

func (*UpdateHostRequest) GetUpdateHostData

func (x *UpdateHostRequest) GetUpdateHostData() *UpdateHostData

func (*UpdateHostRequest) GetUpdateMode

func (x *UpdateHostRequest) GetUpdateMode() request1.UpdateMode

func (*UpdateHostRequest) ProtoMessage

func (*UpdateHostRequest) ProtoMessage()

func (*UpdateHostRequest) ProtoReflect

func (x *UpdateHostRequest) ProtoReflect() protoreflect.Message

func (*UpdateHostRequest) Reset

func (x *UpdateHostRequest) Reset()

func (*UpdateHostRequest) String

func (x *UpdateHostRequest) String() string

func (*UpdateHostRequest) Validate

func (req *UpdateHostRequest) Validate() error

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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