refactor error reporting

This commit is contained in:
Sergey Dudoladov 2018-09-25 16:06:52 +02:00
parent 85e8dea086
commit 3fb58e9077
1 changed files with 25 additions and 22 deletions

View File

@ -76,8 +76,9 @@ func (c *Controller) nodeIsReady(node *v1.Node) bool {
} }
func (c *Controller) moveMasterPodsOffNode(node *v1.Node) { func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
nodeName := util.NameFromMeta(node.ObjectMeta) nodeName := util.NameFromMeta(node.ObjectMeta)
c.logger.Infof("moving pods: node %q became unschedulable and does not have a ready label: %q", c.logger.Infof("moving pods: node %q became unschedulable and does not have a ready label %q",
nodeName, c.opConfig.NodeReadinessLabel) nodeName, c.opConfig.NodeReadinessLabel)
opts := metav1.ListOptions{ opts := metav1.ListOptions{
@ -85,7 +86,7 @@ func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
} }
podList, err := c.KubeClient.Pods(c.opConfig.WatchedNamespace).List(opts) podList, err := c.KubeClient.Pods(c.opConfig.WatchedNamespace).List(opts)
if err != nil { if err != nil {
c.logger.Errorf("could not fetch list of the pods: %v", err) c.logger.Errorf("could not fetch the list of Spilo pods: %v", err)
return return
} }
@ -96,21 +97,25 @@ func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
} }
} }
clusters := make(map[*cluster.Cluster]bool) movedMasterPods := 0
movableMasterPods := make(map[*v1.Pod]*cluster.Cluster) movableMasterPods := make(map[*v1.Pod]*cluster.Cluster)
movedPods := 0 unmovablePods := make(map[spec.NamespacedName]string)
unmovableMasterPods := make(map[spec.NamespacedName]string) // podName -> reason
clusters := make(map[*cluster.Cluster]bool)
for _, pod := range nodePods { for _, pod := range nodePods {
podName := util.NameFromMeta(pod.ObjectMeta) podName := util.NameFromMeta(pod.ObjectMeta)
role, ok := pod.Labels[c.opConfig.PodRoleLabel] role, ok := pod.Labels[c.opConfig.PodRoleLabel]
if !ok { if !ok {
unmovableMasterPods[podName] = fmt.Sprintf("could not move pod %q from node %q: pod has no role label %q", podName, nodeName, c.opConfig.PodRoleLabel) // pods with an unknown role cannot be safely moved to another node
unmovablePods[podName] = fmt.Sprintf("could not move pod %q from node %q: pod has no role label %q", podName, nodeName, c.opConfig.PodRoleLabel)
continue continue
} }
if cluster.PostgresRole(role) != cluster.Master { // deployments can transparently re-create replicas so we do not move away such pods
if cluster.PostgresRole(role) == cluster.Replica {
continue continue
} }
@ -120,7 +125,7 @@ func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
cl, ok := c.clusters[clusterName] cl, ok := c.clusters[clusterName]
c.clustersMu.RUnlock() c.clustersMu.RUnlock()
if !ok { if !ok {
unmovableMasterPods[podName] = fmt.Sprintf("could not move pod %q from node %q: pod belongs to the unknown Postgres cluster %q", podName, nodeName, clusterName) unmovablePods[podName] = fmt.Sprintf("could not move master pod %q from node %q: pod belongs to an unknown Postgres cluster %q", podName, nodeName, clusterName)
continue continue
} }
@ -136,12 +141,12 @@ func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
} }
for pod, cl := range movableMasterPods { for pod, cl := range movableMasterPods {
podName := util.NameFromMeta(pod.ObjectMeta)
if err := cl.MigrateMasterPod(podName); err != nil { podName := util.NameFromMeta(pod.ObjectMeta)
unmovableMasterPods[podName] = fmt.Sprintf("could not move master pod %q from node %q: %v", podName, nodeName, err) if err := cl.MigrateMasterPod(podName); err == nil {
movedMasterPods++
} else { } else {
movedPods++ unmovablePods[podName] = fmt.Sprintf("could not move master pod %q from node %q: %v", podName, nodeName, err)
} }
} }
@ -149,18 +154,16 @@ func (c *Controller) moveMasterPodsOffNode(node *v1.Node) {
cl.Unlock() cl.Unlock()
} }
totalPods := len(nodePods) if leftPods := len(unmovablePods); leftPods > 0 {
c.logger.Warnf("could not move %d master or unknown role pods from the node %q, you may have to delete them manually",
c.logger.Infof("%d out of %d master pods have been moved out from the node %q", leftPods, nodeName)
movedPods, totalPods, nodeName) for _, reason := range unmovablePods {
if leftPods := totalPods - movedPods; leftPods > 0 {
c.logger.Warnf("could not move %d master pods from the node %q, you may have to delete them manually:",
leftPods, totalPods, nodeName)
for _, reason := range unmovableMasterPods {
c.logger.Warning(reason) c.logger.Warning(reason)
} }
} }
c.logger.Infof("%d master pods have been moved out from the node %q", movedMasterPods, nodeName)
} }
func (c *Controller) nodeDelete(obj interface{}) { func (c *Controller) nodeDelete(obj interface{}) {