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 }
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 }
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 }
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 }
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 }
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 }
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 }
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 }
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 }
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 }
//未完成 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 }