knitr::opts_chunk$set( eval = FALSE, collapse = TRUE, comment = "#>", fig.path = "man/figures/README-", out.width = "100%" )
In computationally demanding analysis projects, statisticians and data scientists asynchronously deploy long-running tasks to distributed systems, ranging from traditional clusters to cloud services. The NNG-powered mirai
R package is a sleek and sophisticated scheduler that efficiently processes these intense workloads. The crew
package extends mirai
with a unifying interface for third-party worker launchers. Inspiration also comes from packages future
, rrq
, clustermq
, and batchtools
.
Type | Source | Command
---|---|---
Release | CRAN | install.packages("crew")
Development | GitHub | remotes::install_github("wlandau/crew")
Development | R-universe | install.packages("crew", repos = "https://wlandau.r-universe.dev")
The documentation website at https://wlandau.github.io/crew/ includes a function reference and tutorial vignettes linked below.
crew
crew
The crew
package has unavoidable risks, and the user is responsible for safety, security, and computational resources. Please read the software license and the vignette about specific known risks.
mirai
: a powerful R framework for asynchronous tasks built on NNG. The purpose of crew
is to extend mirai
to different computing platforms for distributed workers.rrq
: a task queue for R based on Redis.rrqueue
: predecessor of rrq
.clustermq
: sends R function calls as jobs to computing clusters.future
: a unified interface for asynchronous evaluation of single tasks and map-reduce calls on a wide variety of backend technologies.batchtools
: tools for computation on batch systems.targets
: a Make-like pipeline tool for R.later
: delayed evaluation of synchronous tasks.promises
: minimally-invasive asynchronous programming for a small number of tasks within Shiny apps.callr
: initiates R process from other R processes.The crew
package incorporates insightful ideas from the following people.
mirai
and nanonext
and graciously accommodated the complicated and demanding feature requests that made crew
possible.rrq
.callr
and wrote an edifying blog post on implementing task queues.workers
prototype, an initial effort that led directly to the current implementation of crew
. crew
would not exist without Kirill's insights about orchestration models for R processes.future
package ecosystem demonstrates the incredible power of a consistent R interface on top of a varying collection of high-performance computing technologies.clustermq
package supports efficient high-performance computing on traditional clusters, and it demonstrates the value of a central R6
object to manage an entire collection of persistent workers.paws
R package is a powerful interface to Amazon Web Services, and the documentation clearly communicates the capabilities and limitations of AWS to R users.paws
with David Kretch.lambdr
package establishes a helpful pattern to submit and collect AWS Lambda jobs from R.googleCloudStorageR
and googleCloudRunner
, and he started the conversation around helping targets
submit jobs to Google Cloud Run.crew
with promises
.Please note that the crew
project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.
To cite package ‘crew’ in publications use: Landau WM (2023). _crew: A Distributed Worker Launcher Framework_. https://wlandau.github.io/crew/, https://github.com/wlandau/crew. A BibTeX entry for LaTeX users is @Manual{, title = {crew: A Distributed Worker Launcher Framework}, author = {William Michael Landau}, year = {2023}, note = {https://wlandau.github.io/crew/, https://github.com/wlandau/crew}, }
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.