本文整理汇总了Golang中models/k8sModel.ReplicationControllerModel类的典型用法代码示例。如果您正苦于以下问题:Golang ReplicationControllerModel类的具体用法?Golang ReplicationControllerModel怎么用?Golang ReplicationControllerModel使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ReplicationControllerModel类的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Post
func (this *LineService) Post(data []byte) line {
fmt.Println("[Post] LineService")
var _data_format data_format
json.Unmarshal(data, &_data_format)
service_model := k8sModel.ServiceModel{}
_get_service_data := service_model.GetService(_data_format.Service_name)
replication_controller_model := k8sModel.ReplicationControllerModel{}
_get_replication_controller_data := replication_controller_model.GetReplicationController(_data_format.Cluster_name)
var _line line
if _get_service_data.Spec.Selector == nil {
_line.Status = "fail"
_line.Errmsg = "service no selector"
return _line
}
_get_service_data.Spec.Selector = _get_replication_controller_data.Spec.Selector
service_model.UpdateService(_data_format.Service_name, _get_service_data)
// _put_service_data := service_model.UpdateService(_data_format.Service_name, _get_service_data)
// if _put_service_data.Status_code == "200" {
// Status = "ok"
// } else {
// Status = "fail"
// }
_line.Status = "ok"
return _line
}
示例2: Delete
func (this *LineService) Delete(data []byte) line {
fmt.Println("[Delete] LineService")
var _data_format data_format
json.Unmarshal(data, &_data_format)
service_model := k8sModel.ServiceModel{}
_get_service_data := service_model.GetService(_data_format.Service_name)
replication_controller_model := k8sModel.ReplicationControllerModel{}
_get_replication_controller_data := replication_controller_model.GetReplicationController(_data_format.Cluster_name)
var _line line
if _get_service_data.Spec.Selector == nil {
_line.Status = "fail"
_line.Errmsg = "service no selector"
return _line
}
if _get_service_data.Spec.Selector["name"] != _get_replication_controller_data.Spec.Selector["name"] {
_line.Status = "fail"
_line.Errmsg = "service and cluster not same"
return _line
}
_get_service_data.Spec.Selector["name"] = _get_service_data.Spec.Selector["name"] + "-giga"
service_model.UpdateService(_data_format.Service_name, _get_service_data)
_line.Status = "ok"
return _line
}
示例3: UpdateReplicationController
func (this *ReplicationControllerService) UpdateReplicationController(rc_name string, data []byte) Cluster {
type rc_format struct {
// Cluster_name string `json:"cluster_name"`
Port string `json:"port"`
Container_count string `json:"container_count"`
Cpu string `json:"cpu"`
Image string `json:"image"`
Label map[string]string `json:"label"`
}
var _rc_format rc_format
json.Unmarshal(data, &_rc_format)
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
_k8s_rc := _replication_controllerModel.GetReplicationController(rc_name)
var _cluster Cluster
_k8s_rc.Metadata.Labels = _rc_format.Label
_k8s_rc.Spec.Replicas, _ = strconv.Atoi(_rc_format.Container_count)
// _k8s_rc.Spec.Selector["name"] = _rc_format.Cluster_name
// _k8s_rc.Spec.Template.Metadata.Labels["name"] = _rc_format.Cluster_name
// _k8s_rc.Spec.Template.Spec.Containers[0].Name = _rc_format.Cluster_name
_k8s_rc.Spec.Template.Spec.Containers[0].Image = _rc_format.Image
_k8s_rc.Spec.Template.Spec.Containers[0].Ports[0].ContainerPort, _ = strconv.Atoi(_rc_format.Port)
_replication_controllerModel.UpdateReplicationController(rc_name, _k8s_rc)
_cluster.Status = "ok"
return _cluster
}
示例4: GetReplicationController
func (this *ReplicationControllerService) GetReplicationController(rc_name string) Cluster {
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
data := _replication_controllerModel.GetReplicationController(rc_name)
var _cluster Cluster
_cluster.Data = this.RcByName(data)
_cluster.Status = "ok"
return _cluster
}
示例5: CreateBoth
func (this *ServiceService) CreateBoth(data []byte) Service {
var data_format struct {
Service_name string `json:"service_name"`
Port string `json:"port"`
Container_count string `json:"container_count"`
Cpu string `json:"cpu"`
Image string `json:"image"`
Label map[string]string `json:"label"`
}
json.Unmarshal(data, &data_format)
var _k8s_service k8s_format.Service
_k8s_service.Kind = "Service"
_k8s_service.Metadata.Name = data_format.Service_name
_k8s_service.Metadata.Labels = data_format.Label
_k8s_service.Metadata.Labels["name"] = data_format.Service_name
_k8s_service.Spec.Type = "NodePort"
_k8s_service.Spec.Selector = map[string]string{"name": data_format.Service_name}
var _k8s_service_ports k8s_format.ServicePort
_k8s_service_ports.Port, _ = strconv.Atoi(data_format.Port)
_k8s_service_ports.TargetPort, _ = strconv.Atoi(data_format.Port)
_k8s_service_ports.Protocol = "TCP"
_k8s_service.Spec.Ports = append(_k8s_service.Spec.Ports, _k8s_service_ports)
var k8s_rc k8s_format.ReplicationController
k8s_rc.Kind = "ReplicationController"
k8s_rc.Metadata.Name = data_format.Service_name
k8s_rc.Metadata.Labels = data_format.Label
k8s_rc.Metadata.Labels["name"] = data_format.Service_name
k8s_rc.Spec.Replicas, _ = strconv.Atoi(data_format.Container_count)
k8s_rc.Spec.Selector = map[string]string{"name": data_format.Service_name}
k8s_rc.Spec.Template.Metadata.Labels = map[string]string{"name": data_format.Service_name}
var k8s_rc_container_port k8s_format.ContainerPort
k8s_rc_container_port.ContainerPort, _ = strconv.Atoi(data_format.Port)
var k8s_rc_container k8s_format.Container
k8s_rc_container.Name = data_format.Service_name
k8s_rc_container.Image = data_format.Image
k8s_rc_container.Ports = append(k8s_rc_container.Ports, k8s_rc_container_port)
k8s_rc.Spec.Template.Spec.Containers = append(k8s_rc.Spec.Template.Spec.Containers, k8s_rc_container)
var rc_model k8sModel.ReplicationControllerModel
var service_model k8sModel.ServiceModel
rc_model.CreateReplicationController(k8s_rc)
service_model.CreateService(_k8s_service)
// _rc_service := data_format
var service Service
service.Status = "ok"
// service.Data = ""
return service
}
示例6: GetRelate
func (this *BubbleService) GetRelate() bubble {
fmt.Println("[Get] Relate Service")
var _bubble bubble
var _item item
var service_model k8sModel.ServiceModel
service_data := service_model.GetServiceList()
// cluster_to_service := map[string]string{}
for _, service := range service_data.Items {
_item.Services = append(_item.Services, service.Metadata.Name)
}
var pod_model k8sModel.PodModel
pod_data := pod_model.GetPodList()
// Test(pod_data)
for _, pod := range pod_data.Items {
// Test(pod)
_item.Containers = append(_item.Containers, pod.Metadata.Name)
}
var rc_model k8sModel.ReplicationControllerModel
rc_data := rc_model.GetReplicationControllerList()
for _, rc := range rc_data.Items {
_item.Clusters = append(_item.Clusters, rc.Metadata.Name)
var _relate relate
_relate.Cluster_name = rc.Metadata.Name
for _, service := range service_data.Items {
// _item.Services = append(_item.Services, service.Metadata.Name)
if service.Spec.Selector != nil &&
service.Spec.Selector["name"] != "" &&
rc.Spec.Selector["name"] == service.Spec.Selector["name"] {
_relate.Service = append(_relate.Service, service.Metadata.Name)
}
}
for _, pod := range pod_data.Items {
if pod.Metadata.Labels != nil &&
pod.Metadata.Labels["name"] != "" &&
rc.Spec.Selector["name"] == pod.Metadata.Labels["name"] {
_relate.Container = append(_relate.Container, pod.Metadata.Name)
}
}
_bubble.Data.Relates = append(_bubble.Data.Relates, _relate)
}
_bubble.Data.Items = _item
_bubble.Status = "ok"
return _bubble
}
示例7: GetReplicationControllerCount
func (this *OverviewService) GetReplicationControllerCount() OverviewList {
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
data := _replication_controllerModel.GetReplicationControllerList()
var _overview_list OverviewList
_overview_list.Status = "ok"
var i int = 0
for _, data_items := range data.Items {
metadata_name := data_items.Metadata.Name
if metadata_name == "kube-dns-v3" {
continue
}
i = i + 1
}
_overview_list.Data.ReplicationController_count = i
return _overview_list
}
示例8: DeleteReplicationController
func (this *ReplicationControllerService) DeleteReplicationController(rc_name string) Cluster {
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
_k8s_rc := _replication_controllerModel.GetReplicationController(rc_name)
_k8s_rc.Spec.Replicas = 0
_replication_controllerModel.UpdateReplicationController(rc_name, _k8s_rc)
_replication_controllerModel.DeleteReplicationController(rc_name)
var _cluster Cluster
_cluster.Status = "ok"
return _cluster
}
示例9: CreateReplicationController
func (this *ReplicationControllerService) CreateReplicationController(data []byte) Cluster {
type rc_format struct {
Cluster_name string `json:"cluster_name"`
Port string `json:"port"`
Container_count string `json:"container_count"`
Cpu string `json:"cpu"`
Image string `json:"image"`
Label map[string]string `json:"label"`
}
var _rc_format rc_format
json.Unmarshal(data, &_rc_format)
var k8s_rc k8s_format.ReplicationController
var k8s_rc_container k8s_format.Container
var k8s_rc_container_port k8s_format.ContainerPort
k8s_rc.Kind = "ReplicationController"
k8s_rc.Metadata.Name = _rc_format.Cluster_name
k8s_rc.Metadata.Labels = _rc_format.Label
k8s_rc.Metadata.Labels["name"] = _rc_format.Cluster_name
k8s_rc.Spec.Replicas, _ = strconv.Atoi(_rc_format.Container_count)
k8s_rc.Spec.Selector = map[string]string{"name": _rc_format.Cluster_name}
k8s_rc.Spec.Template.Metadata.Labels = map[string]string{"name": _rc_format.Cluster_name}
k8s_rc_container.Name = _rc_format.Cluster_name
k8s_rc_container.Image = _rc_format.Image
k8s_rc_container_port.ContainerPort, _ = strconv.Atoi(_rc_format.Port)
k8s_rc_container.Ports = append(k8s_rc_container.Ports, k8s_rc_container_port)
k8s_rc.Spec.Template.Spec.Containers = append(k8s_rc.Spec.Template.Spec.Containers, k8s_rc_container)
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
_replication_controllerModel.CreateReplicationController(k8s_rc)
var _cluster Cluster
_cluster.Status = "ok"
return _cluster
}
示例10: GetReplicationControllerList
func (this *ReplicationControllerService) GetReplicationControllerList() ClusterList {
_replication_controllerModel := k8sModel.ReplicationControllerModel{}
data := _replication_controllerModel.GetReplicationControllerList()
_podModel := k8sModel.PodModel{}
_pod_data := _podModel.GetPodList()
var _cluster_list ClusterList
for _, data_items := range data.Items {
metadata_name := data_items.Metadata.Name
if metadata_name == "kube-dns-v3" {
continue
}
var _cluster Cluster_format
_cluster = this.RcByName(data_items)
replicas := strconv.Itoa(data_items.Status.Replicas)
_cluster.Status = replicas + "/" + replicas
var herd_service herd_format.Data
herd_service.Clusters = append(herd_service.Clusters, metadata_name)
var scale_herd herdModel.ScaleHerdModel
scale_herd_data := scale_herd.GetScale(herd_service)
if len(scale_herd_data.Clusters) > 0 {
_cluster.Auto_scale = scale_herd_data.Clusters[0].Enable_auto_scale
}
for _, _pod_data_item := range _pod_data.Items {
_metadata_name_arr := strings.Split(_pod_data_item.Metadata.Name, "-")
_metadata_name := strings.Join(_metadata_name_arr[:len(_metadata_name_arr)-1], "-")
if metadata_name != _metadata_name {
continue
}
var _pod pod
_pod.Container_name = _pod_data_item.Metadata.Name
_pod.Label = _pod_data_item.Metadata.Labels
_pod.Public_ip = _pod_data_item.Status.PodIP
_pod.Host_ip = _pod_data_item.Status.HostIP
_pod.Status = _pod_data_item.Status.Phase
var getHerd herdModel.GetHerdModel
getHerd_data := getHerd.PostData(herd_service)
for _, cluster := range getHerd_data.Clusters {
if len(cluster.Containers) > 0 {
for _, _container := range cluster.Containers {
_cluster.Cpu += _container.Cpu
_cluster.Mem += _container.Mem
if _pod_data_item.Metadata.Name == _container.Container_name {
_pod.Cpu = _container.Cpu
_pod.Mem = _container.Mem
}
}
}
}
var _image_file image_file
_image_file.Name = _pod_data_item.Spec.Containers[0].Name
_image_file.Image = _pod_data_item.Spec.Containers[0].Image
_pod.Image_file = append(_pod.Image_file, _image_file)
_cluster.Pods = append(_cluster.Pods, _pod)
}
_cluster_list.Status = "ok"
_cluster_list.Data = append(_cluster_list.Data, _cluster)
}
return _cluster_list
}
示例11: GetServiceInfo
//未完成
func (this *OverviewService) GetServiceInfo() OverviewList {
service_model := k8sModel.ServiceModel{}
data := service_model.GetServiceList()
rc_model := k8sModel.ReplicationControllerModel{}
rc_data := rc_model.GetReplicationControllerList()
machine_data := this.GetMachineInfo()
var total_mem float64 = 0
for _, _machine_data := range machine_data.Data.Machine_info {
total_mem += _machine_data.Mem
}
var _overview_list OverviewList
_overview_list.Status = "ok"
for _, data_items := range data.Items {
metadata_name := data_items.Metadata.Name
if metadata_name == "kube-dns" || metadata_name == "kubernetes" {
continue
}
var _service_info service_info
_service_info.Name = metadata_name
var herd_service herd_format.Data
herd_service.Services = append(herd_service.Services, metadata_name)
var getHerd herdModel.GetHerdModel
getHerd_data := getHerd.PostData(herd_service)
var cpu int = 0
var mem int = 0
for _, service_herd := range getHerd_data.Services {
if len(service_herd.Clusters) > 0 {
for _, cluster_herd := range service_herd.Clusters {
if len(cluster_herd.Containers) > 0 {
for _, container_herd := range cluster_herd.Containers {
cpu += container_herd.Cpu
mem += container_herd.Mem
}
}
}
}
}
_service_info.Cpu = cpu
_service_info.Mem = (float64(mem) / total_mem) * 100
for _, _rc_data_itme := range rc_data.Items {
if data_items.Spec.Selector != nil {
if data_items.Spec.Selector["name"] == _rc_data_itme.Spec.Selector["name"] {
_service_info.Container_total += _rc_data_itme.Spec.Replicas
_service_info.Container_run += _rc_data_itme.Spec.Replicas
}
}
}
_overview_list.Data.Service_info = append(_overview_list.Data.Service_info, _service_info)
}
return _overview_list
}