Skip to content

Commit

Permalink
etcdctl: use user specified timeout value for entire RPC
Browse files Browse the repository at this point in the history
etcdctl should use a user specified timeout value. This commit adds a
new option --total-timeout to the command. The value passed via this
option is used as a timeout value of entire RPC (API call of client).

Fixes etcd-io#3517
  • Loading branch information
mitake committed Sep 15, 2015
1 parent 6e7725c commit 5f5ce7b
Show file tree
Hide file tree
Showing 6 changed files with 25 additions and 25 deletions.
2 changes: 1 addition & 1 deletion etcdctl/command/auth_commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ func authEnableDisable(c *cli.Context, enable bool) {
os.Exit(1)
}
s := mustNewAuthAPI(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
var err error
if enable {
err = s.Enable(ctx)
Expand Down
13 changes: 6 additions & 7 deletions etcdctl/command/member_commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ import (

"github.com/coreos/etcd/Godeps/_workspace/src/github.com/codegangsta/cli"
"github.com/coreos/etcd/Godeps/_workspace/src/golang.org/x/net/context"
"github.com/coreos/etcd/client"
)

func NewMemberCommand() cli.Command {
Expand Down Expand Up @@ -59,7 +58,7 @@ func actionMemberList(c *cli.Context) {
os.Exit(1)
}
mAPI := mustNewMembersAPI(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
members, err := mAPI.List(ctx)
cancel()
if err != nil {
Expand All @@ -86,7 +85,7 @@ func actionMemberAdd(c *cli.Context) {
mAPI := mustNewMembersAPI(c)

url := args[1]
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
m, err := mAPI.Add(ctx, url)
cancel()
if err != nil {
Expand All @@ -98,7 +97,7 @@ func actionMemberAdd(c *cli.Context) {
newName := args[0]
fmt.Printf("Added member named %s with ID %s to cluster\n", newName, newID)

ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
members, err := mAPI.List(ctx)
cancel()
if err != nil {
Expand Down Expand Up @@ -133,7 +132,7 @@ func actionMemberRemove(c *cli.Context) {

mAPI := mustNewMembersAPI(c)
// Get the list of members.
listctx, listCancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
listctx, listCancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
members, err := mAPI.List(listctx)
listCancel()
if err != nil {
Expand All @@ -158,7 +157,7 @@ func actionMemberRemove(c *cli.Context) {
}

// Actually attempt to remove the member.
ctx, removeCancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, removeCancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err = mAPI.Remove(ctx, removalID)
removeCancel()
if err != nil {
Expand All @@ -180,7 +179,7 @@ func actionMemberUpdate(c *cli.Context) {

mid := args[0]
urls := args[1]
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err := mAPI.Update(ctx, mid, strings.Split(urls, ","))
cancel()
if err != nil {
Expand Down
14 changes: 7 additions & 7 deletions etcdctl/command/role_commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ func actionRoleList(c *cli.Context) {
os.Exit(1)
}
r := mustNewAuthRoleAPI(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
roles, err := r.ListRoles(ctx)
cancel()
if err != nil {
Expand All @@ -108,14 +108,14 @@ func actionRoleList(c *cli.Context) {

func actionRoleAdd(c *cli.Context) {
api, role := mustRoleAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
currentRole, err := api.GetRole(ctx, role)
cancel()
if currentRole != nil {
fmt.Fprintf(os.Stderr, "Role %s already exists\n", role)
os.Exit(1)
}
ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err = api.AddRole(ctx, role)
cancel()
if err != nil {
Expand All @@ -128,7 +128,7 @@ func actionRoleAdd(c *cli.Context) {

func actionRoleRemove(c *cli.Context) {
api, role := mustRoleAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err := api.RemoveRole(ctx, role)
cancel()
if err != nil {
Expand Down Expand Up @@ -182,14 +182,14 @@ func roleGrantRevoke(c *cli.Context, grant bool) {
}

api, role := mustRoleAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
currentRole, err := api.GetRole(ctx, role)
cancel()
if err != nil {
fmt.Fprintln(os.Stderr, err.Error())
os.Exit(1)
}
ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
var newRole *client.Role
if grant {
newRole, err = api.GrantRoleKV(ctx, role, []string{path}, permType)
Expand All @@ -215,7 +215,7 @@ func roleGrantRevoke(c *cli.Context, grant bool) {
func actionRoleGet(c *cli.Context) {
api, rolename := mustRoleAPIAndName(c)

ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
role, err := api.GetRole(ctx, rolename)
cancel()
if err != nil {
Expand Down
18 changes: 9 additions & 9 deletions etcdctl/command/user_commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ func actionUserList(c *cli.Context) {
os.Exit(1)
}
u := mustNewAuthUserAPI(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
users, err := u.ListUsers(ctx)
cancel()
if err != nil {
Expand All @@ -104,7 +104,7 @@ func actionUserList(c *cli.Context) {

func actionUserAdd(c *cli.Context) {
api, user := mustUserAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
currentUser, err := api.GetUser(ctx, user)
cancel()
if currentUser != nil {
Expand All @@ -116,7 +116,7 @@ func actionUserAdd(c *cli.Context) {
fmt.Fprintln(os.Stderr, "Error reading password:", err)
os.Exit(1)
}
ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err = api.AddUser(ctx, user, pass)
cancel()
if err != nil {
Expand All @@ -129,7 +129,7 @@ func actionUserAdd(c *cli.Context) {

func actionUserRemove(c *cli.Context) {
api, user := mustUserAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err := api.RemoveUser(ctx, user)
cancel()
if err != nil {
Expand All @@ -142,7 +142,7 @@ func actionUserRemove(c *cli.Context) {

func actionUserPasswd(c *cli.Context) {
api, user := mustUserAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
currentUser, err := api.GetUser(ctx, user)
cancel()
if currentUser == nil {
Expand All @@ -155,7 +155,7 @@ func actionUserPasswd(c *cli.Context) {
os.Exit(1)
}

ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
_, err = api.ChangePassword(ctx, user, pass)
cancel()
if err != nil {
Expand All @@ -182,15 +182,15 @@ func userGrantRevoke(c *cli.Context, grant bool) {
}

api, user := mustUserAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
currentUser, err := api.GetUser(ctx, user)
cancel()
if currentUser == nil {
fmt.Fprintln(os.Stderr, err.Error())
os.Exit(1)
}

ctx, cancel = context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel = context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
var newUser *client.User
if grant {
newUser, err = api.GrantUser(ctx, user, roles)
Expand All @@ -217,7 +217,7 @@ func userGrantRevoke(c *cli.Context, grant bool) {

func actionUserGet(c *cli.Context) {
api, username := mustUserAPIAndName(c)
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
user, err := api.GetUser(ctx, username)
cancel()
if err != nil {
Expand Down
2 changes: 1 addition & 1 deletion etcdctl/command/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@ func mustNewClient(c *cli.Context) client.Client {
if debug {
fmt.Fprintf(os.Stderr, "start to sync cluster using endpoints(%s)\n", strings.Join(hc.Endpoints(), ","))
}
ctx, cancel := context.WithTimeout(context.Background(), client.DefaultRequestTimeout)
ctx, cancel := context.WithTimeout(context.Background(), c.GlobalDuration("total-timeout"))
err := hc.Sync(ctx)
cancel()
if err != nil {
Expand Down
1 change: 1 addition & 0 deletions etcdctl/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ func main() {
cli.StringFlag{Name: "ca-file", Value: "", Usage: "verify certificates of HTTPS-enabled servers using this CA bundle"},
cli.StringFlag{Name: "username, u", Value: "", Usage: "provide username[:password] and prompt if password is not supplied."},
cli.DurationFlag{Name: "timeout", Value: time.Second, Usage: "connection timeout per request"},
cli.DurationFlag{Name: "total-timeout", Value: time.Second * 5, Usage: "timeout of entire RPC execution"},
}
app.Commands = []cli.Command{
command.NewBackupCommand(),
Expand Down

0 comments on commit 5f5ce7b

Please sign in to comment.