R/launcher-functions.R

Defines functions launcherControlJob launcherSubmitR launcherSubmitJob launcherNfsMount launcherHostMount launcherResourceLimit launcherPlacementConstraint launcherContainer launcherConfig launcherGetJob launcherGetJobs launcherAvailable launcherGetInfo

Documented in launcherAvailable launcherConfig launcherContainer launcherControlJob launcherGetInfo launcherGetJob launcherGetJobs launcherHostMount launcherNfsMount launcherPlacementConstraint launcherResourceLimit launcherSubmitJob launcherSubmitR

#' Retrieve Workbench Launcher Information
#'
#' Retrieve information about the Workbench launcher, as well as the different clusters
#' that the launcher has been configured to use.
#'
#' @family job-launcher functionality
#' @export
launcherGetInfo <- function() {
  callLauncherFun("launcher.getInfo")
}

#' Check if Workbench Launcher is Available
#'
#' Check if the Workbench launcher is available and configured to support
#' Workbench jobs; that is, jobs normally launched by the user through
#' the RStudio IDE's user interface.
#'
#' @family job-launcher functionality
#' @export
launcherAvailable <- function() {
  callLauncherFun("launcher.jobsFeatureAvailable")
}

#' Retrieve Workbench Job Information
#'
#' Retrieve information on Workbench jobs.
#'
#' @param statuses Return only jobs whose status matches one of `statuses`.
#'   Valid statuses are: Pending, Running, Suspended, Failed, Finished, Killed,
#'   Canceled. When `NULL`, all jobs are returned.
#'
#' @param fields Return a subset of fields associated with each job object.
#'   When `NULL`, all fields associated with a particular job are returned.
#'
#' @param includeSessions Boolean; include jobs which are also operating
#'   as RStudio R sessions?
#'
#' @param tags An optional set of tags. Only jobs that have been assigned one
#'   of these requested tags will be returned.
#'
#' @family job-launcher functionality
#' @export
launcherGetJobs <- function(statuses = NULL,
                            fields = NULL,
                            tags = NULL,
                            includeSessions = FALSE)
{
  callLauncherFun("launcher.getJobs",
                  statuses = statuses,
                  fields = fields,
                  tags = tags,
                  includeSessions = includeSessions)
}



#' Retrieve Workbench Job Information
#' 
#' Retrieve information on a Workbench job with id \code{jobId}.
#' 
#' 
#' @param jobId The id of a Workbench job.
#' 
#' @family job-launcher functionality
#' @export
launcherGetJob <- function(jobId) {
  callLauncherFun("launcher.getJob",
                  jobId = jobId)
}



#' Define a Workbench Launcher Configuration
#' 
#' Define a Workbench launcher configuration, suitable for use with the \code{config}
#' argument to \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}.
#' 
#' 
#' @param name The name of the launcher configuration.
#' 
#' @param value The configuration value. Must either be an integer, float, or
#'   string.
#'   
#' @family job-launcher functionality
#' @export
launcherConfig <- function(name, value = NULL)
{
  valueType <- if (is.integer(value))
    "int"
  else if (is.double(value))
    "float"
  else if (is.character(value))
    "string"

  value <- format(value)

  callLauncherFun("launcher.newConfig",
                  name = name,
                  value = value,
                  valueType = valueType)
}



#' Define a Workbench Launcher Container
#' 
#' Define a launcher container, suitable for use with the \code{container}
#' argument to \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}.
#' 
#' 
#' @param image The container image to use.
#' 
#' @param runAsUserId The user id to run as within the container. Defaults to
#'   the container-specified user.
#'   
#' @param runAsGroupId The group id to run as within the container. Defaults to
#'   the container-specified group.
#'   
#' @family job-launcher functionality
#' @export
launcherContainer <- function(image,
                              runAsUserId = NULL,
                              runAsGroupId = NULL)
{
  if (is.numeric(runAsUserId))
    runAsUserId <- as.integer(runAsUserId)
  
  if (is.null(runAsGroupId))
    runAsGroupId <- as.integer(runAsGroupId)
  
  callLauncherFun("launcher.newContainer",
                  image = image,
                  runAsUserId = runAsUserId,
                  runAsGroupId = runAsGroupId)
}



