2019-04-09 11:39:42 -07:00
# MinIO Logging Quickstart Guide [![Slack](https://slack.min.io/slack?type=svg)](https://slack.min.io)
This document explains how to configure MinIO server to log to different logging targets.
2018-11-02 18:40:08 -07:00
## Log Targets
2019-04-09 11:39:42 -07:00
MinIO supports currently two target types
2018-11-02 18:40:08 -07:00
- console
- http
### Console Target
2019-10-22 22:59:13 -07:00
Console target is on always and cannot be disabled.
### HTTP Target
HTTP target logs to a generic HTTP endpoint in JSON format and is not enabled by default. To enable HTTP target logging you would have to update your MinIO server configuration using `mc admin config set` command.
2018-11-02 18:40:08 -07:00
2019-04-09 11:39:42 -07:00
Assuming `mc` is already [configured ](https://docs.min.io/docs/minio-client-quickstart-guide.html )
2018-11-02 18:40:08 -07:00
```
2019-11-13 17:38:05 -08:00
mc admin config get myminio/ logger_webhook
2019-12-06 13:53:51 -08:00
logger_webhook:name1 auth_token="" endpoint=""
2018-11-02 18:40:08 -07:00
```
```
2019-12-06 13:53:51 -08:00
mc admin config set myminio logger_webhook:name1 auth_token="" endpoint="http://endpoint:port/path"
2019-10-22 22:59:13 -07:00
mc admin service restart myminio
2018-11-02 18:40:08 -07:00
```
2019-10-22 22:59:13 -07:00
NOTE: `http://endpoint:port/path` is a placeholder value to indicate the URL format, please change this accordingly as per your configuration.
2018-11-02 18:40:08 -07:00
2019-10-22 22:59:13 -07:00
MinIO also honors environment variable for HTTP target logging as shown below, this setting will override the endpoint settings in the MinIO server config.
2018-11-02 18:40:08 -07:00
```
2019-12-04 15:32:37 -08:00
export MINIO_LOGGER_WEBHOOK_ENABLE_target1="on"
2019-11-13 17:38:05 -08:00
export MINIO_LOGGER_WEBHOOK_AUTH_TOKEN_target1="token"
export MINIO_LOGGER_WEBHOOK_ENDPOINT_target1=http://localhost:8080/minio/logs
2019-10-22 22:59:13 -07:00
minio server /mnt/data
2018-11-02 18:40:08 -07:00
```
2019-10-22 22:59:13 -07:00
## Audit Targets
Assuming `mc` is already [configured ](https://docs.min.io/docs/minio-client-quickstart-guide.html )
2018-11-02 18:40:08 -07:00
```
2019-11-13 17:38:05 -08:00
mc admin config get myminio/ audit_webhook
2021-03-01 22:49:13 +05:30
audit_webhook:name1 enable=off endpoint= auth_token= client_cert= client_key=
2018-11-02 18:40:08 -07:00
```
```
2019-12-06 13:53:51 -08:00
mc admin config set myminio audit_webhook:name1 auth_token="" endpoint="http://endpoint:port/path"
2019-10-22 22:59:13 -07:00
mc admin service restart myminio
2018-11-02 18:40:08 -07:00
```
2019-10-22 22:59:13 -07:00
NOTE: `http://endpoint:port/path` is a placeholder value to indicate the URL format, please change this accordingly as per your configuration.
MinIO also honors environment variable for HTTP target Audit logging as shown below, this setting will override the endpoint settings in the MinIO server config.
2018-11-02 18:40:08 -07:00
```
2019-12-04 15:32:37 -08:00
export MINIO_AUDIT_WEBHOOK_ENABLE_target1="on"
2019-11-13 17:38:05 -08:00
export MINIO_AUDIT_WEBHOOK_AUTH_TOKEN_target1="token"
export MINIO_AUDIT_WEBHOOK_ENDPOINT_target1=http://localhost:8080/minio/logs
2021-03-01 22:49:13 +05:30
export MINIO_AUDIT_WEBHOOK_CLIENT_CERT="/tmp/cert.pem"
export MINIO_AUDIT_WEBHOOK_CLIENT_KEY=="/tmp/key.pem"
2019-10-22 22:59:13 -07:00
minio server /mnt/data
2018-11-02 18:40:08 -07:00
```
Setting this environment variable automatically enables audit logging to the HTTP target. The audit logging is in JSON format as described below.
2020-05-20 07:04:02 +05:30
2021-01-26 22:21:51 +01:00
NOTE:
- `timeToFirstByte` and `timeToResponse` will be expressed in Nanoseconds.
2021-01-26 13:39:55 -08:00
- Additionally in the case of the erasure coded setup `tags.objectErasureMap` provides per object details about
- Pool number the object operation was performed on.
- Set number the object operation was performed on.
- The list of disks participating in this operation belong to the set.
2020-05-20 07:04:02 +05:30
2018-11-02 18:40:08 -07:00
```json
{
"version": "1",
2019-08-12 20:32:34 -07:00
"deploymentid": "bc0e4d1e-bacc-42eb-91ad-2d7f3eacfa8d",
"time": "2019-08-12T21:34:37.187817748Z",
2018-11-02 18:40:08 -07:00
"api": {
2018-11-21 20:03:24 -08:00
"name": "PutObject",
2019-08-12 20:32:34 -07:00
"bucket": "testbucket",
"object": "hosts",
2018-11-21 20:03:24 -08:00
"status": "OK",
2019-08-12 20:32:34 -07:00
"statusCode": 200,
2020-05-20 07:04:02 +05:30
"timeToFirstByte": "366333ns",
"timeToResponse": "16438202ns"
2018-11-02 18:40:08 -07:00
},
"remotehost": "127.0.0.1",
2019-08-12 20:32:34 -07:00
"requestID": "15BA4A72C0C70AFC",
"userAgent": "MinIO (linux; amd64) minio-go/v6.0.32 mc/2019-08-12T18:27:13Z",
2018-11-02 18:40:08 -07:00
"requestHeader": {
2019-08-12 20:32:34 -07:00
"Authorization": "AWS4-HMAC-SHA256 Credential=minio/20190812/us-east-1/s3/aws4_request,SignedHeaders=host;x-amz-content-sha256;x-amz-date;x-amz-decoded-content-length,Signature=d3f02a6aeddeb29b06e1773b6a8422112890981269f2463a26f307b60423177c",
"Content-Length": "686",
2018-11-21 20:03:24 -08:00
"Content-Type": "application/octet-stream",
2019-08-12 20:32:34 -07:00
"User-Agent": "MinIO (linux; amd64) minio-go/v6.0.32 mc/2019-08-12T18:27:13Z",
2018-11-21 20:03:24 -08:00
"X-Amz-Content-Sha256": "STREAMING-AWS4-HMAC-SHA256-PAYLOAD",
2019-08-12 20:32:34 -07:00
"X-Amz-Date": "20190812T213437Z",
"X-Amz-Decoded-Content-Length": "512"
2018-11-02 18:40:08 -07:00
},
"responseHeader": {
"Accept-Ranges": "bytes",
2019-08-12 20:32:34 -07:00
"Content-Length": "0",
2018-11-02 18:40:08 -07:00
"Content-Security-Policy": "block-all-mixed-content",
2019-08-12 20:32:34 -07:00
"ETag": "a414c889dc276457bd7175f974332cb0-1",
"Server": "MinIO/DEVELOPMENT.2019-08-12T21-28-07Z",
2018-11-02 18:40:08 -07:00
"Vary": "Origin",
2019-08-12 20:32:34 -07:00
"X-Amz-Request-Id": "15BA4A72C0C70AFC",
2018-11-02 18:40:08 -07:00
"X-Xss-Protection": "1; mode=block"
2021-01-26 22:21:51 +01:00
},
"tags": {
"objectErasureMap": {
2021-01-26 13:39:55 -08:00
"object": {
"poolId": 1,
"setId": 10,
"disks": [
"http://server01/mnt/pool1/disk01",
"http://server02/mnt/pool1/disk02",
"http://server03/mnt/pool1/disk03",
"http://server04/mnt/pool1/disk04"
2021-01-26 22:21:51 +01:00
]
2021-01-26 13:39:55 -08:00
}
2018-11-02 18:40:08 -07:00
}
}
```
## Explore Further
2019-04-09 11:39:42 -07:00
* [MinIO Quickstart Guide ](https://docs.min.io/docs/minio-quickstart-guide )
* [Configure MinIO Server with TLS ](https://docs.min.io/docs/how-to-secure-access-to-minio-server-with-tls )