example_lease_test.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. // Copyright 2016 CoreOS, Inc.
  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. "github.com/coreos/etcd/Godeps/_workspace/src/golang.org/x/net/context"
  19. "github.com/coreos/etcd/clientv3"
  20. "github.com/coreos/etcd/lease"
  21. )
  22. func ExampleLease_create() {
  23. cli, err := clientv3.New(clientv3.Config{
  24. Endpoints: endpoints,
  25. DialTimeout: dialTimeout,
  26. })
  27. if err != nil {
  28. log.Fatal(err)
  29. }
  30. defer cli.Close()
  31. kvc := clientv3.NewKV(cli)
  32. lapi := clientv3.NewLease(cli)
  33. defer lapi.Close()
  34. // minimum lease TTL is 5-second
  35. resp, err := lapi.Create(context.TODO(), 5)
  36. if err != nil {
  37. log.Fatal(err)
  38. }
  39. // after 5 seconds, the key 'foo' will be removed
  40. _, err = kvc.Put(context.TODO(), "foo", "bar", clientv3.WithLease(lease.LeaseID(resp.ID)))
  41. if err != nil {
  42. log.Fatal(err)
  43. }
  44. }
  45. func ExampleLease_revoke() {
  46. cli, err := clientv3.New(clientv3.Config{
  47. Endpoints: endpoints,
  48. DialTimeout: dialTimeout,
  49. })
  50. if err != nil {
  51. log.Fatal(err)
  52. }
  53. defer cli.Close()
  54. kvc := clientv3.NewKV(cli)
  55. lapi := clientv3.NewLease(cli)
  56. defer lapi.Close()
  57. resp, err := lapi.Create(context.TODO(), 5)
  58. if err != nil {
  59. log.Fatal(err)
  60. }
  61. _, err = kvc.Put(context.TODO(), "foo", "bar", clientv3.WithLease(lease.LeaseID(resp.ID)))
  62. if err != nil {
  63. log.Fatal(err)
  64. }
  65. // revoking lease expires the key attached to its lease ID
  66. _, err = lapi.Revoke(context.TODO(), lease.LeaseID(resp.ID))
  67. if err != nil {
  68. log.Fatal(err)
  69. }
  70. gresp, err := kvc.Get(context.TODO(), "foo")
  71. if err != nil {
  72. log.Fatal(err)
  73. }
  74. fmt.Println("number of keys:", len(gresp.Kvs))
  75. // number of keys: 0
  76. }
  77. func ExampleLease_keepAlive() {
  78. cli, err := clientv3.New(clientv3.Config{
  79. Endpoints: endpoints,
  80. DialTimeout: dialTimeout,
  81. })
  82. if err != nil {
  83. log.Fatal(err)
  84. }
  85. defer cli.Close()
  86. kvc := clientv3.NewKV(cli)
  87. lapi := clientv3.NewLease(cli)
  88. defer lapi.Close()
  89. resp, err := lapi.Create(context.TODO(), 5)
  90. if err != nil {
  91. log.Fatal(err)
  92. }
  93. _, err = kvc.Put(context.TODO(), "foo", "bar", clientv3.WithLease(lease.LeaseID(resp.ID)))
  94. if err != nil {
  95. log.Fatal(err)
  96. }
  97. // the key 'foo' will be kept forever
  98. _, err = lapi.KeepAlive(context.TODO(), lease.LeaseID(resp.ID))
  99. if err != nil {
  100. log.Fatal(err)
  101. }
  102. }
  103. func ExampleLease_keepAliveOnce() {
  104. cli, err := clientv3.New(clientv3.Config{
  105. Endpoints: endpoints,
  106. DialTimeout: dialTimeout,
  107. })
  108. if err != nil {
  109. log.Fatal(err)
  110. }
  111. defer cli.Close()
  112. kvc := clientv3.NewKV(cli)
  113. lapi := clientv3.NewLease(cli)
  114. defer lapi.Close()
  115. resp, err := lapi.Create(context.TODO(), 5)
  116. if err != nil {
  117. log.Fatal(err)
  118. }
  119. _, err = kvc.Put(context.TODO(), "foo", "bar", clientv3.WithLease(lease.LeaseID(resp.ID)))
  120. if err != nil {
  121. log.Fatal(err)
  122. }
  123. // to renew the lease only once
  124. _, err = lapi.KeepAliveOnce(context.TODO(), lease.LeaseID(resp.ID))
  125. if err != nil {
  126. log.Fatal(err)
  127. }
  128. }