Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ansible needs a native task timeout support #159

Closed
ssbarnea opened this issue Mar 13, 2019 · 4 comments
Closed

Ansible needs a native task timeout support #159

ssbarnea opened this issue Mar 13, 2019 · 4 comments

Comments

@ssbarnea
Copy link
Member

Proposal: native timeout support for tasks

Author: Sorin Sbarnea <@ssbarnea> IRC: zbr

Date: 2019-03-12

  • Status: New
  • Proposal type: core
  • Targeted release: 2.8
  • Associated PR: N/A
  • Estimated time to implement: ???

Motivation

The current use pattern is to run with async but this means adding at least one additional task for each task where you want to implement a timeout, it just does not scale at all, making playbooks more verbose, harder to read and debug.

We just need a simple way to declare a task failed if it exceeded an maximum runtime lenght, with a default of 0 which disables the timeout (backwards compatibe).

Problems

What problems exist that this proposal will solve?

Solution proposal

As seen in this example the module execution would be stopped if it exceeds 10s (seconds is the SI unit of measure for time). This would not be an argument for a specific module, it should apply to most modules.

    - shell: pause
      timeout: 10

Testing (optional)

TBH

Documentation (optional)

TBH

@jborean93
Copy link

The current use pattern is to run with async but this means adding at least one additional task for each task where you want to implement a timeout

Not sure what you mean, the below will run just like any other module and time out after 10 seconds, exactly the same as your example just with the async key.

- shell: pause
  async: 10

@ansiblejunky
Copy link

We have the command_timeout option in the ansible.cfg that controls the general timeout for commands:

# The command timeout value defines the amount of time to wait for a command
# or RPC call before timing out. The value for the command timeout must
# be less than the value of the persistent connection idle timeout (connect_timeout)
# The default value is 30 second.
command_timeout = 30

Also, for those modules that are more time-sensitive, they seem to have a timeout argument.

So I am not sure with these 2 points, whether we also need timeout as something standard for any task - which I would assume would override the ansible.cfg option? That could be dangerous though. You might grab a role from Galaxy or somewhere else that set some crazy timeout value on the task and then you run it and it doesn't run as expected.

@bcoca
Copy link
Member

bcoca commented Apr 17, 2020

@ansiblejunky command_timeout is not what it says it is, it is mostly another 'connection timeout' and it does not apply to all tasks, just those that are 'persistent' and use ansible-connection indirectly via selection of certain connection plugins (mostly related to networking appliances).

@bcoca
Copy link
Member

bcoca commented Jun 2, 2020

done ansible/ansible#69284

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants