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

Improve argument streaming for remote job execution (part 1) #1397

Open
wants to merge 19 commits into
base: devel
Choose a base branch
from

Conversation

Shrews
Copy link
Contributor

@Shrews Shrews commented Sep 24, 2024

Changes to Remote Job Execution Argument Streaming

Reason For Change

Remote job execution involves a Transmitter node streaming the job keyword arguments as a JSON object to a Worker node. Adding new keyword arguments to the interface.run() or interface.run_async() methods can cause errors within the remote job streaming interface when an older Worker node receives the new, unrecognized keyword argument from a newer Transmitter node (worker/transmitter version mismatch).

For more background information on the streaming process, see this page of the documentation.

Fixes #1324

Solution

The total fix will require a multi-stage solution:

  • First stage of the solution (implemented in this PR) will have the Transmitter process stream only keyword arguments that are actually specified and have a value different from their default value. This does not fix the case when a new keyword argument is introduced and used with a non-default value, but does fix older Worker nodes from failing when the new keyword is not used since the new keyword will not be sent in the argument stream.
  • The second stage (not implemented here) will have the Worker process gracefully fail on unrecognized keywords.

Change Details

  • RunnerConfig object will become the main source for supplying job parameters instead of kwargs.
    • Turns the BaseConfig and RunnerConfig classes into dataclasses to allow us to properly define arguments, their data types, and their default values.
      • Since the __init__() method is now autogenerated, care is taken to keep the same name for a few class attributes that did not have the same name as their argument. This is done through the use of Python class property decorators. Internally, the attribute is referenced by the non-alias version.
    • By default, all RunnerConfig attributes are streamable to a Worker. Attributes that are NEVER streamable will have explicit dataclass metadata to mark it as such (example, field(metadata={MetaValues.TRANSMIT: False})).
  • interface.run() and interface.run_async() changed to accept a RunnerConfig object.
    • Can now be used in one of two ways:
      • Old-style: method takes only kwargs parameters; backwards compatible
      • New-style: method takes a RunnerConfig object and a few select parameters.
    • Non-public methods lower in the call hierarchy (init_runner(), dump_artifacts(), etc) are modified to allow for receiving a RunnerConfig object instead of keyword arguments.
  • Transmitter modified to query the RunnerConfig object to retrieve the keyword arguments to transmit.
  • Includes a new porting guide in the documentation describing the change.
    • Parameter docs for interface.run() method moved to BaseConfig and RunnerConfig docs.

TODO

  • Testing with Controller?

@Shrews Shrews force-pushed the kwarg-protocol-3 branch 3 times, most recently from 1931b5f to 7f88c89 Compare September 24, 2024 19:32
@Shrews Shrews force-pushed the kwarg-protocol-3 branch 2 times, most recently from 2eadf31 to 61cb018 Compare October 14, 2024 16:45
@github-actions github-actions bot added the docs Changes to documentation label Oct 14, 2024
@Shrews Shrews force-pushed the kwarg-protocol-3 branch 2 times, most recently from 5e28eea to 5fbae20 Compare October 14, 2024 18:36
@Shrews Shrews changed the title Keyword argument protocol - config dataclasses Improve argument streaming for remote job execution (part 1) Oct 14, 2024
@Shrews Shrews force-pushed the kwarg-protocol-3 branch 5 times, most recently from 15fe5e5 to 9be5cd1 Compare October 17, 2024 18:48
@Shrews Shrews force-pushed the kwarg-protocol-3 branch 4 times, most recently from d599164 to 9ef249d Compare November 5, 2024 19:33
@Shrews Shrews force-pushed the kwarg-protocol-3 branch 4 times, most recently from 630fc50 to 728b9ff Compare November 18, 2024 15:13
Copy link
Member

@nitzmahone nitzmahone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Didn't get all the way through the fine-toothed comb review before I ran out of days, but looking great- I think this solves the most important parts of the internal arg-splatting problem well.

src/ansible_runner/config/_base.py Show resolved Hide resolved
src/ansible_runner/config/runner.py Outdated Show resolved Hide resolved
src/ansible_runner/config/runner.py Show resolved Hide resolved
@Shrews Shrews marked this pull request as ready for review January 13, 2025 20:06
@Shrews Shrews requested a review from a team as a code owner January 13, 2025 20:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
docs Changes to documentation
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Account for streaming payload splatting version incompatibilities
2 participants