#' Define a Workbench Launcher Placement Constraint
#' 
#' Define a launcher placement constraint, suitable for use with the
#' \code{placementConstraints} argument to
#' \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}.
#' 
#' 
#' @param name The name of this placement constraint.
#' 
#' @param value The value of the constraint. A job will only be placed on a
#'   requested node if the requested placement constraint is present.
#'   
#' @family job-launcher functionality
#' @export
launcherPlacementConstraint <- function(name,
                                        value = NULL)
{
  callLauncherFun("launcher.newPlacementConstraint",
                  name = name,
                  value = value)
}



#' Define a Workbench Launcher Resource Limit
#' 
#' Define a launcher resource limit, suitable for use with the
#' \code{resourceLimits} argument to
#' \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}.
#' 
#' 
#' @param type The resource limit type. Must be one of cpuCount, cpuFrequency,
#'   cpuSet, cpuTime, memory, memorySwap. Different launcher plugins may support
#'   different subsets of these resource limit types; please consult the plugin
#'   documentation to learn which limits are supported.
#'   
#' @param value The formatted value of the requested limit.
#' 
#' @family job-launcher functionality
#' @export
launcherResourceLimit <- function(type, value) {
  callLauncherFun("launcher.newResourceLimit",
                  type = type,
                  value = value)
}



#' Define a Workbench Launcher Host Mount
#' 
#' Define a launcher host mount, suitable for use with the \code{mounts}
#' argument to \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}. This can
#' be used to mount a path from the host into the generated container.
#' 
#' @param path The host path to be mounted.
#' 
#' @param mountPath The destination path for the mount in the container.
#' 
#' @param readOnly Boolean; should the path be mounted read-only?
#' 
#' @family job-launcher functionality
#' @export launcherHostMount
launcherHostMount <- function(path,
                              mountPath,
                              readOnly = TRUE)
{
  callLauncherFun("launcher.newHostMount",
                  path = path,
                  mountPath = mountPath,
                  readOnly = readOnly)
}



#' Define a Workbench Launcher NFS Mount
#' 
#' Define a launcher NFS mount, suitable for use with the \code{mounts}
#' argument to \code{\link[=launcherSubmitJob]{launcherSubmitJob()}}. This can
#' be used to mount a path from a networked filesystem into a newly generated
#' container.
#' 
#' 
#' @param host The host name, or IP address, of the NFS server.
#' 
#' @param path The NFS path to be mounted.
#' 
#' @param mountPath The destination path for the mount in the container.
#' 
#' @param readOnly Boolean; should the path be mounted read-only?
#' 
#' @family job-launcher functionality
#' @export launcherNfsMount
launcherNfsMount <- function(host,
                             path,
                             mountPath,
                             readOnly = TRUE)
{
  callLauncherFun("launcher.newNfsMount",
                  host = host,
                  path = path,
                  mountPath = mountPath,
                  readOnly = readOnly)
}



