1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00

Merge pull request #34235 from aaronlehmann/recursive-rlock

cluster: Avoid recursive RLock
This commit is contained in:
Victor Vieux 2017-07-24 15:50:22 -07:00 committed by GitHub
commit 92b3dcb601

View file

@ -11,57 +11,50 @@ import (
// GetTasks returns a list of tasks matching the filter options. // GetTasks returns a list of tasks matching the filter options.
func (c *Cluster) GetTasks(options apitypes.TaskListOptions) ([]types.Task, error) { func (c *Cluster) GetTasks(options apitypes.TaskListOptions) ([]types.Task, error) {
c.mu.RLock() var r *swarmapi.ListTasksResponse
defer c.mu.RUnlock()
state := c.currentNodeState() if err := c.lockedManagerAction(func(ctx context.Context, state nodeState) error {
if !state.IsActiveManager() { filterTransform := func(filter filters.Args) error {
return nil, c.errNoManager(state) if filter.Include("service") {
} serviceFilters := filter.Get("service")
for _, serviceFilter := range serviceFilters {
filterTransform := func(filter filters.Args) error { service, err := getService(ctx, state.controlClient, serviceFilter, false)
if filter.Include("service") { if err != nil {
serviceFilters := filter.Get("service") return err
for _, serviceFilter := range serviceFilters { }
service, err := c.GetService(serviceFilter, false) filter.Del("service", serviceFilter)
if err != nil { filter.Add("service", service.ID)
return err
} }
filter.Del("service", serviceFilter)
filter.Add("service", service.ID)
} }
} if filter.Include("node") {
if filter.Include("node") { nodeFilters := filter.Get("node")
nodeFilters := filter.Get("node") for _, nodeFilter := range nodeFilters {
for _, nodeFilter := range nodeFilters { node, err := getNode(ctx, state.controlClient, nodeFilter)
node, err := c.GetNode(nodeFilter) if err != nil {
if err != nil { return err
return err }
filter.Del("node", nodeFilter)
filter.Add("node", node.ID)
} }
filter.Del("node", nodeFilter)
filter.Add("node", node.ID)
} }
if !filter.Include("runtime") {
// default to only showing container tasks
filter.Add("runtime", "container")
filter.Add("runtime", "")
}
return nil
} }
if !filter.Include("runtime") {
// default to only showing container tasks filters, err := newListTasksFilters(options.Filters, filterTransform)
filter.Add("runtime", "container") if err != nil {
filter.Add("runtime", "") return err
} }
return nil
}
filters, err := newListTasksFilters(options.Filters, filterTransform) r, err = state.controlClient.ListTasks(
if err != nil { ctx,
return nil, err &swarmapi.ListTasksRequest{Filters: filters})
} return err
}); err != nil {
ctx, cancel := c.getRequestContext()
defer cancel()
r, err := state.controlClient.ListTasks(
ctx,
&swarmapi.ListTasksRequest{Filters: filters})
if err != nil {
return nil, err return nil, err
} }