diff --git a/go/http/api.go b/go/http/api.go index d4c43d0e0..cb74bf897 100644 --- a/go/http/api.go +++ b/go/http/api.go @@ -723,7 +723,7 @@ func (this *HttpAPI) LocateErrantGTID(params martini.Params, r render.Render, re Respond(r, &APIResponse{Code: ERROR, Message: err.Error()}) return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("located errant GTID"), Details: errantBinlogs}) + Respond(r, &APIResponse{Code: OK, Message: "located errant GTID", Details: errantBinlogs}) } // ErrantGTIDResetMaster removes errant transactions on a server by way of RESET MASTER @@ -2805,7 +2805,7 @@ func (this *HttpAPI) Health(params martini.Params, r render.Render, req *http.Re return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Application node is healthy"), Details: health}) + Respond(r, &APIResponse{Code: OK, Message: "Application node is healthy", Details: health}) } @@ -2839,7 +2839,7 @@ func (this *HttpAPI) StatusCheck(params martini.Params, r render.Render, req *ht r.JSON(500, &APIResponse{Code: ERROR, Message: fmt.Sprintf("Application node is unhealthy %+v", err), Details: health}) return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Application node is healthy"), Details: health}) + Respond(r, &APIResponse{Code: OK, Message: "Application node is healthy", Details: health}) } // GrabElection forcibly grabs leadership. Use with care!! @@ -2854,7 +2854,7 @@ func (this *HttpAPI) GrabElection(params martini.Params, r render.Render, req *h return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Node elected as leader")}) + Respond(r, &APIResponse{Code: OK, Message: "Node elected as leader"}) } // Reelect causes re-elections for an active node @@ -2869,7 +2869,7 @@ func (this *HttpAPI) Reelect(params martini.Params, r render.Render, req *http.R return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Set re-elections")}) + Respond(r, &APIResponse{Code: OK, Message: "Set re-elections"}) } // RaftAddPeer adds a new node to the raft cluster @@ -2923,7 +2923,7 @@ func (this *HttpAPI) RaftYield(params martini.Params, r render.Render, req *http return } orcraft.PublishYield(params["node"]) - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Asynchronously yielded")}) + Respond(r, &APIResponse{Code: OK, Message: "Asynchronously yielded"}) } // RaftYieldHint yields to a host whose name contains given hint (e.g. DC) @@ -3064,7 +3064,7 @@ func (this *HttpAPI) ReloadConfiguration(params martini.Params, r render.Render, config.Reload(extraConfigFile) inst.AuditOperation("reload-configuration", nil, "Triggered via API") - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Config reloaded"), Details: extraConfigFile}) + Respond(r, &APIResponse{Code: OK, Message: "Config reloaded", Details: extraConfigFile}) } // ReplicationAnalysis retuens list of issues @@ -3085,7 +3085,7 @@ func (this *HttpAPI) replicationAnalysis(clusterName string, instanceKey *inst.I analysis = filtered } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Analysis"), Details: analysis}) + Respond(r, &APIResponse{Code: OK, Message: "Analysis", Details: analysis}) } // ReplicationAnalysis retuens list of issues @@ -3296,7 +3296,7 @@ func (this *HttpAPI) AutomatedRecoveryFilters(params martini.Params, r render.Re automatedRecoveryMap["RecoverIntermediateMasterClusterFilters"] = config.Config.RecoverIntermediateMasterClusterFilters automatedRecoveryMap["RecoveryIgnoreHostnameFilters"] = config.Config.RecoveryIgnoreHostnameFilters - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Automated recovery configuration details"), Details: automatedRecoveryMap}) + Respond(r, &APIResponse{Code: OK, Message: "Automated recovery configuration details", Details: automatedRecoveryMap}) } // AuditFailureDetection provides list of topology_failure_detection entries @@ -3439,7 +3439,7 @@ func (this *HttpAPI) AcknowledgeClusterRecoveries(params martini.Params, r rende comment := strings.TrimSpace(req.URL.Query().Get("comment")) if comment == "" { - Respond(r, &APIResponse{Code: ERROR, Message: fmt.Sprintf("No acknowledge comment given")}) + Respond(r, &APIResponse{Code: ERROR, Message: "No acknowledge comment given"}) return } userId := getUserId(req, user) @@ -3458,7 +3458,7 @@ func (this *HttpAPI) AcknowledgeClusterRecoveries(params martini.Params, r rende return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Acknowledged cluster recoveries"), Details: clusterName}) + Respond(r, &APIResponse{Code: OK, Message: "Acknowledged cluster recoveries", Details: clusterName}) } // ClusterInfo provides details of a given cluster @@ -3476,7 +3476,7 @@ func (this *HttpAPI) AcknowledgeInstanceRecoveries(params martini.Params, r rend comment := strings.TrimSpace(req.URL.Query().Get("comment")) if comment == "" { - Respond(r, &APIResponse{Code: ERROR, Message: fmt.Sprintf("No acknowledge comment given")}) + Respond(r, &APIResponse{Code: ERROR, Message: "No acknowledge comment given"}) return } userId := getUserId(req, user) @@ -3495,7 +3495,7 @@ func (this *HttpAPI) AcknowledgeInstanceRecoveries(params martini.Params, r rend return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Acknowledged instance recoveries"), Details: instanceKey}) + Respond(r, &APIResponse{Code: OK, Message: "Acknowledged instance recoveries", Details: instanceKey}) } // ClusterInfo provides details of a given cluster @@ -3522,7 +3522,7 @@ func (this *HttpAPI) AcknowledgeRecovery(params martini.Params, r render.Render, } comment := strings.TrimSpace(req.URL.Query().Get("comment")) if comment == "" { - Respond(r, &APIResponse{Code: ERROR, Message: fmt.Sprintf("No acknowledge comment given")}) + Respond(r, &APIResponse{Code: ERROR, Message: "No acknowledge comment given"}) return } userId := getUserId(req, user) @@ -3547,7 +3547,7 @@ func (this *HttpAPI) AcknowledgeRecovery(params martini.Params, r render.Render, return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Acknowledged recovery"), Details: idParam}) + Respond(r, &APIResponse{Code: OK, Message: "Acknowledged recovery", Details: idParam}) } // ClusterInfo provides details of a given cluster @@ -3559,7 +3559,7 @@ func (this *HttpAPI) AcknowledgeAllRecoveries(params martini.Params, r render.Re comment := strings.TrimSpace(req.URL.Query().Get("comment")) if comment == "" { - Respond(r, &APIResponse{Code: ERROR, Message: fmt.Sprintf("No acknowledge comment given")}) + Respond(r, &APIResponse{Code: ERROR, Message: "No acknowledge comment given"}) return } userId := getUserId(req, user) @@ -3579,7 +3579,7 @@ func (this *HttpAPI) AcknowledgeAllRecoveries(params martini.Params, r render.Re return } - Respond(r, &APIResponse{Code: OK, Message: fmt.Sprintf("Acknowledged all recoveries"), Details: comment}) + Respond(r, &APIResponse{Code: OK, Message: "Acknowledged all recoveries", Details: comment}) } // BlockedRecoveries reads list of currently blocked recoveries, optionally filtered by cluster name diff --git a/go/inst/candidate_database_instance_dao.go b/go/inst/candidate_database_instance_dao.go index d10178fb9..2335cfc2d 100644 --- a/go/inst/candidate_database_instance_dao.go +++ b/go/inst/candidate_database_instance_dao.go @@ -17,8 +17,6 @@ package inst import ( - "fmt" - "github.com/openark/golib/log" "github.com/openark/golib/sqlutils" @@ -33,7 +31,7 @@ func RegisterCandidateInstance(candidate *CandidateDatabaseInstance) error { } args := sqlutils.Args(candidate.Hostname, candidate.Port, string(candidate.PromotionRule), candidate.LastSuggestedString) - query := fmt.Sprintf(` + query := ` insert into candidate_database_instance ( hostname, port, @@ -44,7 +42,7 @@ func RegisterCandidateInstance(candidate *CandidateDatabaseInstance) error { ) on duplicate key update last_suggested=values(last_suggested), promotion_rule=values(promotion_rule) - `) + ` writeFunc := func() error { _, err := db.ExecOrchestrator(query, args...) AuditOperation("register-candidate", candidate.Key(), string(candidate.PromotionRule)) diff --git a/go/logic/topology_recovery.go b/go/logic/topology_recovery.go index 855a79387..9050393c4 100644 --- a/go/logic/topology_recovery.go +++ b/go/logic/topology_recovery.go @@ -553,17 +553,17 @@ func recoverDeadMaster(topologyRecovery *TopologyRecovery, candidateInstanceKey switch topologyRecovery.RecoveryType { case MasterRecoveryGTID: { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("RecoverDeadMaster: regrouping replicas via GTID")) + AuditTopologyRecovery(topologyRecovery, "RecoverDeadMaster: regrouping replicas via GTID") lostReplicas, _, cannotReplicateReplicas, promotedReplica, err = inst.RegroupReplicasGTID(failedInstanceKey, true, false, nil, &topologyRecovery.PostponedFunctionsContainer, promotedReplicaIsIdeal) } case MasterRecoveryPseudoGTID: { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("RecoverDeadMaster: regrouping replicas via Pseudo-GTID")) + AuditTopologyRecovery(topologyRecovery, "RecoverDeadMaster: regrouping replicas via Pseudo-GTID") lostReplicas, _, _, cannotReplicateReplicas, promotedReplica, err = inst.RegroupReplicasPseudoGTIDIncludingSubReplicasOfBinlogServers(failedInstanceKey, true, nil, &topologyRecovery.PostponedFunctionsContainer, promotedReplicaIsIdeal) } case MasterRecoveryBinlogServer: { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("RecoverDeadMaster: recovering via binlog servers")) + AuditTopologyRecovery(topologyRecovery, "RecoverDeadMaster: recovering via binlog servers") promotedReplica, err = recoverDeadMasterInBinlogServerTopology(topologyRecovery) } } @@ -644,9 +644,9 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de // Maybe we promoted a "prefer_not" // Maybe we promoted a server in a different DC than the master // There's many options. We may wish to replace the server we promoted with a better one. - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("checking if should replace promoted replica with a better candidate")) + AuditTopologyRecovery(topologyRecovery, "checking if should replace promoted replica with a better candidate") if candidateInstanceKey == nil { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ checking if promoted replica is the ideal candidate")) + AuditTopologyRecovery(topologyRecovery, "+ checking if promoted replica is the ideal candidate") if deadInstance != nil { for _, candidateReplica := range candidateReplicas { if promotedReplica.Key.Equals(&candidateReplica.Key) && @@ -662,7 +662,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de // We didn't pick the ideal candidate; let's see if we can replace with a candidate from same DC and ENV if candidateInstanceKey == nil { // Try a candidate replica that is in same DC & env as the dead instance - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for an ideal candidate")) + AuditTopologyRecovery(topologyRecovery, "+ searching for an ideal candidate") if deadInstance != nil { for _, candidateReplica := range candidateReplicas { if canTakeOverPromotedServerAsMaster(candidateReplica, promotedReplica) && @@ -677,7 +677,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de } if candidateInstanceKey == nil { // We cannot find a candidate in same DC and ENV as dead master - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ checking if promoted replica is an OK candidate")) + AuditTopologyRecovery(topologyRecovery, "+ checking if promoted replica is an OK candidate") for _, candidateReplica := range candidateReplicas { if promotedReplica.Key.Equals(&candidateReplica.Key) { // Seems like we promoted a candidate replica (though not in same DC and ENV as dead master) @@ -694,7 +694,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de // Still nothing? if candidateInstanceKey == nil { // Try a candidate replica that is in same DC & env as the promoted replica (our promoted replica is not an "is_candidate") - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for a candidate")) + AuditTopologyRecovery(topologyRecovery, "+ searching for a candidate") for _, candidateReplica := range candidateReplicas { if canTakeOverPromotedServerAsMaster(candidateReplica, promotedReplica) && promotedReplica.DataCenter == candidateReplica.DataCenter && @@ -708,7 +708,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de // Still nothing? if candidateInstanceKey == nil { // Try a candidate replica (our promoted replica is not an "is_candidate") - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for a candidate")) + AuditTopologyRecovery(topologyRecovery, "+ searching for a candidate") for _, candidateReplica := range candidateReplicas { if canTakeOverPromotedServerAsMaster(candidateReplica, promotedReplica) { if satisfied, reason := MasterFailoverGeographicConstraintSatisfied(&topologyRecovery.AnalysisEntry, candidateReplica); satisfied { @@ -735,7 +735,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de if candidateInstanceKey == nil { // Still nothing? Then we didn't find a replica marked as "candidate". OK, further down the stream we have: // find neutral instance in same dv&env as dead master - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for a neutral server to replace promoted server, in same DC and env as dead master")) + AuditTopologyRecovery(topologyRecovery, "+ searching for a neutral server to replace promoted server, in same DC and env as dead master") for _, neutralReplica := range neutralReplicas { if canTakeOverPromotedServerAsMaster(neutralReplica, promotedReplica) && deadInstance.DataCenter == neutralReplica.DataCenter && @@ -747,7 +747,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de } if candidateInstanceKey == nil { // find neutral instance in same dv&env as promoted replica - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for a neutral server to replace promoted server, in same DC and env as promoted replica")) + AuditTopologyRecovery(topologyRecovery, "+ searching for a neutral server to replace promoted server, in same DC and env as promoted replica") for _, neutralReplica := range neutralReplicas { if canTakeOverPromotedServerAsMaster(neutralReplica, promotedReplica) && promotedReplica.DataCenter == neutralReplica.DataCenter && @@ -758,7 +758,7 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de } } if candidateInstanceKey == nil { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ searching for a neutral server to replace a prefer_not")) + AuditTopologyRecovery(topologyRecovery, "+ searching for a neutral server to replace a prefer_not") for _, neutralReplica := range neutralReplicas { if canTakeOverPromotedServerAsMaster(neutralReplica, promotedReplica) { if satisfied, reason := MasterFailoverGeographicConstraintSatisfied(&topologyRecovery.AnalysisEntry, neutralReplica); satisfied { @@ -776,12 +776,12 @@ func SuggestReplacementForPromotedReplica(topologyRecovery *TopologyRecovery, de // So do we have a candidate? if candidateInstanceKey == nil { // Found nothing. Stick with promoted replica - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ found no server to promote on top promoted replica")) + AuditTopologyRecovery(topologyRecovery, "+ found no server to promote on top promoted replica") return promotedReplica, false, nil } if promotedReplica.Key.Equals(candidateInstanceKey) { // Sanity. It IS the candidate, nothing to promote... - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("+ sanity check: found our very own server to promote; doing nothing")) + AuditTopologyRecovery(topologyRecovery, "+ sanity check: found our very own server to promote; doing nothing") return promotedReplica, false, nil } replacement, _, err = inst.ReadInstance(candidateInstanceKey) @@ -905,7 +905,7 @@ func checkAndRecoverDeadMaster(analysisEntry inst.ReplicationAnalysis, candidate if config.Config.ApplyMySQLPromotionAfterMasterFailover || analysisEntry.CommandHint == inst.GracefulMasterTakeoverCommandHint { // on GracefulMasterTakeoverCommandHint it makes utter sense to RESET SLAVE ALL and read_only=0, and there is no sense in not doing so. - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("- RecoverDeadMaster: will apply MySQL changes to promoted master")) + AuditTopologyRecovery(topologyRecovery, "- RecoverDeadMaster: will apply MySQL changes to promoted master") { _, err := inst.ResetReplicationOperation(&promotedReplica.Key) if err != nil { @@ -949,7 +949,7 @@ func checkAndRecoverDeadMaster(analysisEntry inst.ReplicationAnalysis, candidate } if config.Config.MasterFailoverDetachReplicaMasterHost { postponedFunction := func() error { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("- RecoverDeadMaster: detaching master host on promoted master")) + AuditTopologyRecovery(topologyRecovery, "- RecoverDeadMaster: detaching master host on promoted master") inst.DetachReplicaMasterHost(&promotedReplica.Key) return nil } @@ -1167,7 +1167,7 @@ func RecoverDeadIntermediateMaster(topologyRecovery *TopologyRecovery, skipProce relocateReplicasToCandidateSibling() } if !recoveryResolved { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("- RecoverDeadIntermediateMaster: will next attempt regrouping of replicas")) + AuditTopologyRecovery(topologyRecovery, "- RecoverDeadIntermediateMaster: will next attempt regrouping of replicas") // Plan B: regroup (we wish to reduce cross-DC replication streams) lostReplicas, _, _, _, regroupPromotedReplica, regroupError := inst.RegroupReplicas(failedInstanceKey, true, nil, nil) if regroupError != nil { @@ -1185,7 +1185,7 @@ func RecoverDeadIntermediateMaster(topologyRecovery *TopologyRecovery, skipProce } // Plan C: try replacement intermediate master in other DC... if candidateSiblingOfIntermediateMaster != nil && candidateSiblingOfIntermediateMaster.DataCenter != intermediateMasterInstance.DataCenter { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("- RecoverDeadIntermediateMaster: will next attempt relocating to another DC server")) + AuditTopologyRecovery(topologyRecovery, "- RecoverDeadIntermediateMaster: will next attempt relocating to another DC server") relocateReplicasToCandidateSibling() } } @@ -1438,7 +1438,7 @@ func checkAndRecoverDeadCoMaster(analysisEntry inst.ReplicationAnalysis, candida recoverDeadCoMasterSuccessCounter.Inc(1) if config.Config.ApplyMySQLPromotionAfterMasterFailover { - AuditTopologyRecovery(topologyRecovery, fmt.Sprintf("- RecoverDeadMaster: will apply MySQL changes to promoted master")) + AuditTopologyRecovery(topologyRecovery, "- RecoverDeadMaster: will apply MySQL changes to promoted master") inst.SetReadOnly(&promotedReplica.Key, false) } if !skipProcesses {