astro-run-remote-runner
is an extension of astro-run that allows runners to act as remote services and lets astro-run
act as a client to connect via gRPC requests. The remote runner streams runtime logs, events, etc. to the client using streams.
Add astro-run
and astro-run-remote-runner
as dependencies in your Cargo.toml
:
toml
[dependencies]
astro-run = "0.1"
astro-run-remote-runner = "0.1"
```rust use astrorun::{stream, Context, Result, RunResult}; use astrorunremoterunner::AstroRunRemoteRunnerServer;
// Simulated implementation of a Runner struct Runner {}
impl Runner { fn new() -> Self { Runner {} } }
impl astrorun::Runner for Runner { fn run(&self, ctx: Context) -> astrorun::RunResponse { let (tx, rx) = stream();
tx.log(ctx.command.run);
tx.end(RunResult::Succeeded);
Ok(rx)
} }
async fn main() -> Result<()> { let runner = Runner::new();
let runner_server = AstroRunRemoteRunnerServer::builder() .runner(runner) .build() .unwrap();
runner_server.serve("127.0.0.1:5002").await.unwrap();
Ok(()) } ```
```rust use astrorun::{AstroRun, Result, Workflow}; use astrorunremoterunner::AstroRunRemoteRunnerClient;
async fn main() -> Result<()> { let client_runner = AstroRunRemoteRunnerClient::builder().build().unwrap();
let mut clonedclientrunner = clientrunner.clone(); let handle = tokio::task::spawn(async move { // Run the client runner in background clonedclient_runner .start(vec!["http://127.0.0.1:5002"]) .await .unwrap(); });
let astrorun = AstroRun::builder().runner(clientrunner).build();
let workflow = r#" jobs: job-id: steps: - run: Hello World "#;
let workflow = Workflow::builder() .config(workflow) .build(&astro_run) .unwrap();
// Create a new execution context let ctx = astrorun.executioncontext().build();
// Run workflow let _res = workflow.run(ctx).await;
// Wait for the client runner to finish handle.await.unwrap();
Ok(()) } ```
In the above example, you can replace the runner with a specific implementation from astro-runner.