example_maintenence_test.go 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // Copyright 2016 The etcd Authors
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package clientv3_test
  15. import (
  16. "fmt"
  17. "log"
  18. "golang.org/x/net/context"
  19. "github.com/coreos/etcd/clientv3"
  20. )
  21. func ExampleMaintenance_status() {
  22. for _, ep := range endpoints {
  23. cli, err := clientv3.New(clientv3.Config{
  24. Endpoints: []string{ep},
  25. DialTimeout: dialTimeout,
  26. })
  27. if err != nil {
  28. log.Fatal(err)
  29. }
  30. defer cli.Close()
  31. // resp, err := cli.Status(context.Background(), ep)
  32. //
  33. // or
  34. //
  35. mapi := clientv3.NewMaintenance(cli)
  36. resp, err := mapi.Status(context.Background(), ep)
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. fmt.Printf("endpoint: %s / IsLeader: %v\n", ep, resp.Header.MemberId == resp.Leader)
  41. }
  42. // endpoint: localhost:2379 / IsLeader: false
  43. // endpoint: localhost:22379 / IsLeader: false
  44. // endpoint: localhost:32379 / IsLeader: true
  45. }
  46. func ExampleMaintenance_defragment() {
  47. for _, ep := range endpoints {
  48. cli, err := clientv3.New(clientv3.Config{
  49. Endpoints: []string{ep},
  50. DialTimeout: dialTimeout,
  51. })
  52. if err != nil {
  53. log.Fatal(err)
  54. }
  55. defer cli.Close()
  56. if _, err = cli.Defragment(context.TODO(), ep); err != nil {
  57. log.Fatal(err)
  58. }
  59. }
  60. }