Documentation ¶
Index ¶
- func Respond(r render.Render, apiResponse *APIResponse)
- type APIResponse
- type APIResponseCode
- type HttpAPI
- func (this *HttpAPI) AcknowledgeAllRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) AcknowledgeClusterRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) AcknowledgeInstanceRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) AcknowledgeRecovery(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ActiveClusterRecovery(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AllInstances(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AsciiTopology(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AsciiTopologyTabulated(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AsciiTopologyTags(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AsyncDiscover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Audit(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AuditFailureDetection(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AuditRecovery(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AuditRecoverySteps(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) AutomatedRecoveryFilters(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) BackendQueryMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) BackendQueryMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) BeginDowntime(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) BeginMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) BlockedRecoveries(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) BulkInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) BulkPromotionRules(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) CanReplicateFrom(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) CanReplicateFromGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) CheckGlobalRecoveries(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Cluster(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterByAlias(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterByInstance(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterInfo(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterInfoByAlias(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterMaster(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClusterOSCReplicas(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Clusters(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ClustersInfo(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) DeregisterHostnameUnresolve(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DetachReplicaMasterHost(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DisableGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DisableGlobalRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Discover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DiscoveryMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DiscoveryMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DiscoveryQueueMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) DiscoveryQueueMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Downtimed(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) EnableGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) EnableGlobalRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) EndDowntime(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) EndMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) EndMaintenanceByInstanceKey(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ErrantGTIDInjectEmpty(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ErrantGTIDResetMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) FlushBinaryLogs(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ForceMasterFailover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ForceMasterTakeover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Forget(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ForgetCluster(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) GetHeuristicClusterPoolInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) GetHeuristicClusterPoolInstancesLag(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) GrabElection(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) GracefulMasterTakeover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) GracefulMasterTakeoverAuto(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Headers(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Health(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) HostnameResolveCache(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) InMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Instance(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) InstanceReplicas(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) KillQuery(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) LBCheck(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) LeaderCheck(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) LocateErrantGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Maintenance(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) MakeCoMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Masters(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) MoveBelow(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) MoveBelowGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) MoveReplicasGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) MoveUp(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) MoveUpReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Problems(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) PurgeBinaryLogs(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ReadClusterPoolInstancesMap(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ReadReplicationAnalysisChangelog(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ReattachReplicaMasterHost(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RecentlyActiveClusterRecovery(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) RecentlyActiveInstanceRecovery(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Recover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RecoverLite(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Reelect(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Refresh(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RegisterCandidate(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RegisterHostnameUnresolve(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RegisterRequests(m *martini.ClassicMartini)
- func (this *HttpAPI) RegroupReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RegroupReplicasBinlogServers(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RegroupReplicasGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ReloadClusterAlias(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ReloadConfiguration(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RelocateBelow(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RelocateReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ReplicationAnalysis(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ReplicationAnalysisForCluster(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) ReplicationAnalysisForKey(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Repoint(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RepointReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ResetHostnameResolveCache(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) ResetReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Resolve(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) RestartReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) RestartReplicationStatements(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Search(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) SetClusterAliasManualOverride(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) SetReadOnly(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) SetWriteable(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) SkipQuery(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) SnapshotTopologies(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) StartReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) StatusCheck(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) StopReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) StopReplicationNicely(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) SubmitMastersToKvStores(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) SubmitPoolInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Tag(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) TagValue(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Tagged(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) Tags(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) TakeMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) TakeSiblings(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) Untag(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) UntagAll(params martini.Params, r render.Render, req *http.Request)
- func (this *HttpAPI) WriteBufferMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpAPI) WriteBufferMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
- type HttpWeb
- func (this *HttpWeb) About(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) AccessToken(params martini.Params, r render.Render, req *http.Request, ...)
- func (this *HttpWeb) Agent(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) AgentSeedDetails(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Agents(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Audit(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) AuditFailureDetection(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) AuditRecovery(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Cluster(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) ClusterByAlias(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) ClusterByInstance(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) ClusterPools(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Clusters(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) ClustersAnalysis(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Discover(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) FAQ(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Home(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Index(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) KeepCalm(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) RegisterDebug(m *martini.ClassicMartini)
- func (this *HttpWeb) RegisterRequests(m *martini.ClassicMartini)
- func (this *HttpWeb) Search(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Seeds(params martini.Params, r render.Render, req *http.Request, user auth.User)
- func (this *HttpWeb) Status(params martini.Params, r render.Render, req *http.Request, user auth.User)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Respond ¶
func Respond(r render.Render, apiResponse *APIResponse)
Types ¶
type APIResponse ¶
type APIResponse struct { Code APIResponseCode Message string Details interface{} }
APIResponse is a response returned as JSON to various requests.
type APIResponseCode ¶
type APIResponseCode int
APIResponseCode is an OK/ERROR response code
const ( ERROR APIResponseCode = iota OK )
func (*APIResponseCode) HttpStatus ¶
func (this *APIResponseCode) HttpStatus() int
HttpStatus returns the respective HTTP status for this response
func (*APIResponseCode) MarshalJSON ¶
func (this *APIResponseCode) MarshalJSON() ([]byte, error)
func (*APIResponseCode) String ¶
func (this *APIResponseCode) String() string
type HttpAPI ¶
type HttpAPI struct {
URLPrefix string
}
func (*HttpAPI) AcknowledgeAllRecoveries ¶
func (this *HttpAPI) AcknowledgeAllRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
ClusterInfo provides details of a given cluster
func (*HttpAPI) AcknowledgeClusterRecoveries ¶
func (this *HttpAPI) AcknowledgeClusterRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
ClusterInfo provides details of a given cluster
func (*HttpAPI) AcknowledgeInstanceRecoveries ¶
func (this *HttpAPI) AcknowledgeInstanceRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
ClusterInfo provides details of a given cluster
func (*HttpAPI) AcknowledgeRecovery ¶
func (this *HttpAPI) AcknowledgeRecovery(params martini.Params, r render.Render, req *http.Request, user auth.User)
ClusterInfo provides details of a given cluster
func (*HttpAPI) ActiveClusterRecovery ¶
func (this *HttpAPI) ActiveClusterRecovery(params martini.Params, r render.Render, req *http.Request)
ActiveClusterRecovery returns recoveries in-progress for a given cluster
func (*HttpAPI) AllInstances ¶
AllInstances lists all known instances
func (*HttpAPI) AsciiTopology ¶
AsciiTopology returns an ascii graph of cluster's instances
func (*HttpAPI) AsciiTopologyTabulated ¶
func (this *HttpAPI) AsciiTopologyTabulated(params martini.Params, r render.Render, req *http.Request)
AsciiTopology returns an ascii graph of cluster's instances
func (*HttpAPI) AsciiTopologyTags ¶
AsciiTopologyTags returns an ascii graph of cluster's instances and instance tags
func (*HttpAPI) AsyncDiscover ¶
func (this *HttpAPI) AsyncDiscover(params martini.Params, r render.Render, req *http.Request, user auth.User)
AsyncDiscover issues an asynchronous read on an instance. This is useful for bulk loads of a new set of instances and will not block if the instance is slow to respond or not reachable.
func (*HttpAPI) AuditFailureDetection ¶
func (this *HttpAPI) AuditFailureDetection(params martini.Params, r render.Render, req *http.Request)
AuditFailureDetection provides list of topology_failure_detection entries
func (*HttpAPI) AuditRecovery ¶
AuditRecovery provides list of topology-recovery entries
func (*HttpAPI) AuditRecoverySteps ¶
AuditRecoverySteps returns audited steps of a given recovery
func (*HttpAPI) AutomatedRecoveryFilters ¶
func (this *HttpAPI) AutomatedRecoveryFilters(params martini.Params, r render.Render, req *http.Request)
AutomatedRecoveryFilters retuens list of clusters which are configured with automated recovery
func (*HttpAPI) BackendQueryMetricsAggregated ¶
func (*HttpAPI) BackendQueryMetricsRaw ¶
func (this *HttpAPI) BackendQueryMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
BackendQueryMetricsRaw returns the raw backend query metrics
func (*HttpAPI) BeginDowntime ¶
func (this *HttpAPI) BeginDowntime(params martini.Params, r render.Render, req *http.Request, user auth.User)
BeginDowntime sets a downtime flag with default duration
func (*HttpAPI) BeginMaintenance ¶
func (this *HttpAPI) BeginMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
BeginMaintenance begins maintenance mode for given instance
func (*HttpAPI) BlockedRecoveries ¶
BlockedRecoveries reads list of currently blocked recoveries, optionally filtered by cluster name
func (*HttpAPI) BulkInstances ¶
func (this *HttpAPI) BulkInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
BulkInstances returns a list of all known instances
func (*HttpAPI) BulkPromotionRules ¶
func (this *HttpAPI) BulkPromotionRules(params martini.Params, r render.Render, req *http.Request, user auth.User)
BulkPromotionRules returns a list of the known promotion rules for each instance
func (*HttpAPI) CanReplicateFrom ¶
func (this *HttpAPI) CanReplicateFrom(params martini.Params, r render.Render, req *http.Request, user auth.User)
CanReplicateFrom attempts to move an instance below another via pseudo GTID matching of binlog entries
func (*HttpAPI) CanReplicateFromGTID ¶
func (this *HttpAPI) CanReplicateFromGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
CanReplicateFromGTID attempts to move an instance below another via GTID.
func (*HttpAPI) CheckGlobalRecoveries ¶
func (this *HttpAPI) CheckGlobalRecoveries(params martini.Params, r render.Render, req *http.Request)
CheckGlobalRecoveries checks whether
func (*HttpAPI) ClusterByAlias ¶
ClusterByAlias provides list of instances in given cluster
func (*HttpAPI) ClusterByInstance ¶
ClusterByInstance provides list of instances in cluster an instance belongs to
func (*HttpAPI) ClusterInfo ¶
ClusterInfo provides details of a given cluster
func (*HttpAPI) ClusterInfoByAlias ¶
Cluster provides list of instances in given cluster
func (*HttpAPI) ClusterMaster ¶
ClusterMaster returns the writable master of a given cluster
func (*HttpAPI) ClusterOSCReplicas ¶
ClusterOSCReplicas returns heuristic list of OSC replicas
func (*HttpAPI) ClustersInfo ¶
ClustersInfo provides list of known clusters, along with some added metadata per cluster
func (*HttpAPI) DeregisterHostnameUnresolve ¶
func (this *HttpAPI) DeregisterHostnameUnresolve(params martini.Params, r render.Render, req *http.Request, user auth.User)
DeregisterHostnameUnresolve deregisters the unresolve name used previously
func (*HttpAPI) DetachReplicaMasterHost ¶
func (this *HttpAPI) DetachReplicaMasterHost(params martini.Params, r render.Render, req *http.Request, user auth.User)
DetachReplicaMasterHost detaches a replica from its master by setting an invalid (yet revertible) host name
func (*HttpAPI) DisableGTID ¶
func (this *HttpAPI) DisableGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
DisableGTID attempts to disable GTID on a replica, and revert to binlog file:pos
func (*HttpAPI) DisableGlobalRecoveries ¶
func (this *HttpAPI) DisableGlobalRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
DisableGlobalRecoveries globally disables recoveries
func (*HttpAPI) Discover ¶
func (this *HttpAPI) Discover(params martini.Params, r render.Render, req *http.Request, user auth.User)
Discover issues a synchronous read on an instance
func (*HttpAPI) DiscoveryMetricsAggregated ¶
func (this *HttpAPI) DiscoveryMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
DiscoveryMetricsAggregated will return a single set of aggregated metrics for raw values collected since the specified time.
func (*HttpAPI) DiscoveryMetricsRaw ¶
func (this *HttpAPI) DiscoveryMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
DiscoveryMetricsRaw will return the last X seconds worth of discovery information in time based order as a JSON array
func (*HttpAPI) DiscoveryQueueMetricsAggregated ¶
func (this *HttpAPI) DiscoveryQueueMetricsAggregated(params martini.Params, r render.Render, req *http.Request, user auth.User)
DiscoveryQueueMetricsAggregated returns a single value showing the metrics of the discovery queue over the last N seconds. This is expected to be called every 60 seconds (?) and the config setting of the retention period is currently hard-coded. See go/discovery/ for more information.
func (*HttpAPI) DiscoveryQueueMetricsRaw ¶
func (this *HttpAPI) DiscoveryQueueMetricsRaw(params martini.Params, r render.Render, req *http.Request, user auth.User)
DiscoveryQueueMetricsRaw returns the raw queue metrics (active and queued values), data taken secondly for the last N seconds.
func (*HttpAPI) EnableGTID ¶
func (this *HttpAPI) EnableGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
EnableGTID attempts to enable GTID on a replica
func (*HttpAPI) EnableGlobalRecoveries ¶
func (this *HttpAPI) EnableGlobalRecoveries(params martini.Params, r render.Render, req *http.Request, user auth.User)
EnableGlobalRecoveries globally enables recoveries
func (*HttpAPI) EndDowntime ¶
func (this *HttpAPI) EndDowntime(params martini.Params, r render.Render, req *http.Request, user auth.User)
EndDowntime terminates downtime (removes downtime flag) for an instance
func (*HttpAPI) EndMaintenance ¶
func (this *HttpAPI) EndMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
EndMaintenance terminates maintenance mode
func (*HttpAPI) EndMaintenanceByInstanceKey ¶
func (this *HttpAPI) EndMaintenanceByInstanceKey(params martini.Params, r render.Render, req *http.Request, user auth.User)
EndMaintenanceByInstanceKey terminates maintenance mode for given instance
func (*HttpAPI) ErrantGTIDInjectEmpty ¶
func (this *HttpAPI) ErrantGTIDInjectEmpty(params martini.Params, r render.Render, req *http.Request, user auth.User)
ErrantGTIDInjectEmpty removes errant transactions by injecting and empty transaction on the cluster's master
func (*HttpAPI) ErrantGTIDResetMaster ¶
func (this *HttpAPI) ErrantGTIDResetMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
ErrantGTIDResetMaster removes errant transactions on a server by way of RESET MASTER
func (*HttpAPI) FlushBinaryLogs ¶
func (this *HttpAPI) FlushBinaryLogs(params martini.Params, r render.Render, req *http.Request, user auth.User)
FlushBinaryLogs runs a single FLUSH BINARY LOGS
func (*HttpAPI) ForceMasterFailover ¶
func (this *HttpAPI) ForceMasterFailover(params martini.Params, r render.Render, req *http.Request, user auth.User)
ForceMasterFailover fails over a master (even if there's no particular problem with the master)
func (*HttpAPI) ForceMasterTakeover ¶
func (this *HttpAPI) ForceMasterTakeover(params martini.Params, r render.Render, req *http.Request, user auth.User)
ForceMasterTakeover fails over a master (even if there's no particular problem with the master)
func (*HttpAPI) Forget ¶
func (this *HttpAPI) Forget(params martini.Params, r render.Render, req *http.Request, user auth.User)
Forget removes an instance entry fro backend database
func (*HttpAPI) ForgetCluster ¶
func (this *HttpAPI) ForgetCluster(params martini.Params, r render.Render, req *http.Request, user auth.User)
ForgetCluster forgets all instacnes of a cluster
func (*HttpAPI) GetHeuristicClusterPoolInstances ¶
func (this *HttpAPI) GetHeuristicClusterPoolInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
GetHeuristicClusterPoolInstances returns instances belonging to a cluster's pool
func (*HttpAPI) GetHeuristicClusterPoolInstancesLag ¶
func (this *HttpAPI) GetHeuristicClusterPoolInstancesLag(params martini.Params, r render.Render, req *http.Request, user auth.User)
GetHeuristicClusterPoolInstances returns instances belonging to a cluster's pool
func (*HttpAPI) GrabElection ¶
func (this *HttpAPI) GrabElection(params martini.Params, r render.Render, req *http.Request, user auth.User)
GrabElection forcibly grabs leadership. Use with care!!
func (*HttpAPI) GracefulMasterTakeover ¶
func (this *HttpAPI) GracefulMasterTakeover(params martini.Params, r render.Render, req *http.Request, user auth.User)
GracefulMasterTakeover gracefully fails over a master, either: - onto its single replica, or - onto a replica indicated by the user
func (*HttpAPI) GracefulMasterTakeoverAuto ¶
func (this *HttpAPI) GracefulMasterTakeoverAuto(params martini.Params, r render.Render, req *http.Request, user auth.User)
GracefulMasterTakeoverAuto gracefully fails over a master onto a replica of orchestrator's choosing
func (*HttpAPI) HostnameResolveCache ¶
func (this *HttpAPI) HostnameResolveCache(params martini.Params, r render.Render, req *http.Request)
HostnameResolveCache shows content of in-memory hostname cache
func (*HttpAPI) InMaintenance ¶
func (this *HttpAPI) InMaintenance(params martini.Params, r render.Render, req *http.Request, user auth.User)
EndMaintenanceByInstanceKey terminates maintenance mode for given instance
func (*HttpAPI) InstanceReplicas ¶
InstanceReplicas lists all replicas of given instance
func (*HttpAPI) KillQuery ¶
func (this *HttpAPI) KillQuery(params martini.Params, r render.Render, req *http.Request, user auth.User)
KillQuery kills a query running on a server
func (*HttpAPI) LBCheck ¶
LBCheck returns a constant respnse, and this can be used by load balancers that expect a given string.
func (*HttpAPI) LeaderCheck ¶
LBCheck returns a constant respnse, and this can be used by load balancers that expect a given string.
func (*HttpAPI) LocateErrantGTID ¶
func (this *HttpAPI) LocateErrantGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
LocateErrantGTID identifies the binlog positions for errant GTIDs on an instance
func (*HttpAPI) Maintenance ¶
Maintenance provides list of instance under active maintenance
func (*HttpAPI) MakeCoMaster ¶
func (this *HttpAPI) MakeCoMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
MakeCoMaster attempts to make an instance co-master with its own master
func (*HttpAPI) MoveBelow ¶
func (this *HttpAPI) MoveBelow(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveBelow attempts to move an instance below its supposed sibling
func (*HttpAPI) MoveBelowGTID ¶
func (this *HttpAPI) MoveBelowGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveBelowGTID attempts to move an instance below another, via GTID
func (*HttpAPI) MoveReplicasGTID ¶
func (this *HttpAPI) MoveReplicasGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveReplicasGTID attempts to move an instance below another, via GTID
func (*HttpAPI) MoveUp ¶
func (this *HttpAPI) MoveUp(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveUp attempts to move an instance up the topology
func (*HttpAPI) MoveUpReplicas ¶
func (this *HttpAPI) MoveUpReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveUpReplicas attempts to move up all replicas of an instance
func (*HttpAPI) PurgeBinaryLogs ¶
func (this *HttpAPI) PurgeBinaryLogs(params martini.Params, r render.Render, req *http.Request, user auth.User)
PurgeBinaryLogs purges binary logs up to given binlog file
func (*HttpAPI) ReadClusterPoolInstancesMap ¶
func (this *HttpAPI) ReadClusterPoolInstancesMap(params martini.Params, r render.Render, req *http.Request, user auth.User)
SubmitPoolHostnames (re-)applies the list of hostnames for a given pool
func (*HttpAPI) ReadReplicationAnalysisChangelog ¶
func (this *HttpAPI) ReadReplicationAnalysisChangelog(params martini.Params, r render.Render, req *http.Request)
ReadReplicationAnalysisChangelog lists instances and their analysis changelog
func (*HttpAPI) ReattachReplicaMasterHost ¶
func (this *HttpAPI) ReattachReplicaMasterHost(params martini.Params, r render.Render, req *http.Request, user auth.User)
ReattachReplicaMasterHost reverts a detachReplicaMasterHost command by resoting the original master hostname in CHANGE MASTER TO
func (*HttpAPI) RecentlyActiveClusterRecovery ¶
func (this *HttpAPI) RecentlyActiveClusterRecovery(params martini.Params, r render.Render, req *http.Request)
RecentlyActiveClusterRecovery returns recoveries in-progress for a given cluster
func (*HttpAPI) RecentlyActiveInstanceRecovery ¶
func (this *HttpAPI) RecentlyActiveInstanceRecovery(params martini.Params, r render.Render, req *http.Request)
RecentlyActiveClusterRecovery returns recoveries in-progress for a given cluster
func (*HttpAPI) Recover ¶
func (this *HttpAPI) Recover(params martini.Params, r render.Render, req *http.Request, user auth.User)
Recover attempts recovery on a given instance
func (*HttpAPI) RecoverLite ¶
func (this *HttpAPI) RecoverLite(params martini.Params, r render.Render, req *http.Request, user auth.User)
RecoverLite attempts recovery on a given instance, without executing external processes
func (*HttpAPI) Reelect ¶
func (this *HttpAPI) Reelect(params martini.Params, r render.Render, req *http.Request, user auth.User)
Reelect causes re-elections for an active node
func (*HttpAPI) Refresh ¶
func (this *HttpAPI) Refresh(params martini.Params, r render.Render, req *http.Request, user auth.User)
Refresh synchronuously re-reads a topology instance
func (*HttpAPI) RegisterCandidate ¶
func (this *HttpAPI) RegisterCandidate(params martini.Params, r render.Render, req *http.Request, user auth.User)
Registers promotion preference for given instance
func (*HttpAPI) RegisterHostnameUnresolve ¶
func (this *HttpAPI) RegisterHostnameUnresolve(params martini.Params, r render.Render, req *http.Request, user auth.User)
RegisterHostnameUnresolve registers the unresolve name to use
func (*HttpAPI) RegisterRequests ¶
func (this *HttpAPI) RegisterRequests(m *martini.ClassicMartini)
RegisterRequests makes for the de-facto list of known API calls
func (*HttpAPI) RegroupReplicas ¶
func (this *HttpAPI) RegroupReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
RegroupReplicas attempts to pick a replica of a given instance and make it take its siblings, using any method possible (GTID, binlog servers)
func (*HttpAPI) RegroupReplicasBinlogServers ¶
func (this *HttpAPI) RegroupReplicasBinlogServers(params martini.Params, r render.Render, req *http.Request, user auth.User)
RegroupReplicasBinlogServers attempts to pick a replica of a given instance and make it take its siblings, efficiently, using GTID
func (*HttpAPI) RegroupReplicasGTID ¶
func (this *HttpAPI) RegroupReplicasGTID(params martini.Params, r render.Render, req *http.Request, user auth.User)
RegroupReplicasGTID attempts to pick a replica of a given instance and make it take its siblings, efficiently, using GTID
func (*HttpAPI) ReloadClusterAlias ¶
func (this *HttpAPI) ReloadClusterAlias(params martini.Params, r render.Render, req *http.Request, user auth.User)
ReloadClusterAlias clears in-memory hostname resovle cache
func (*HttpAPI) ReloadConfiguration ¶
func (this *HttpAPI) ReloadConfiguration(params martini.Params, r render.Render, req *http.Request, user auth.User)
ReloadConfiguration reloads confiug settings (not all of which will apply after change)
func (*HttpAPI) RelocateBelow ¶
func (this *HttpAPI) RelocateBelow(params martini.Params, r render.Render, req *http.Request, user auth.User)
RelocateBelow attempts to move an instance below another, orchestrator choosing the best (potentially multi-step) relocation method
func (*HttpAPI) RelocateReplicas ¶
func (this *HttpAPI) RelocateReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
Relocates attempts to smartly relocate replicas of a given instance below another
func (*HttpAPI) ReplicationAnalysis ¶
ReplicationAnalysis retuens list of issues
func (*HttpAPI) ReplicationAnalysisForCluster ¶
func (this *HttpAPI) ReplicationAnalysisForCluster(params martini.Params, r render.Render, req *http.Request)
ReplicationAnalysis retuens list of issues
func (*HttpAPI) ReplicationAnalysisForKey ¶
func (this *HttpAPI) ReplicationAnalysisForKey(params martini.Params, r render.Render, req *http.Request)
ReplicationAnalysis retuens list of issues
func (*HttpAPI) Repoint ¶
func (this *HttpAPI) Repoint(params martini.Params, r render.Render, req *http.Request, user auth.User)
Repoint positiones a replica under another (or same) master with exact same coordinates. Useful for binlog servers
func (*HttpAPI) RepointReplicas ¶
func (this *HttpAPI) RepointReplicas(params martini.Params, r render.Render, req *http.Request, user auth.User)
MoveUpReplicas attempts to move up all replicas of an instance
func (*HttpAPI) ResetHostnameResolveCache ¶
func (this *HttpAPI) ResetHostnameResolveCache(params martini.Params, r render.Render, req *http.Request, user auth.User)
ResetHostnameResolveCache clears in-memory hostname resovle cache
func (*HttpAPI) ResetReplication ¶
func (this *HttpAPI) ResetReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
ResetReplication makes a replica forget about its master, effectively breaking the replication
func (*HttpAPI) Resolve ¶
Resolve tries to resolve hostname and then checks to see if port is open on that host.
func (*HttpAPI) RestartReplication ¶
func (this *HttpAPI) RestartReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
RestartReplication stops & starts replication on given instance
func (*HttpAPI) RestartReplicationStatements ¶
func (this *HttpAPI) RestartReplicationStatements(params martini.Params, r render.Render, req *http.Request, user auth.User)
RestartReplicationStatements receives a query to execute that requires a replication restart to apply. As an example, this may be `set global rpl_semi_sync_slave_enabled=1`. orchestrator will check replication status on given host and will wrap with appropriate stop/start statements, if need be.
func (*HttpAPI) Search ¶
Search provides list of instances matching given search param via various criteria.
func (*HttpAPI) SetClusterAliasManualOverride ¶
func (this *HttpAPI) SetClusterAliasManualOverride(params martini.Params, r render.Render, req *http.Request, user auth.User)
SetClusterAlias will change an alias for a given clustername
func (*HttpAPI) SetReadOnly ¶
func (this *HttpAPI) SetReadOnly(params martini.Params, r render.Render, req *http.Request, user auth.User)
SetReadOnly sets the global read_only variable
func (*HttpAPI) SetWriteable ¶
func (this *HttpAPI) SetWriteable(params martini.Params, r render.Render, req *http.Request, user auth.User)
SetWriteable clear the global read_only variable
func (*HttpAPI) SkipQuery ¶
func (this *HttpAPI) SkipQuery(params martini.Params, r render.Render, req *http.Request, user auth.User)
SkipQuery skips a single query on a failed replication instance
func (*HttpAPI) SnapshotTopologies ¶
SnapshotTopologies triggers orchestrator to record a snapshot of host/master for all known hosts.
func (*HttpAPI) StartReplication ¶
func (this *HttpAPI) StartReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
StartReplication starts replication on given instance
func (*HttpAPI) StatusCheck ¶
A configurable endpoint that can be for regular status checks or whatever. While similar to Health() this returns 500 on failure. This will prevent issues for those that have come to expect a 200 It might be a good idea to deprecate the current Health() behavior and roll this in at some point
func (*HttpAPI) StopReplication ¶
func (this *HttpAPI) StopReplication(params martini.Params, r render.Render, req *http.Request, user auth.User)
StopReplication stops replication on given instance
func (*HttpAPI) StopReplicationNicely ¶
func (this *HttpAPI) StopReplicationNicely(params martini.Params, r render.Render, req *http.Request, user auth.User)
StopReplicationNicely stops replication on given instance, such that sql thead is aligned with IO thread
func (*HttpAPI) SubmitMastersToKvStores ¶
func (this *HttpAPI) SubmitMastersToKvStores(params martini.Params, r render.Render, req *http.Request)
Write a cluster's master (or all clusters masters) to kv stores. This should generally only happen once in a lifetime of a cluster. Otherwise KV stores are updated via failovers.
func (*HttpAPI) SubmitPoolInstances ¶
func (this *HttpAPI) SubmitPoolInstances(params martini.Params, r render.Render, req *http.Request, user auth.User)
SubmitPoolInstances (re-)applies the list of hostnames for a given pool
func (*HttpAPI) TakeMaster ¶
func (this *HttpAPI) TakeMaster(params martini.Params, r render.Render, req *http.Request, user auth.User)
TakeMaster
func (*HttpAPI) TakeSiblings ¶
func (this *HttpAPI) TakeSiblings(params martini.Params, r render.Render, req *http.Request, user auth.User)
TakeSiblings
type HttpWeb ¶
type HttpWeb struct {
URLPrefix string
}
HttpWeb is the web requests server, mapping each request to a web page
func (*HttpWeb) AccessToken ¶
func (*HttpWeb) AgentSeedDetails ¶
func (*HttpWeb) AuditFailureDetection ¶
func (*HttpWeb) AuditRecovery ¶
func (*HttpWeb) ClusterByAlias ¶
func (*HttpWeb) ClusterByInstance ¶
func (*HttpWeb) ClusterPools ¶
func (*HttpWeb) ClustersAnalysis ¶
func (*HttpWeb) RegisterDebug ¶
func (this *HttpWeb) RegisterDebug(m *martini.ClassicMartini)
RegisterDebug adds handlers for /debug/vars (expvar) and /debug/pprof (net/http/pprof) support
func (*HttpWeb) RegisterRequests ¶
func (this *HttpWeb) RegisterRequests(m *martini.ClassicMartini)
RegisterRequests makes for the de-facto list of known Web calls