github.com/minio/madmin-go/v2@v2.2.1/examples/service-trace.go (about)

     1  //go:build ignore
     2  // +build ignore
     3  
     4  // Copyright (c) 2015-2022 MinIO, Inc.
     5  //
     6  // This file is part of MinIO Object Storage stack
     7  //
     8  // This program is free software: you can redistribute it and/or modify
     9  // it under the terms of the GNU Affero General Public License as
    10  // published by the Free Software Foundation, either version 3 of the
    11  // License, or (at your option) any later version.
    12  //
    13  // This program is distributed in the hope that it will be useful,
    14  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    15  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    16  // GNU Affero General Public License for more details.
    17  //
    18  // You should have received a copy of the GNU Affero General Public License
    19  // along with this program. If not, see <http://www.gnu.org/licenses/>.
    20  //
    21  
    22  package main
    23  
    24  import (
    25  	"context"
    26  	"fmt"
    27  	"log"
    28  
    29  	"github.com/minio/madmin-go/v2"
    30  )
    31  
    32  func main() {
    33  	// Note: YOUR-ACCESSKEYID, YOUR-SECRETACCESSKEY are
    34  	// dummy values, please replace them with original values.
    35  
    36  	// API requests are secure (HTTPS) if secure=true and insecure (HTTP) otherwise.
    37  	// New returns an MinIO Admin client object.
    38  	madmClnt, err := madmin.New("your-minio.example.com:9000", "YOUR-ACCESSKEYID", "YOUR-SECRETACCESSKEY", true)
    39  	if err != nil {
    40  		log.Fatalln(err)
    41  	}
    42  
    43  	// Start listening on all http trace activity from all servers in the minio cluster.
    44  	traceCh := madmClnt.ServiceTrace(context.Background(), madmin.ServiceTraceOpts{
    45  		S3:        true,
    46  		Internal:  true,
    47  		Storage:   true,
    48  		OS:        true,
    49  		Threshold: 0,
    50  	})
    51  	for traceInfo := range traceCh {
    52  		if traceInfo.Err != nil {
    53  			fmt.Println(traceInfo.Err)
    54  		}
    55  		fmt.Println(traceInfo)
    56  	}
    57  }