#' Submit a Workbench Job
#' 
#' Submit a Workbench job. See
#' <https://docs.posit.co/job-launcher/latest/index.html> for more
#' information.
#' 
#' 
#' @param name A descriptive name to assign to the job.
#' 
#' @param cluster The name of the cluster this job should be submitted to.
#' 
#' @param tags A set of user-defined tags, used for searching and querying
#'   jobs.
#' @param command The command to run within the job. This is executed via the
#'   system shell. Only one of command or exe should be specified.
#'   
#' @param exe The (fully pathed) executable to run within the job. Only one of
#'   \code{command} or \code{exe} should be specified.
#'   
#' @param args An array of arguments to pass to the command / executable.
#' 
#' @param environment A list of environment variables to be set for processes
#'   launched with this job.
#'   
#' @param stdin Data to be written to stdin when the job process is launched.
#' 
#' @param stdoutFile The file used for the job's generated standard output. Not
#'   all launcher plugins support this parameter.
#'   
#' @param stderrFile The file used for the job's generated standard error. Not
#'   all launcher plugins support this parameter.
#'   
#' @param workingDirectory The working directory to be used by the command /
#'   executable associated with this job.
#'   
#' @param host The host that the job is running on, or the desired host during
#'   job submission.
#'   
#' @param container The container to be used for launched jobs.
#' 
#' @param exposedPorts The ports that are exposed by services running on a
#'   container. Only applicable to systems that support containers.
#'   
#' @param mounts A list of mount points. See
#'   \code{\link[=launcherHostMount]{launcherHostMount()}} and
#'   \code{\link[=launcherNfsMount]{launcherNfsMount()}} for more information.
#' 
#' @param placementConstraints A list of placement constraints. See
#'   \code{\link[=launcherPlacementConstraint]{launcherPlacementConstraint()}}
#'   for more information.
#'   
#' @param resourceLimits A list of resource limits. See
#'   \code{\link[=launcherResourceLimit]{launcherResourceLimit()}} for more
#'   information.
#'   
#' @param queues A list of available submission queues for the cluster. Only
#'   applicable to batch systems like LSF.
#'   
#' @param config A list of cluster-specific configuration options. See
#'   \code{\link[=launcherConfig]{launcherConfig()}} for more information.
#'   
#' @param user The user-name of the job owner.
#' 
#' @param applyConfigSettings Apply server-configured mounts, exposedPorts, and
#'   environment, in addition to any specified in this call.
#'   
#' @family job-launcher functionality
#' @export
launcherSubmitJob <- function(name,
                              cluster = "Local",
                              tags = NULL,

                              command = NULL,
                              exe = NULL,
                              args = NULL,
                              environment = NULL,
                              stdin = NULL,
                              stdoutFile = NULL,
                              stderrFile = NULL,
                              workingDirectory = NULL,

                              host = NULL,
                              container = NULL,
                              exposedPorts = NULL,
                              mounts = NULL,
                              placementConstraints = NULL,
                              resourceLimits = NULL,
                              queues = NULL,

                              config = NULL,
                              user = Sys.getenv("USER"),

                              applyConfigSettings = TRUE)
{
  callLauncherFun("launcher.submitJob",
                  args = args,
                  cluster = cluster,
                  command = command,
                  config = config,
                  container = container,
                  environment = environment,
                  exe = exe,
                  exposedPorts = exposedPorts,
                  host = host,
                  mounts = mounts,
                  name = name,
                  placementConstraints = placementConstraints,
                  queues = queues,
                  resourceLimits = resourceLimits,
                  stderrFile = stderrFile,
                  stdin = stdin,
                  stdoutFile = stdoutFile,
                  tags = tags,
                  user = user,
                  workingDirectory = workingDirectory,
                  applyConfigSettings = applyConfigSettings)
}



#' Execute an R Script as a Workbench Job
#' 
#' Convenience function for running an R script as a Workbench job using
#' whichever R is found on the path in the Workbench launcher cluster.
#' 
#' See \code{\link[=launcherSubmitJob]{launcherSubmitJob()}} for running jobs
#' with full control over command, environment, and so forth.
#' 
#' @param script Fully qualified path of R script. Must be a path that is
#'   available in the job container (if using containerized job cluster such as
#'   Kubernetes).
#' 
#' @param cluster The name of the cluster this job should be submitted to.
#' 
#' @param container The container to be used for launched jobs.
#' 
#' @family job-launcher functionality
#' @export
launcherSubmitR <- function(script,
                            cluster = "Local",
                            container = NULL)
{
  # don't proactively check for existence of the script; possible the supplied
  # path only resolves correctly in the job cluster
  scriptPath <- path.expand(script)
  scriptFile <- basename(scriptPath)
  scriptArg <- paste("-f", scriptPath)
  jobTag <- paste("rstudio-r-script-job", scriptFile, sep = ":")
  callLauncherFun("launcher.submitJob",
                  args = c("--slave", "--no-save", "--no-restore", scriptArg),
                  cluster = cluster,
                  command = "R",
                  container = container,
                  name = scriptFile,
                  tags = c(jobTag),
                  applyConfigSettings = TRUE)
}



#' Interact with (Control) a Workbench Job
#' 
#' Interact with a Workbench job.
#' 
#' 
#' @param jobId The job id.
#' 
#' @param operation The operation to execute. The operation should be one of
#'   \code{c("suspend", "resume", "stop", "kill", "cancel")}. Note that different
#'   launcher plugins support different subsets of these operations -- consult
#'   your launcher plugin documentation to see which operations are supported.
#'
#' @family job-launcher functionality
#' @export
launcherControlJob <- function(jobId,
                               operation = c("suspend", "resume", "stop", "kill", "cancel"))
{
  callLauncherFun("launcher.controlJob",
                  jobId = jobId,
                  operation = operation)
}

Try the rstudioapi package in your browser

Any scripts or data that you put into this service are public.

rstudioapi documentation built on Oct. 23, 2024, 1:07 a.m.