2017-01-16 15:26:26 -08:00
|
|
|
# Golang Admin Client API Reference [![Slack](https://slack.minio.io/slack?type=svg)](https://slack.minio.io)
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
## Initialize Minio Admin Client object.
|
|
|
|
|
|
|
|
## Minio
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2017-01-17 23:32:58 +05:30
|
|
|
"fmt"
|
2016-12-20 18:49:48 -08:00
|
|
|
|
2017-01-17 23:32:58 +05:30
|
|
|
"github.com/minio/minio/pkg/madmin"
|
2016-12-20 18:49:48 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2017-01-17 23:32:58 +05:30
|
|
|
// Use a secure connection.
|
|
|
|
ssl := true
|
|
|
|
|
|
|
|
// Initialize minio client object.
|
|
|
|
mdmClnt, err := madmin.New("your-minio.example.com:9000", "YOUR-ACCESSKEYID", "YOUR-SECRETKEY", ssl)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fetch service status.
|
|
|
|
st, err := mdmClnt.ServiceStatus()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fmt.Printf("%#v\n", st)
|
2016-12-20 18:49:48 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
| Service operations | LockInfo operations | Healing operations | Config operations | Misc |
|
|
|
|
|:------------------------------------|:----------------------------|:--------------------------------------|:--------------------------|:------------------------------------|
|
|
|
|
| [`ServiceStatus`](#ServiceStatus) | [`ListLocks`](#ListLocks) | [`Heal`](#Heal) | [`GetConfig`](#GetConfig) | [`SetCredentials`](#SetCredentials) |
|
|
|
|
| [`ServiceSendAction`](#ServiceSendAction) | [`ClearLocks`](#ClearLocks) | | [`SetConfig`](#SetConfig) | |
|
|
|
|
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
## 1. Constructor
|
|
|
|
<a name="Minio"></a>
|
|
|
|
|
|
|
|
### New(endpoint string, accessKeyID string, secretAccessKey string, ssl bool) (*AdminClient, error)
|
|
|
|
Initializes a new admin client object.
|
|
|
|
|
|
|
|
__Parameters__
|
|
|
|
|
|
|
|
|
|
|
|
|Param |Type |Description |
|
|
|
|
|:---|:---| :---|
|
|
|
|
|`endpoint` | _string_ |Minio endpoint. |
|
|
|
|
|`accessKeyID` |_string_ | Access key for the object storage endpoint. |
|
|
|
|
|`secretAccessKey` | _string_ |Secret key for the object storage endpoint. |
|
|
|
|
|`ssl` | _bool_ | Set this value to 'true' to enable secure (HTTPS) access. |
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 2. Admin API Version
|
|
|
|
|
|
|
|
<a name="VersionInfo"></a>
|
|
|
|
### VersionInfo() (AdminAPIVersionInfo, error)
|
|
|
|
Fetch server's supported Administrative API version.
|
2016-12-20 18:49:48 -08:00
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
|
|
|
|
|
|
|
info, err := madmClnt.VersionInfo()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Printf("%s\n", info.Version)
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
## 3. Service operations
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
<a name="ServiceStatus"></a>
|
|
|
|
### ServiceStatus() (ServiceStatusMetadata, error)
|
2017-01-17 23:32:58 +05:30
|
|
|
Fetch service status, replies disk space used, backend type and total disks offline/online (applicable in distributed mode).
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
| Param | Type | Description |
|
|
|
|
|---|---|---|
|
2017-01-17 23:32:58 +05:30
|
|
|
|`serviceStatus` | _ServiceStatusMetadata_ | Represents current server status info in following format: |
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
|
|
|
|
| Param | Type | Description |
|
|
|
|
|---|---|---|
|
2017-01-23 17:56:06 +01:00
|
|
|
|`st.ServerVersion.Version` | _string_ | Server version. |
|
|
|
|
|`st.ServerVersion.CommitID` | _string_ | Server commit id. |
|
|
|
|
|`st.StorageInfo.Total` | _int64_ | Total disk space. |
|
|
|
|
|`st.StorageInfo.Free` | _int64_ | Free disk space. |
|
|
|
|
|`st.StorageInfo.Backend`| _struct{}_ | Represents backend type embedded structure. |
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
| Param | Type | Description |
|
|
|
|
|---|---|---|
|
2017-02-09 23:26:44 -08:00
|
|
|
|`backend.Type` | _BackendType_ | Type of backend used by the server currently only FS or Erasure. |
|
|
|
|
|`backend.OnlineDisks`| _int_ | Total number of disks online (only applies to Erasure backend), is empty for FS. |
|
|
|
|
|`backend.OfflineDisks` | _int_ | Total number of disks offline (only applies to Erasure backend), is empty for FS. |
|
2018-01-12 07:52:52 +05:30
|
|
|
|`backend.StandardSCParity` | _int_ | Parity disks set for standard storage class, is empty for FS. |
|
|
|
|
|`backend.RRSCParity` | _int_ | Parity disks set for reduced redundancy storage class, is empty for FS. |
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2016-12-20 18:49:48 -08:00
|
|
|
```go
|
|
|
|
|
|
|
|
st, err := madmClnt.ServiceStatus()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Printf("%#v\n", st)
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
<a name="ServiceSendAction"></a>
|
|
|
|
### ServiceSendAction(act ServiceActionValue) (error)
|
|
|
|
Sends a service action command to service - possible actions are restarting and stopping the server.
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2016-12-20 18:49:48 -08:00
|
|
|
```go
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
// to restart
|
|
|
|
st, err := madmClnt.ServiceSendAction(ServiceActionValueRestart)
|
|
|
|
// or to stop
|
|
|
|
// st, err := madmClnt.ServiceSendAction(ServiceActionValueStop)
|
2016-12-20 18:49:48 -08:00
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
2017-01-17 23:32:58 +05:30
|
|
|
log.Printf("Success")
|
2016-12-20 18:49:48 -08:00
|
|
|
|
|
|
|
```
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 4. Info operations
|
2017-04-21 15:15:53 +01:00
|
|
|
|
|
|
|
<a name="ServerInfo"></a>
|
|
|
|
### ServerInfo() ([]ServerInfo, error)
|
|
|
|
Fetch all information for all cluster nodes, such as uptime, region, network statistics, etc..
|
|
|
|
|
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
|
|
|
serversInfo, err := madmClnt.ServerInfo()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, peerInfo := range serversInfo {
|
|
|
|
log.Printf("Node: %s, Info: %v\n", peerInfo.Addr, peerInfo.Data)
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 5. Lock operations
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2017-01-17 23:32:58 +05:30
|
|
|
<a name="ListLocks"></a>
|
2017-02-02 00:47:30 +05:30
|
|
|
### ListLocks(bucket, prefix string, duration time.Duration) ([]VolumeLockInfo, error)
|
|
|
|
If successful returns information on the list of locks held on ``bucket`` matching ``prefix`` for longer than ``duration`` seconds.
|
2017-01-17 23:32:58 +05:30
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
|
|
|
volLocks, err := madmClnt.ListLocks("mybucket", "myprefix", 30 * time.Second)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Println("List of locks: ", volLocks)
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
<a name="ClearLocks"></a>
|
2017-02-02 00:47:30 +05:30
|
|
|
### ClearLocks(bucket, prefix string, duration time.Duration) ([]VolumeLockInfo, error)
|
|
|
|
If successful returns information on the list of locks cleared on ``bucket`` matching ``prefix`` for longer than ``duration`` seconds.
|
2017-01-17 23:32:58 +05:30
|
|
|
|
|
|
|
__Example__
|
2016-12-20 18:49:48 -08:00
|
|
|
|
2017-01-17 23:32:58 +05:30
|
|
|
``` go
|
|
|
|
volLocks, err := madmClnt.ClearLocks("mybucket", "myprefix", 30 * time.Second)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Println("List of locks cleared: ", volLocks)
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 6. Heal operations
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
<a name="Heal"></a>
|
|
|
|
### Heal(bucket, prefix string, healOpts HealOpts, clientToken string, forceStart bool) (start HealStartSuccess, status HealTaskStatus, err error)
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
Start a heal sequence that scans data under given (possible empty)
|
|
|
|
`bucket` and `prefix`. The `recursive` bool turns on recursive
|
|
|
|
traversal under the given path. `dryRun` does not mutate on-disk data,
|
|
|
|
but performs data validation. `incomplete` enables healing of
|
|
|
|
multipart uploads that are in progress. `removeBadFiles` removes
|
|
|
|
unrecoverable files. `statisticsOnly` turns off detailed
|
|
|
|
heal-operations reporting in the status call.
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
Two heal sequences on overlapping paths may not be initiated.
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
The progress of a heal should be followed using the `HealStatus`
|
|
|
|
API. The server accumulates results of the heal traversal and waits
|
|
|
|
for the client to receive and acknowledge them using the status
|
|
|
|
API. When the statistics-only option is set, the server only maintains
|
|
|
|
aggregates statistics - in this case, no acknowledgement of results is
|
|
|
|
required.
|
2017-01-19 18:34:18 +01:00
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
healPath, err := madmClnt.HealStart("", "", true, false, true, false, false)
|
2017-01-17 23:32:58 +05:30
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
2018-01-22 14:54:55 -08:00
|
|
|
log.Printf("Heal sequence started at %s", healPath)
|
2017-01-17 23:32:58 +05:30
|
|
|
|
|
|
|
```
|
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
#### HealTaskStatus structure
|
2017-04-14 22:58:35 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
| Param | Type | Description |
|
|
|
|
|----|--------|--------|
|
|
|
|
| s.Summary | _string_ | Short status of heal sequence |
|
|
|
|
| s.FailureDetail | _string_ | Error message in case of heal sequence failure |
|
|
|
|
| s.HealSettings | _HealOpts_ | Contains the booleans set in the `HealStart` call |
|
|
|
|
| s.Items | _[]HealResultItem_ | Heal records for actions performed by server |
|
|
|
|
| s.Statistics | _HealStatistics_ | Aggregate of heal records from beginning |
|
2017-04-14 22:58:35 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
#### HealResultItem structure
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
| Param | Type | Description |
|
|
|
|
|------|-------|---------|
|
|
|
|
| ResultIndex | _int64_ | Index of the heal-result record |
|
|
|
|
| Type | _HealItemType_ | Represents kind of heal operation in the heal record |
|
|
|
|
| Bucket | _string_ | Bucket name |
|
|
|
|
| Object | _string_ | Object name |
|
|
|
|
| Detail | _string_ | Details about heal operation |
|
|
|
|
| DiskInfo.AvailableOn | _[]int_ | List of disks on which the healed entity is present and healthy |
|
|
|
|
| DiskInfo.HealedOn | _[]int_ | List of disks on which the healed entity was restored |
|
2017-04-01 06:25:15 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
#### HealStatistics structure
|
2017-01-17 23:32:58 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
Most parameters represent the aggregation of heal operations since the
|
|
|
|
start of the heal sequence.
|
2017-01-23 14:02:55 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
| Param | Type | Description |
|
|
|
|
|-------|-----|----------|
|
|
|
|
| NumDisks | _int_ | Number of disks configured in the backend |
|
|
|
|
| NumBucketsScanned | _int64_ | Number of buckets scanned |
|
|
|
|
| BucketsMissingByDisk | _map[int]int64_ | Map of disk to number of buckets missing |
|
|
|
|
| BucketsAvailableByDisk | _map[int]int64_ | Map of disk to number of buckets available |
|
|
|
|
| BucketsHealedByDisk | _map[int]int64_ | Map of disk to number of buckets healed on |
|
|
|
|
| NumObjectsScanned | _int64_ | Number of objects scanned |
|
|
|
|
| NumUploadsScanned | _int64_ | Number of uploads scanned |
|
|
|
|
| ObjectsByAvailablePC | _map[int64]_ | Map of available part counts (after heal) to number of objects |
|
|
|
|
| ObjectsByHealedPC | _map[int64]_ | Map of healed part counts to number of objects |
|
|
|
|
| ObjectsMissingByDisk | _map[int64]_ | Map of disk number to number of objects with parts missing on that disk |
|
|
|
|
| ObjectsAvailableByDisk | _map[int64]_ | Map of disk number to number of objects available on that disk |
|
|
|
|
| ObjectsHealedByDisk | _map[int64]_ | Map of disk number to number of objects healed on that disk |
|
2017-01-23 14:02:55 +05:30
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
2017-01-24 21:41:05 +05:30
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
res, err := madmClnt.HealStatus("", "")
|
2017-01-23 14:02:55 +05:30
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
2018-01-22 14:54:55 -08:00
|
|
|
log.Printf("Heal sequence status data %#v", res)
|
2017-01-23 14:02:55 +05:30
|
|
|
|
|
|
|
```
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 7. Config operations
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2017-02-21 02:28:50 +05:30
|
|
|
<a name="GetConfig"></a>
|
|
|
|
### GetConfig() ([]byte, error)
|
|
|
|
Get config.json of a minio setup.
|
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
|
|
|
configBytes, err := madmClnt.GetConfig()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("failed due to: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pretty-print config received as json.
|
|
|
|
var buf bytes.Buffer
|
|
|
|
err = json.Indent(buf, configBytes, "", "\t")
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("failed due to: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Println("config received successfully: ", string(buf.Bytes()))
|
|
|
|
```
|
2017-02-25 20:06:08 +01:00
|
|
|
|
|
|
|
|
2017-02-28 01:10:27 +05:30
|
|
|
<a name="SetConfig"></a>
|
|
|
|
### SetConfig(config io.Reader) (SetConfigResult, error)
|
|
|
|
Set config.json of a minio setup and restart setup for configuration
|
|
|
|
change to take effect.
|
2017-02-25 20:06:08 +01:00
|
|
|
|
2017-02-28 01:10:27 +05:30
|
|
|
|
|
|
|
| Param | Type | Description |
|
|
|
|
|---|---|---|
|
|
|
|
|`st.Status` | _bool_ | true if set-config succeeded, false otherwise. |
|
|
|
|
|`st.NodeSummary.Name` | _string_ | Network address of the node. |
|
2017-03-03 11:53:48 +01:00
|
|
|
|`st.NodeSummary.ErrSet` | _bool_ | Bool representation indicating if an error is encountered with the node.|
|
|
|
|
|`st.NodeSummary.ErrMsg` | _string_ | String representation of the error (if any) on the node.|
|
2017-02-28 01:10:27 +05:30
|
|
|
|
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
|
|
|
config := bytes.NewReader([]byte(`config.json contents go here`))
|
|
|
|
result, err := madmClnt.SetConfig(config)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("failed due to: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var buf bytes.Buffer
|
|
|
|
enc := json.NewEncoder(&buf)
|
|
|
|
enc.SetEscapeHTML(false)
|
|
|
|
enc.SetIndent("", "\t")
|
|
|
|
err = enc.Encode(result)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Println("SetConfig: ", string(buf.Bytes()))
|
|
|
|
```
|
2017-04-21 15:15:53 +01:00
|
|
|
|
2018-01-22 14:54:55 -08:00
|
|
|
## 8. Misc operations
|
2017-04-21 15:15:53 +01:00
|
|
|
|
|
|
|
<a name="SetCredentials"></a>
|
|
|
|
|
|
|
|
### SetCredentials() error
|
|
|
|
Set new credentials of a Minio setup.
|
|
|
|
|
|
|
|
__Example__
|
|
|
|
|
|
|
|
``` go
|
|
|
|
err = madmClnt.SetCredentials("YOUR-NEW-ACCESSKEY", "YOUR-NEW-SECRETKEY")
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
log.Println("New credentials successfully set.")
|
|
|
|
|
|
|
|
```
|