cctools
|
A manager-worker library. More...
Go to the source code of this file.
Data Structures | |
struct | work_queue_task |
A task description. More... | |
struct | work_queue_stats |
Statistics describing a work queue. More... | |
Macros | |
#define | WORK_QUEUE_DEFAULT_PORT 9123 |
Default Work Queue port number. More... | |
#define | WORK_QUEUE_RANDOM_PORT 0 |
Indicates that any port may be chosen. More... | |
#define | WORK_QUEUE_WAITFORTASK -1 |
Timeout value to wait for a task to complete before returning. More... | |
#define | WORK_QUEUE_DEFAULT_KEEPALIVE_INTERVAL 120 |
Default value for Work Queue keepalive interval in seconds. More... | |
#define | WORK_QUEUE_DEFAULT_KEEPALIVE_TIMEOUT 30 |
Default value for Work Queue keepalive timeout in seconds. More... | |
Functions | |
Functions - Tasks | |
struct work_queue_task * | work_queue_task_create (const char *full_command) |
Create a new task object. More... | |
struct work_queue_task * | work_queue_task_clone (const struct work_queue_task *task) |
Create a copy of a task Create a functionally identical copy of a work_queue_task that can be re-submitted via work_queue_submit. More... | |
void | work_queue_task_specify_command (struct work_queue_task *t, const char *cmd) |
Indicate the command to be executed. More... | |
int | work_queue_task_specify_file (struct work_queue_task *t, const char *local_name, const char *remote_name, work_queue_file_type_t type, work_queue_file_flags_t flags) |
Add a file to a task. More... | |
int | work_queue_task_specify_file_piece (struct work_queue_task *t, const char *local_name, const char *remote_name, off_t start_byte, off_t end_byte, work_queue_file_type_t type, work_queue_file_flags_t flags) |
Add a file piece to a task. More... | |
int | work_queue_task_specify_buffer (struct work_queue_task *t, const char *data, int length, const char *remote_name, work_queue_file_flags_t flags) |
Add an input buffer to a task. More... | |
int | work_queue_task_specify_directory (struct work_queue_task *t, const char *local_name, const char *remote_name, work_queue_file_type_t type, work_queue_file_flags_t flags, int recursive) |
Add a directory to a task. More... | |
int | work_queue_task_specify_file_command (struct work_queue_task *t, const char *remote_name, const char *cmd, work_queue_file_type_t type, work_queue_file_flags_t flags) |
Gets/puts file at remote_name using cmd at worker. More... | |
void | work_queue_task_specify_max_retries (struct work_queue_task *t, int64_t max_retries) |
Specify the number of times this task is retried on worker errors. More... | |
void | work_queue_task_specify_memory (struct work_queue_task *t, int64_t memory) |
Specify the amount of disk space required by a task. More... | |
void | work_queue_task_specify_disk (struct work_queue_task *t, int64_t disk) |
Specify the amount of disk space required by a task. More... | |
void | work_queue_task_specify_cores (struct work_queue_task *t, int cores) |
Specify the number of cores required by a task. More... | |
void | work_queue_task_specify_gpus (struct work_queue_task *t, int gpus) |
Specify the number of gpus required by a task. More... | |
void | work_queue_task_specify_end_time (struct work_queue_task *t, int64_t useconds) |
Specify the maximum end time allowed for the task (in microseconds since the Epoch). More... | |
void | work_queue_task_specify_start_time_min (struct work_queue_task *t, int64_t useconds) |
Specify the minimum start time allowed for the task (in microseconds since the Epoch). More... | |
void | work_queue_task_specify_running_time (struct work_queue_task *t, int64_t useconds) |
Specify the maximum time (in microseconds) the task is allowed to run in a worker. More... | |
void | work_queue_task_specify_running_time_max (struct work_queue_task *t, int64_t seconds) |
Specify the maximum time (in seconds) the task is allowed to run in a worker. More... | |
void | work_queue_task_specify_running_time_min (struct work_queue_task *t, int64_t seconds) |
Specify the minimum time (in seconds) the task is expected to run in a worker. More... | |
void | work_queue_task_specify_tag (struct work_queue_task *t, const char *tag) |
Attach a user defined string tag to the task. More... | |
void | work_queue_task_specify_category (struct work_queue_task *t, const char *category) |
Label the task with the given category. More... | |
void | work_queue_task_specify_feature (struct work_queue_task *t, const char *name) |
Label the task with a user-defined feature. More... | |
void | work_queue_task_specify_priority (struct work_queue_task *t, double priority) |
Specify the priority of this task relative to others in the queue. More... | |
void | work_queue_task_specify_environment_variable (struct work_queue_task *t, const char *name, const char *value) |
Specify an environment variable to be added to the task. More... | |
void | work_queue_task_specify_algorithm (struct work_queue_task *t, work_queue_schedule_t algorithm) |
Select the scheduling algorithm for a single task. More... | |
void | work_queue_task_specify_monitor_output (struct work_queue_task *t, const char *monitor_output) |
Specify a custom name for the monitoring summary. More... | |
void | work_queue_task_delete (struct work_queue_task *t) |
Delete a task. More... | |
int | work_queue_specify_snapshot_file (struct work_queue_task *t, const char *monitor_snapshot_file) |
When monitoring, indicates a json-encoded file that instructs the monitor to take a snapshot of the task resources. More... | |
Functions - Queues | |
struct work_queue * | work_queue_create (int port) |
Create a new work queue. More... | |
struct work_queue * | work_queue_ssl_create (int port, const char *key, const char *cert) |
Create a new work queue using SSL. More... | |
int | work_queue_enable_monitoring (struct work_queue *q, char *monitor_output_directory, int watchdog) |
Enables resource monitoring on the give work queue. More... | |
int | work_queue_enable_monitoring_full (struct work_queue *q, char *monitor_output_directory, int watchdog) |
Enables resource monitoring on the give work queue. More... | |
int | work_queue_submit (struct work_queue *q, struct work_queue_task *t) |
Submit a task to a queue. More... | |
int | work_queue_specify_min_taskid (struct work_queue *q, int minid) |
Set the minimum taskid of future submitted tasks. More... | |
void | work_queue_block_host (struct work_queue *q, const char *hostname) |
Block workers in hostname from working for queue q. More... | |
void | work_queue_block_host_with_timeout (struct work_queue *q, const char *hostname, time_t seconds) |
Block workers in hostname from a queue, but remove block after timeout seconds. More... | |
void | work_queue_unblock_host (struct work_queue *q, const char *hostname) |
Unblock host from a queue. More... | |
void | work_queue_unblock_all (struct work_queue *q) |
Unblock all host. More... | |
void | work_queue_invalidate_cached_file (struct work_queue *q, const char *local_name, work_queue_file_t type) |
Invalidate cached file. More... | |
struct work_queue_task * | work_queue_wait (struct work_queue *q, int timeout) |
Wait for a task to complete. More... | |
struct work_queue_task * | work_queue_wait_for_tag (struct work_queue *q, const char *tag, int timeout) |
Wait for a task with a given task to complete. More... | |
int | work_queue_hungry (struct work_queue *q) |
Determine whether the queue is 'hungry' for more tasks. More... | |
int | work_queue_empty (struct work_queue *q) |
Determine whether the queue is empty. More... | |
int | work_queue_port (struct work_queue *q) |
Get the listening port of the queue. More... | |
void | work_queue_get_stats (struct work_queue *q, struct work_queue_stats *s) |
Get queue statistics (only from manager). More... | |
void | work_queue_get_stats_hierarchy (struct work_queue *q, struct work_queue_stats *s) |
Get statistics of the manager queue together with foremen information. More... | |
void | work_queue_get_stats_category (struct work_queue *q, const char *c, struct work_queue_stats *s) |
Get the task statistics for the given category. More... | |
char * | work_queue_status (struct work_queue *q, const char *request) |
Get queue information as json. More... | |
struct rmsummary ** | work_queue_workers_summary (struct work_queue *q) |
Summary data for all workers in buffer. More... | |
work_queue_task_state_t | work_queue_task_state (struct work_queue *q, int taskid) |
Get the current state of the task. More... | |
void | work_queue_set_bandwidth_limit (struct work_queue *q, const char *bandwidth) |
Limit the queue bandwidth when transferring files to and from workers. More... | |
double | work_queue_get_effective_bandwidth (struct work_queue *q) |
Get current queue bandwidth. More... | |
char * | work_queue_get_worker_summary (struct work_queue *q) |
Summarize workers. More... | |
int | work_queue_activate_fast_abort (struct work_queue *q, double multiplier) |
Turn on or off fast abort functionality for a given queue for tasks without an explicit category. More... | |
int | work_queue_activate_fast_abort_category (struct work_queue *q, const char *category, double multiplier) |
Turn on or off fast abort functionality for a given category. More... | |
int | work_queue_specify_draining_by_hostname (struct work_queue *q, const char *hostname, int drain_flag) |
Set the draining mode per worker hostname. More... | |
int | work_queue_specify_category_mode (struct work_queue *q, const char *category, work_queue_category_mode_t mode) |
Turn on or off first-allocation labeling for a given category. More... | |
int | work_queue_enable_category_resource (struct work_queue *q, const char *category, const char *resource, int autolabel) |
Turn on or off first-allocation labeling for a given category and resource. More... | |
void | work_queue_specify_algorithm (struct work_queue *q, work_queue_schedule_t algorithm) |
Change the worker selection algorithm. More... | |
const char * | work_queue_name (struct work_queue *q) |
Get the project name of the queue. More... | |
void | work_queue_specify_name (struct work_queue *q, const char *name) |
Change the project name for a given queue. More... | |
void | work_queue_specify_debug_path (struct work_queue *q, const char *path) |
Change the debug log path for a given queue (used by TLQ). More... | |
void | work_queue_specify_tlq_port (struct work_queue *q, int port) |
Change the home host and port for a given queue (used by TLQ). More... | |
void | work_queue_specify_priority (struct work_queue *q, int priority) |
Change the priority for a given queue. More... | |
void | work_queue_specify_num_tasks_left (struct work_queue *q, int ntasks) |
Specify the number of tasks not yet submitted to the queue. More... | |
void | work_queue_specify_catalog_server (struct work_queue *q, const char *hostname, int port) |
Specify the catalog server the manager should report to. More... | |
void | work_queue_specify_catalog_servers (struct work_queue *q, const char *hosts) |
Specify the catalog server(s) the manager should report to. More... | |
struct work_queue_task * | work_queue_cancel_by_taskid (struct work_queue *q, int id) |
Cancel a submitted task using its task id and remove it from queue. More... | |
struct work_queue_task * | work_queue_cancel_by_tasktag (struct work_queue *q, const char *tag) |
Cancel a submitted task using its tag and remove it from queue. More... | |
struct list * | work_queue_cancel_all_tasks (struct work_queue *q) |
Cancel all submitted tasks and remove them from the queue. More... | |
int | work_queue_shut_down_workers (struct work_queue *q, int n) |
Shut down workers connected to the work_queue system. More... | |
void | work_queue_delete (struct work_queue *q) |
Delete a work queue. More... | |
int | work_queue_specify_log (struct work_queue *q, const char *logfile) |
Add a log file that records cummulative statistics of the connected workers and submitted tasks. More... | |
int | work_queue_specify_transactions_log (struct work_queue *q, const char *logfile) |
Add a log file that records the states of the connected workers and tasks. More... | |
void | work_queue_specify_password (struct work_queue *q, const char *password) |
Add a mandatory password that each worker must present. More... | |
int | work_queue_specify_password_file (struct work_queue *q, const char *file) |
Add a mandatory password file that each worker must present. More... | |
void | work_queue_specify_keepalive_interval (struct work_queue *q, int interval) |
Change the keepalive interval for a given queue. More... | |
void | work_queue_specify_keepalive_timeout (struct work_queue *q, int timeout) |
Change the keepalive timeout for identifying dead workers for a given queue. More... | |
void | work_queue_manager_preferred_connection (struct work_queue *q, const char *preferred_connection) |
Set the preference for using hostname over IP address to connect. More... | |
int | work_queue_tune (struct work_queue *q, const char *name, double value) |
Tune advanced parameters for work queue. More... | |
void | work_queue_specify_max_resources (struct work_queue *q, const struct rmsummary *rm) |
Sets the maximum resources a task without an explicit category ("default" category). More... | |
void | work_queue_specify_min_resources (struct work_queue *q, const struct rmsummary *rm) |
Sets the minimum resources a task without an explicit category ("default" category). More... | |
void | work_queue_specify_category_max_resources (struct work_queue *q, const char *category, const struct rmsummary *rm) |
Sets the maximum resources a task in the category may use. More... | |
void | work_queue_specify_category_min_resources (struct work_queue *q, const char *category, const struct rmsummary *rm) |
Sets the minimum resources a task in the category may use. More... | |
void | work_queue_specify_category_first_allocation_guess (struct work_queue *q, const char *category, const struct rmsummary *rm) |
Set the initial guess for resource autolabeling for the given category. More... | |
void | work_queue_initialize_categories (struct work_queue *q, struct rmsummary *max, const char *summaries_file) |
Initialize first value of categories. More... | |
const char * | work_queue_result_str (work_queue_result_t result) |
Explain result codes from tasks. More... | |
Variables | |
int | wq_option_scheduler |
Initial setting for algorithm to assign tasks to workers upon creating queue . More... | |
Functions - Deprecated | |
#define | WORK_QUEUE_TASK_ORDER_FIFO 0 |
Retrieve tasks based on first-in-first-out order. More... | |
#define | WORK_QUEUE_TASK_ORDER_LIFO 1 |
Retrieve tasks based on last-in-first-out order. More... | |
#define | WORK_QUEUE_MANAGER_MODE_STANDALONE 0 |
Work Queue manager does not report to the catalog server. More... | |
#define | WORK_QUEUE_MANAGER_MODE_CATALOG 1 |
Work Queue manager reports to catalog server. More... | |
void | work_queue_specify_task_order (struct work_queue *q, int order) |
Specified how the submitted tasks should be ordered. More... | |
void | work_queue_specify_manager_mode (struct work_queue *q, int mode) |
Specify the manager mode for a given queue. More... | |
void | work_queue_specify_estimate_capacity_on (struct work_queue *q, int estimate_capacity_on) |
Change whether to estimate manager capacity for a given queue. More... | |
int | work_queue_task_specify_input_buf (struct work_queue_task *t, const char *buf, int length, const char *rname) |
Add an input buffer to a task. More... | |
int | work_queue_task_specify_input_file (struct work_queue_task *t, const char *fname, const char *rname) |
Add an input file to a task. More... | |
int | work_queue_task_specify_input_file_do_not_cache (struct work_queue_task *t, const char *fname, const char *rname) |
Add an input file to a task, without caching. More... | |
int | work_queue_task_specify_output_file (struct work_queue_task *t, const char *rname, const char *fname) |
Add an output file to a task. More... | |
int | work_queue_task_specify_output_file_do_not_cache (struct work_queue_task *t, const char *rname, const char *fname) |
Add an output file to a task without caching. More... | |
char * | work_queue_generate_disk_alloc_full_filename (char *pwd, int taskid) |
Generate a worker-level unique filename to indicate a disk allocation being full. More... | |
void | work_queue_task_specify_enviroment_variable (struct work_queue_task *t, const char *name, const char *value) |
Same as work_queue_task_specify_environment_variable, but with a typo in environment. More... | |
A manager-worker library.
The work queue provides an implementation of the manager-worker computing model using TCP sockets, Unix applications, and files as intermediate buffers. A manager process uses work_queue_create to create a queue, then work_queue_submit to submit tasks. Once tasks are running, call work_queue_wait to wait for completion. A generic worker program, named work_queue_worker
, can be run on any machine, and simply needs to be told the host and port of the manager.
#define WORK_QUEUE_DEFAULT_PORT 9123 |
Default Work Queue port number.
#define WORK_QUEUE_RANDOM_PORT 0 |
Indicates that any port may be chosen.
#define WORK_QUEUE_WAITFORTASK -1 |
Timeout value to wait for a task to complete before returning.
#define WORK_QUEUE_DEFAULT_KEEPALIVE_INTERVAL 120 |
Default value for Work Queue keepalive interval in seconds.
#define WORK_QUEUE_DEFAULT_KEEPALIVE_TIMEOUT 30 |
Default value for Work Queue keepalive timeout in seconds.
#define WORK_QUEUE_TASK_ORDER_FIFO 0 |
Retrieve tasks based on first-in-first-out order.
#define WORK_QUEUE_TASK_ORDER_LIFO 1 |
Retrieve tasks based on last-in-first-out order.
#define WORK_QUEUE_MANAGER_MODE_STANDALONE 0 |
Work Queue manager does not report to the catalog server.
#define WORK_QUEUE_MANAGER_MODE_CATALOG 1 |
Work Queue manager reports to catalog server.
enum work_queue_result_t |
enum work_queue_file_t |
struct work_queue_task* work_queue_task_create | ( | const char * | full_command | ) |
Create a new task object.
Once created and elaborated with functions such as work_queue_task_specify_file and work_queue_task_specify_buffer, the task should be passed to work_queue_submit.
full_command | The shell command line to be executed by the task. If null, the command will be given later by work_queue_task_specify_command |
Referenced by work_queue.Task::__init__().
struct work_queue_task* work_queue_task_clone | ( | const struct work_queue_task * | task | ) |
Create a copy of a task
Create a functionally identical copy of a work_queue_task that can be re-submitted via work_queue_submit.
Referenced by work_queue.Task::clone().
void work_queue_task_specify_command | ( | struct work_queue_task * | t, |
const char * | cmd | ||
) |
Indicate the command to be executed.
t | A task object. |
cmd | The command to be executed. This string will be duplicated by this call, so the argument may be freed or re-used afterward. |
Referenced by work_queue.PythonTask::output(), and work_queue.Task::specify_command().
int work_queue_task_specify_file | ( | struct work_queue_task * | t, |
const char * | local_name, | ||
const char * | remote_name, | ||
work_queue_file_type_t | type, | ||
work_queue_file_flags_t | flags | ||
) |
Add a file to a task.
t | A task object. |
local_name | The name of the file on local disk or shared filesystem. |
remote_name | The name of the file at the remote execution site. |
type | Must be one of the following values:
|
flags | May be zero to indicate no special handling or any of work_queue_file_flags_t or'd together. The most common are:
|
Referenced by work_queue.Task::specify_file().
int work_queue_task_specify_file_piece | ( | struct work_queue_task * | t, |
const char * | local_name, | ||
const char * | remote_name, | ||
off_t | start_byte, | ||
off_t | end_byte, | ||
work_queue_file_type_t | type, | ||
work_queue_file_flags_t | flags | ||
) |
Add a file piece to a task.
t | A task object. |
local_name | The name of the file on local disk or shared filesystem. |
remote_name | The name of the file at the remote execution site. |
start_byte | The starting byte offset of the file piece to be transferred. |
end_byte | The ending byte offset of the file piece to be transferred. |
type | Must be one of the following values:
|
flags | May be zero to indicate no special handling or any of work_queue_file_flags_t or'd together. The most common are:
|
Referenced by work_queue.Task::specify_file_piece().
int work_queue_task_specify_buffer | ( | struct work_queue_task * | t, |
const char * | data, | ||
int | length, | ||
const char * | remote_name, | ||
work_queue_file_flags_t | flags | ||
) |
Add an input buffer to a task.
t | A task object. |
data | The data to be passed as an input file. |
length | The length of the buffer, in bytes |
remote_name | The name of the remote file to create. |
flags | May be zero to indicate no special handling or any of work_queue_file_flags_t or'd together. The most common are:
|
Referenced by work_queue.Task::specify_buffer().
int work_queue_task_specify_directory | ( | struct work_queue_task * | t, |
const char * | local_name, | ||
const char * | remote_name, | ||
work_queue_file_type_t | type, | ||
work_queue_file_flags_t | flags, | ||
int | recursive | ||
) |
Add a directory to a task.
t | A task object. |
local_name | The name of the directory on local disk or shared filesystem. Optional if the directory is empty. |
remote_name | The name of the directory at the remote execution site. |
type | Must be one of the following values:
|
flags | May be zero to indicate no special handling or any of work_queue_file_flags_t or'd together. The most common are:
|
recursive | indicates whether just the directory (0) or the directory and all of its contents (1) should be included. |
Referenced by work_queue.Task::specify_directory().
int work_queue_task_specify_file_command | ( | struct work_queue_task * | t, |
const char * | remote_name, | ||
const char * | cmd, | ||
work_queue_file_type_t | type, | ||
work_queue_file_flags_t | flags | ||
) |
Gets/puts file at remote_name using cmd at worker.
t | A task object. |
remote_name | The name of the file as seen by the task. |
cmd | The shell command to transfer the file. For input files, it should read the contents from remote_name via stdin. For output files, it should write the contents to stdout. |
type | Must be one of the following values:
|
flags | May be zero to indicate no special handling or any of work_queue_file_flags_t or'd together. The most common are:
|
Referenced by work_queue.Task::specify_file_command().
void work_queue_task_specify_max_retries | ( | struct work_queue_task * | t, |
int64_t | max_retries | ||
) |
Specify the number of times this task is retried on worker errors.
If less than one, the task is retried indefinitely (this the default). A task that did not succeed after the given number of retries is returned with result WORK_QUEUE_RESULT_MAX_RETRIES.
t | A task object. |
max_retries | The number of retries. |
Referenced by work_queue.Task::specify_max_retries().
void work_queue_task_specify_memory | ( | struct work_queue_task * | t, |
int64_t | memory | ||
) |
Specify the amount of disk space required by a task.
t | A task object. |
memory | The amount of disk space required by the task, in megabytes. |
Referenced by work_queue.Task::specify_memory().
void work_queue_task_specify_disk | ( | struct work_queue_task * | t, |
int64_t | disk | ||
) |
Specify the amount of disk space required by a task.
t | A task object. |
disk | The amount of disk space required by the task, in megabytes. |
Referenced by work_queue.Task::specify_disk().
void work_queue_task_specify_cores | ( | struct work_queue_task * | t, |
int | cores | ||
) |
Specify the number of cores required by a task.
t | A task object. |
cores | The number of cores required by the task. |
Referenced by work_queue.Task::specify_cores().
void work_queue_task_specify_gpus | ( | struct work_queue_task * | t, |
int | gpus | ||
) |
Specify the number of gpus required by a task.
t | A task object. |
gpus | The number of gpus required by the task. |
Referenced by work_queue.Task::specify_gpus().
void work_queue_task_specify_end_time | ( | struct work_queue_task * | t, |
int64_t | useconds | ||
) |
Specify the maximum end time allowed for the task (in microseconds since the Epoch).
If less than 1, then no end time is specified (this is the default). This is useful, for example, when the task uses certificates that expire.
t | A task object. |
useconds | Number of useconds since the Epoch. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_start_time_min | ( | struct work_queue_task * | t, |
int64_t | useconds | ||
) |
Specify the minimum start time allowed for the task (in microseconds since the Epoch).
If less than 1, then no minimum start time is specified (this is the default).
t | A task object. |
useconds | Number of useconds since the Epoch. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_running_time | ( | struct work_queue_task * | t, |
int64_t | useconds | ||
) |
Specify the maximum time (in microseconds) the task is allowed to run in a worker.
This time is accounted since the the moment the task starts to run in a worker. If less than 1, then no maximum time is specified (this is the default).
t | A task object. |
useconds | Maximum number of seconds the task may run in a worker. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_running_time_max | ( | struct work_queue_task * | t, |
int64_t | seconds | ||
) |
Specify the maximum time (in seconds) the task is allowed to run in a worker.
This time is accounted since the moment the task starts to run in a worker. If less than 1, then no maximum time is specified (this is the default). Note: same effect as work_queue_task_specify_running_time.
t | A task object. |
seconds | Maximum number of seconds the task may run in a worker. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_running_time_min | ( | struct work_queue_task * | t, |
int64_t | seconds | ||
) |
Specify the minimum time (in seconds) the task is expected to run in a worker.
This time is accounted since the moment the task starts to run in a worker. If less than 1, then no minimum time is specified (this is the default).
t | A task object. |
seconds | Minimum number of seconds the task may run in a worker. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_tag | ( | struct work_queue_task * | t, |
const char * | tag | ||
) |
Attach a user defined string tag to the task.
This field is not interpreted by the work queue, but is provided for the user's convenience in identifying tasks when they complete.
t | A task object. |
tag | The tag to attach to task t. |
Referenced by work_queue.Task::specify_tag().
void work_queue_task_specify_category | ( | struct work_queue_task * | t, |
const char * | category | ||
) |
Label the task with the given category.
It is expected that tasks with the same category have similar resources requirements (e.g. for fast abort).
t | A task object. |
category | The name of the category to use. |
Referenced by work_queue.Task::specify_category().
void work_queue_task_specify_feature | ( | struct work_queue_task * | t, |
const char * | name | ||
) |
Label the task with a user-defined feature.
The task will only run on a worker that provides (–feature option) such feature.
t | A task object. |
name | The name of the feature. |
Referenced by work_queue.Task::specify_feature().
void work_queue_task_specify_priority | ( | struct work_queue_task * | t, |
double | priority | ||
) |
Specify the priority of this task relative to others in the queue.
Tasks with a higher priority value run first. If no priority is given, a task is placed at the end of the ready list, regardless of the priority.
t | A task object. |
priority | The priority of the task. |
Referenced by work_queue.Task::specify_priority().
void work_queue_task_specify_environment_variable | ( | struct work_queue_task * | t, |
const char * | name, | ||
const char * | value | ||
) |
Specify an environment variable to be added to the task.
t | A task object |
name | Name of the variable. |
value | Value of the variable. |
Referenced by work_queue.Task::specify_environment_variable().
void work_queue_task_specify_algorithm | ( | struct work_queue_task * | t, |
work_queue_schedule_t | algorithm | ||
) |
Select the scheduling algorithm for a single task.
To change the scheduling algorithm for all tasks, use work_queue_specify_algorithm instead.
t | A task object. |
algorithm | The algorithm to use in assigning this task to a worker. For possible values, see work_queue_schedule_t. |
Referenced by work_queue.Task::specify_algorithm().
void work_queue_task_specify_monitor_output | ( | struct work_queue_task * | t, |
const char * | monitor_output | ||
) |
Specify a custom name for the monitoring summary.
If work_queue_enable_monitoring is also enabled, the summary is also written to that directory.
t | A task object. |
monitor_output | Resource summary file. |
Referenced by work_queue.Task::specify_monitor_output().
void work_queue_task_delete | ( | struct work_queue_task * | t | ) |
Delete a task.
This may be called on tasks after they are returned from work_queue_wait.
t | The task to delete. |
Referenced by work_queue.Task::__init__().
int work_queue_specify_snapshot_file | ( | struct work_queue_task * | t, |
const char * | monitor_snapshot_file | ||
) |
When monitoring, indicates a json-encoded file that instructs the
monitor to take a snapshot of the task resources.
Snapshots appear in the JSON summary file of the task, under the key "snapshots". Snapshots are taken on events on files described in the monitor_snapshot_file. The monitor_snapshot_file is a json encoded file with the following format:
{ "FILENAME": { "from-start":boolean, "from-start-if-truncated":boolean, "delete-if-found":boolean, "events": [ { "label":"EVENT_NAME", "on-create":boolean, "on-truncate":boolean, "pattern":"REGEXP", "count":integer }, { "label":"EVENT_NAME", ... } ] }, "FILENAME": { ... }
All fields but label are optional.
from-start:boolean If FILENAME exits when task starts running, process from line 1. Default: false, as the task may be appending to an already existing file. from-start-if-truncated If FILENAME is truncated, process from line 1. Default: true, to account for log rotations. delete-if-found Delete FILENAME when found. Default: false events: label Name that identifies the snapshot. Only alphanumeric, -, and _ characters are allowed. on-create Take a snapshot every time the file is created. Default: false on-truncate Take a snapshot when the file is truncated. Default: false pattern Take a snapshot when a line matches the regexp pattern. Default: none count Maximum number of snapshots for this label. Default: -1 (no limit)
For more information, consult the manual of the resource_monitor.
t | A work queue task object. |
monitor_snapshot_file | A filename. |
Referenced by work_queue.Task::specify_snapshot_file().
struct work_queue* work_queue_create | ( | int | port | ) |
Create a new work queue.
Users may modify the behavior of work_queue_create by setting the following environmental variables before calling the function:
If the queue has a project name, then queue statistics and information will be reported to a catalog server. To specify the catalog server, the user may set the CATALOG_HOST and CATALOG_PORT environmental variables as described in catalog_query_create.
port | The port number to listen on. If zero is specified, then the port stored in the WORK_QUEUE_PORT environment variable is used if available. If it isn't, or if -1 is specified, the first unused port between WORK_QUEUE_LOW_PORT and WORK_QUEUE_HIGH_PORT (1024 and 32767 by default) is chosen. |
struct work_queue* work_queue_ssl_create | ( | int | port, |
const char * | key, | ||
const char * | cert | ||
) |
Create a new work queue using SSL.
Like work_queue_create, but all communications with the queue are encoded using TLS with they key and certificate provided. If key or cert are NULL, then TLS is not activated.
port | The port number to listen on. If zero is specified, then the port stored in the WORK_QUEUE_PORT environment variable is used if available. If it isn't, or if -1 is specified, the first unused port between WORK_QUEUE_LOW_PORT and WORK_QUEUE_HIGH_PORT (1024 and 32767 by default) is chosen. |
key | A key in pem format. |
cert | A certificate in pem format. |
Referenced by work_queue.WorkQueue::__init__().
int work_queue_enable_monitoring | ( | struct work_queue * | q, |
char * | monitor_output_directory, | ||
int | watchdog | ||
) |
Enables resource monitoring on the give work queue.
It generates a resource summary per task, which is written to the given directory. It also creates all_summaries-PID.log, that consolidates all summaries into a single. If monitor_output_dirname is NULL, work_queue_task is updated with the resources measured, and no summary file is kept unless explicitely given by work_queue_task's monitor_output_file.
q | A work queue object. |
monitor_output_directory | The name of the output directory. If NULL, summaries are kept only when monitor_output_directory is specify per task, but resources_measured from work_queue_task is updated. |
watchdog | if not 0, kill tasks that exhaust declared resources. |
Referenced by work_queue.WorkQueue::enable_monitoring().
int work_queue_enable_monitoring_full | ( | struct work_queue * | q, |
char * | monitor_output_directory, | ||
int | watchdog | ||
) |
Enables resource monitoring on the give work queue.
As work_queue_enable_monitoring, but it generates a time series and a monitor debug file (WARNING: for long running tasks these files may reach gigabyte sizes. This function is mostly used for debugging.)
q | A work queue object. |
monitor_output_directory | The name of the output directory. |
watchdog | if not 0, kill tasks that exhaust declared resources. |
Referenced by work_queue.WorkQueue::enable_monitoring_full().
int work_queue_submit | ( | struct work_queue * | q, |
struct work_queue_task * | t | ||
) |
Submit a task to a queue.
Once a task is submitted to a queue, it is not longer under the user's control and should not be inspected until returned via work_queue_wait. Once returned, it is safe to re-submit the same take object via work_queue_submit.
q | A work queue object. |
t | A task object returned from work_queue_task_create. |
Referenced by work_queue.WorkQueue::submit().
int work_queue_specify_min_taskid | ( | struct work_queue * | q, |
int | minid | ||
) |
Set the minimum taskid of future submitted tasks.
Further submitted tasks are guaranteed to have a taskid larger or equal to minid. This function is useful to make taskids consistent in a workflow that consists of sequential managers. (Note: This function is rarely used). If the minimum id provided is smaller than the last taskid computed, the minimum id provided is ignored.
q | A work queue object. |
minid | Minimum desired taskid |
Referenced by work_queue.WorkQueue::specify_min_taskid().
void work_queue_block_host | ( | struct work_queue * | q, |
const char * | hostname | ||
) |
Block workers in hostname from working for queue q.
q | A work queue object. |
hostname | A string for hostname. |
Referenced by work_queue.WorkQueue::block_host().
void work_queue_block_host_with_timeout | ( | struct work_queue * | q, |
const char * | hostname, | ||
time_t | seconds | ||
) |
Block workers in hostname from a queue, but remove block after timeout seconds.
If timeout is less than 1, then the hostname is blocked indefinitely, as if work_queue_block_host was called instead.
q | A work queue object. |
hostname | A string for hostname. |
seconds | Number of seconds to the hostname will be blocked. |
Referenced by work_queue.WorkQueue::block_host_with_timeout().
void work_queue_unblock_host | ( | struct work_queue * | q, |
const char * | hostname | ||
) |
Unblock host from a queue.
q | A work queue object. |
hostname | A string for hostname. |
Referenced by work_queue.WorkQueue::unblock_host().
void work_queue_unblock_all | ( | struct work_queue * | q | ) |
Unblock all host.
q | A work queue object. |
Referenced by work_queue.WorkQueue::unblock_host().
void work_queue_invalidate_cached_file | ( | struct work_queue * | q, |
const char * | local_name, | ||
work_queue_file_t | type | ||
) |
Invalidate cached file.
The file or directory with the given local name specification is deleted from the workers' cache, so that a newer version may be used. Any running task using the file is canceled and resubmitted. Completed tasks waiting for retrieval are not affected. (Currently anonymous buffers and file pieces cannot be deleted once cached in a worker.)
q | A work queue object. |
local_name | The name of the file on local disk or shared filesystem, or uri. |
type | One of: |
Referenced by work_queue.WorkQueue::invalidate_cache_file().
struct work_queue_task* work_queue_wait | ( | struct work_queue * | q, |
int | timeout | ||
) |
Wait for a task to complete.
This call will block until either a task has completed, the timeout has expired, or the queue is empty. If a task has completed, the corresponding task object will be returned by this function. The caller may examine the task and then dispose of it using work_queue_task_delete.
If the task ran to completion, then the result
field will be zero and the return_status
field will contain the Unix exit code of the task. If the task could not, then the result
field will be non-zero and the return_status
field will be undefined.
q | A work queue object. |
timeout | The number of seconds to wait for a completed task before returning. Use an integer time to set the timeout or the constant WORK_QUEUE_WAITFORTASK to block until a task has completed. |
struct work_queue_task* work_queue_wait_for_tag | ( | struct work_queue * | q, |
const char * | tag, | ||
int | timeout | ||
) |
Wait for a task with a given task to complete.
Similar to work_queue_wait, but guarantees that the returned task has the specified tag.
q | A work queue object. |
tag | The desired tag. If NULL, then tasks are returned regardless of their tag. |
timeout | The number of seconds to wait for a completed task before returning. Use an integer time to set the timeout or the constant WORK_QUEUE_WAITFORTASK to block until a task has completed. |
Referenced by work_queue.WorkQueue::wait_for_tag().
int work_queue_hungry | ( | struct work_queue * | q | ) |
Determine whether the queue is 'hungry' for more tasks.
While the Work Queue can handle a very large number of tasks, it runs most efficiently when the number of tasks is slightly larger than the number of active workers. This function gives the user of a flexible application a hint about whether it would be better to submit more tasks via work_queue_submit or wait for some to complete via work_queue_wait.
q | A work queue object. |
Referenced by work_queue.WorkQueue::hungry().
int work_queue_empty | ( | struct work_queue * | q | ) |
Determine whether the queue is empty.
When all of the desired tasks have been submitted to the queue, the user should continue to call work_queue_wait until this function returns true.
q | A work queue object. |
Referenced by work_queue.WorkQueue::empty().
int work_queue_port | ( | struct work_queue * | q | ) |
Get the listening port of the queue.
As noted in work_queue_create, there are many controls that affect what TCP port the queue will listen on. Rather than assuming a specific port, the user should simply call this function to determine what port was selected.
q | A work queue object. |
Referenced by work_queue.WorkQueue::port().
void work_queue_get_stats | ( | struct work_queue * | q, |
struct work_queue_stats * | s | ||
) |
Get queue statistics (only from manager).
q | A work queue object. |
s | A pointer to a buffer that will be filed with statistics. |
Referenced by work_queue.WorkQueue::stats().
void work_queue_get_stats_hierarchy | ( | struct work_queue * | q, |
struct work_queue_stats * | s | ||
) |
Get statistics of the manager queue together with foremen information.
q | A work queue object. |
s | A pointer to a buffer that will be filed with statistics. |
Referenced by work_queue.WorkQueue::stats_hierarchy().
void work_queue_get_stats_category | ( | struct work_queue * | q, |
const char * | c, | ||
struct work_queue_stats * | s | ||
) |
Get the task statistics for the given category.
q | A work queue object. |
c | A category name. |
s | A pointer to a buffer that will be filed with statistics. |
Referenced by work_queue.WorkQueue::stats_category().
char* work_queue_status | ( | struct work_queue * | q, |
const char * | request | ||
) |
Get queue information as json.
q | A work queue object. |
request | One of: queue, tasks, workers, or categories |
Referenced by work_queue.WorkQueue::status().
struct rmsummary** work_queue_workers_summary | ( | struct work_queue * | q | ) |
Summary data for all workers in buffer.
q | A work queue object. |
Referenced by work_queue.WorkQueue::workers_summary().
work_queue_task_state_t work_queue_task_state | ( | struct work_queue * | q, |
int | taskid | ||
) |
Get the current state of the task.
q | A work queue object. |
taskid | The taskid of the task. |
Referenced by work_queue.WorkQueue::task_state().
void work_queue_set_bandwidth_limit | ( | struct work_queue * | q, |
const char * | bandwidth | ||
) |
Limit the queue bandwidth when transferring files to and from workers.
q | A work queue object. |
bandwidth | The bandwidth limit in bytes per second. |
double work_queue_get_effective_bandwidth | ( | struct work_queue * | q | ) |
Get current queue bandwidth.
q | A work queue object. |
char* work_queue_get_worker_summary | ( | struct work_queue * | q | ) |
Summarize workers.
This function summarizes the workers currently connected to the manager, indicating how many from each worker pool are attached.
q | A work queue object. |
int work_queue_activate_fast_abort | ( | struct work_queue * | q, |
double | multiplier | ||
) |
Turn on or off fast abort functionality for a given queue for tasks without
an explicit category.
Given the multiplier, abort a task which running time is larger than the average times the multiplier. Fast-abort is computed per task category. The value specified here applies to all the categories for which work_queue_activate_fast_abort_category was not explicitely called.
q | A work queue object. |
multiplier | The multiplier of the average task time at which point to abort; if less than zero, fast_abort is deactivated (the default). |
Referenced by work_queue.WorkQueue::activate_fast_abort().
int work_queue_activate_fast_abort_category | ( | struct work_queue * | q, |
const char * | category, | ||
double | multiplier | ||
) |
Turn on or off fast abort functionality for a given category.
Given the multiplier, abort a task which running time is larger than the average times the multiplier. The value specified here applies only to tasks in the given category. (Note: work_queue_activate_fast_abort_category(q, "default", n) is the same as work_queue_activate_fast_abort(q, n).)
q | A work queue object. |
category | A category name. |
multiplier | The multiplier of the average task time at which point to abort; if zero, fast_abort is deactivated. If less than zero (default), use the fast abort of the "default" category. |
Referenced by work_queue.WorkQueue::activate_fast_abort_category().
int work_queue_specify_draining_by_hostname | ( | struct work_queue * | q, |
const char * | hostname, | ||
int | drain_flag | ||
) |
Set the draining mode per worker hostname.
If drain_flag is 0, workers at hostname receive tasks as usual.
If drain_flag is not 1, no new tasks are dispatched to workers at hostname, and if empty they are shutdown.
q | A work queue object. |
hostname | The hostname running the worker. |
drain_flag | Draining mode. |
Referenced by work_queue.WorkQueue::specify_draining_by_hostname().
int work_queue_specify_category_mode | ( | struct work_queue * | q, |
const char * | category, | ||
work_queue_category_mode_t | mode | ||
) |
Turn on or off first-allocation labeling for a given category.
By default, cores, memory, and disk are labeled, and gpus are unlabeled. Turn on/off other specific resources use work_queue_enable_category_resource
q | A work queue object. |
category | A category name. |
mode | One of work_queue_category_mode_t. |
Referenced by work_queue.WorkQueue::specify_category_mode().
int work_queue_enable_category_resource | ( | struct work_queue * | q, |
const char * | category, | ||
const char * | resource, | ||
int | autolabel | ||
) |
Turn on or off first-allocation labeling for a given category and resource.
This function should be use to fine-tune the defaults from work_queue_specify_category_mode.
q | A work queue object. |
category | A category name. |
resource | A resource name. |
autolabel | 0 off, 1 on. |
Referenced by work_queue.WorkQueue::specify_category_autolabel_resource().
void work_queue_specify_algorithm | ( | struct work_queue * | q, |
work_queue_schedule_t | algorithm | ||
) |
Change the worker selection algorithm.
This function controls which worker will be selected for a given task.
q | A work queue object. |
algorithm | The algorithm to use in assigning a task to a worker. See work_queue_schedule_t for possible values. |
Referenced by work_queue.WorkQueue::specify_algorithm().
const char* work_queue_name | ( | struct work_queue * | q | ) |
Get the project name of the queue.
q | A work queue object. |
Referenced by work_queue.WorkQueue::name().
void work_queue_specify_name | ( | struct work_queue * | q, |
const char * | name | ||
) |
Change the project name for a given queue.
q | A work queue object. |
name | The new project name. |
Referenced by work_queue.WorkQueue::__init__(), and work_queue.WorkQueue::specify_name().
void work_queue_specify_debug_path | ( | struct work_queue * | q, |
const char * | path | ||
) |
Change the debug log path for a given queue (used by TLQ).
q | A work queue object. |
path | The debug log path. |
void work_queue_specify_tlq_port | ( | struct work_queue * | q, |
int | port | ||
) |
Change the home host and port for a given queue (used by TLQ).
q | A work queue object. |
port | New local port for the TLQ URL. |
void work_queue_specify_priority | ( | struct work_queue * | q, |
int | priority | ||
) |
Change the priority for a given queue.
q | A work queue object. |
priority | The new priority of the queue. Higher priority managers will attract workers first. |
Referenced by work_queue.WorkQueue::specify_priority().
void work_queue_specify_num_tasks_left | ( | struct work_queue * | q, |
int | ntasks | ||
) |
Specify the number of tasks not yet submitted to the queue.
It is used by work_queue_factory to determine the number of workers to launch. If not specified, it defaults to 0. work_queue_factory considers the number of tasks as: num tasks left + num tasks running + num tasks read.
q | A work queue object. |
ntasks | Number of tasks yet to be submitted. |
Referenced by work_queue.WorkQueue::specify_num_tasks_left().
void work_queue_specify_catalog_server | ( | struct work_queue * | q, |
const char * | hostname, | ||
int | port | ||
) |
Specify the catalog server the manager should report to.
q | A work queue object. |
hostname | The catalog server's hostname. |
port | The port the catalog server is listening on. |
Referenced by work_queue.WorkQueue::specify_catalog_server().
void work_queue_specify_catalog_servers | ( | struct work_queue * | q, |
const char * | hosts | ||
) |
Specify the catalog server(s) the manager should report to.
q | A work queue object. |
hosts | The catalog servers given as a comma delimited list of hostnames or hostname:port |
struct work_queue_task* work_queue_cancel_by_taskid | ( | struct work_queue * | q, |
int | id | ||
) |
Cancel a submitted task using its task id and remove it from queue.
q | A work queue object. |
id | The taskid returned from work_queue_submit. |
Referenced by work_queue.WorkQueue::cancel_by_taskid().
struct work_queue_task* work_queue_cancel_by_tasktag | ( | struct work_queue * | q, |
const char * | tag | ||
) |
Cancel a submitted task using its tag and remove it from queue.
q | A work queue object. |
tag | The tag name assigned to task using work_queue_task_specify_tag. |
Referenced by work_queue.WorkQueue::cancel_by_tasktag().
struct list* work_queue_cancel_all_tasks | ( | struct work_queue * | q | ) |
Cancel all submitted tasks and remove them from the queue.
q | A work queue object. |
int work_queue_shut_down_workers | ( | struct work_queue * | q, |
int | n | ||
) |
Shut down workers connected to the work_queue system.
Gives a best effort and then returns the number of workers given the shut down order.
q | A work queue object. |
n | The number to shut down. All workers if given "0". |
Referenced by work_queue.WorkQueue::shutdown_workers().
void work_queue_delete | ( | struct work_queue * | q | ) |
Delete a work queue.
This function should only be called after work_queue_empty returns true.
q | A work queue to delete. |
Referenced by work_queue.WorkQueue::__init__().
int work_queue_specify_log | ( | struct work_queue * | q, |
const char * | logfile | ||
) |
Add a log file that records cummulative statistics of the connected workers and submitted tasks.
q | A work queue object. |
logfile | The filename. |
Referenced by work_queue.WorkQueue::specify_log().
int work_queue_specify_transactions_log | ( | struct work_queue * | q, |
const char * | logfile | ||
) |
Add a log file that records the states of the connected workers and tasks.
q | A work queue object. |
logfile | The filename. |
Referenced by work_queue.WorkQueue::specify_transactions_log().
void work_queue_specify_password | ( | struct work_queue * | q, |
const char * | password | ||
) |
Add a mandatory password that each worker must present.
q | A work queue object. |
password | The password to require. |
Referenced by work_queue.WorkQueue::specify_password().
int work_queue_specify_password_file | ( | struct work_queue * | q, |
const char * | file | ||
) |
Add a mandatory password file that each worker must present.
q | A work queue object. |
file | The name of the file containing the password. |
Referenced by work_queue.WorkQueue::specify_password_file().
void work_queue_specify_keepalive_interval | ( | struct work_queue * | q, |
int | interval | ||
) |
Change the keepalive interval for a given queue.
q | A work queue object. |
interval | The minimum number of seconds to wait before sending new keepalive checks to workers. |
Referenced by work_queue.WorkQueue::specify_keepalive_interval().
void work_queue_specify_keepalive_timeout | ( | struct work_queue * | q, |
int | timeout | ||
) |
Change the keepalive timeout for identifying dead workers for a given queue.
q | A work queue object. |
timeout | The minimum number of seconds to wait for a keepalive response from worker before marking it as dead. |
Referenced by work_queue.WorkQueue::specify_keepalive_timeout().
void work_queue_manager_preferred_connection | ( | struct work_queue * | q, |
const char * | preferred_connection | ||
) |
Set the preference for using hostname over IP address to connect.
'by_ip' uses IP addresses from the network interfaces of the manager (standard behavior), 'by_hostname' to use the hostname at the manager, or 'by_apparent_ip' to use the address of the manager as seen by the catalog server.
q | A work queue object. |
preferred_connection | An string to indicate using 'by_ip' or a 'by_hostname'. |
Referenced by work_queue.WorkQueue::specify_manager_preferred_connection(), and work_queue.WorkQueue::specify_master_preferred_connection().
int work_queue_tune | ( | struct work_queue * | q, |
const char * | name, | ||
double | value | ||
) |
Tune advanced parameters for work queue.
q | A work queue object. |
name | The name of the parameter to tune
|
value | The value to set the parameter to. |
Referenced by work_queue.WorkQueue::tune().
void work_queue_specify_max_resources | ( | struct work_queue * | q, |
const struct rmsummary * | rm | ||
) |
Sets the maximum resources a task without an explicit category ("default" category).
rm specifies the maximum resources a task in the default category may use.
q | Reference to the current work queue object. |
rm | Structure indicating maximum values. See rmsummary for possible fields. |
Referenced by work_queue.WorkQueue::specify_max_resources().
void work_queue_specify_min_resources | ( | struct work_queue * | q, |
const struct rmsummary * | rm | ||
) |
Sets the minimum resources a task without an explicit category ("default" category).
rm specifies the maximum resources a task in the default category may use.
q | Reference to the current work queue object. |
rm | Structure indicating maximum values. See rmsummary for possible fields. |
Referenced by work_queue.WorkQueue::specify_min_resources().
void work_queue_specify_category_max_resources | ( | struct work_queue * | q, |
const char * | category, | ||
const struct rmsummary * | rm | ||
) |
Sets the maximum resources a task in the category may use.
q | Reference to the current work queue object. |
category | Name of the category. |
rm | Structure indicating minimum values. See rmsummary for possible fields. |
Referenced by work_queue.WorkQueue::specify_category_max_resources().
void work_queue_specify_category_min_resources | ( | struct work_queue * | q, |
const char * | category, | ||
const struct rmsummary * | rm | ||
) |
Sets the minimum resources a task in the category may use.
q | Reference to the current work queue object. |
category | Name of the category. |
rm | Structure indicating minimum values. See rmsummary for possible fields. |
Referenced by work_queue.WorkQueue::specify_category_min_resources().
void work_queue_specify_category_first_allocation_guess | ( | struct work_queue * | q, |
const char * | category, | ||
const struct rmsummary * | rm | ||
) |
Set the initial guess for resource autolabeling for the given category.
q | Reference to the current work queue object. |
category | Name of the category. |
rm | Structure indicating maximum values. Autolabeling available for cores, memory, disk, and gpus |
Referenced by work_queue.WorkQueue::specify_category_first_allocation_guess().
void work_queue_initialize_categories | ( | struct work_queue * | q, |
struct rmsummary * | max, | ||
const char * | summaries_file | ||
) |
Initialize first value of categories.
q | Reference to the current work queue object. |
max | Structure indicating maximum values. Autolabeling available for cores, memory, disk, and gpus |
summaries_file | JSON file with resource summaries. |
Referenced by work_queue.WorkQueue::initialize_categories().
const char* work_queue_result_str | ( | work_queue_result_t | result | ) |
Explain result codes from tasks.
result | Result from a task returned by work_queue_wait. |
Referenced by work_queue.Task::result_str().
void work_queue_specify_task_order | ( | struct work_queue * | q, |
int | order | ||
) |
Specified how the submitted tasks should be ordered.
It does not have any effect now.
q | A work queue object. |
order | The ordering to use for dispatching submitted tasks: |
Referenced by work_queue.WorkQueue::specify_task_order().
void work_queue_specify_manager_mode | ( | struct work_queue * | q, |
int | mode | ||
) |
Specify the manager mode for a given queue.
q | A work queue object. |
mode |
|
Referenced by work_queue.WorkQueue::specify_manager_mode(), and work_queue.WorkQueue::specify_master_mode().
void work_queue_specify_estimate_capacity_on | ( | struct work_queue * | q, |
int | estimate_capacity_on | ||
) |
Change whether to estimate manager capacity for a given queue.
q | A work queue object. |
estimate_capacity_on | if the value of this parameter is 1, then work queue should estimate the manager capacity. If the value is 0, then work queue would not estimate its manager capacity. |
Referenced by work_queue.WorkQueue::estimate_capacity().
int work_queue_task_specify_input_buf | ( | struct work_queue_task * | t, |
const char * | buf, | ||
int | length, | ||
const char * | rname | ||
) |
Add an input buffer to a task.
t | The task to which to add parameters |
buf | A pointer to the data buffer to send to the worker to be available to the commands. |
length | The number of bytes of data in the buffer |
rname | The name of the file in which to store the buffer data on the worker |
int work_queue_task_specify_input_file | ( | struct work_queue_task * | t, |
const char * | fname, | ||
const char * | rname | ||
) |
Add an input file to a task.
t | The task to which to add parameters |
fname | The name of the data file to send to the worker to be available to the commands. |
rname | The name of the file in which to store the buffer data on the worker. |
int work_queue_task_specify_input_file_do_not_cache | ( | struct work_queue_task * | t, |
const char * | fname, | ||
const char * | rname | ||
) |
Add an input file to a task, without caching.
t | The task to which to add parameters |
fname | The name of the data file to send to the worker to be available to the commands. |
rname | The name of the file in which to store the buffer data on the worker. |
int work_queue_task_specify_output_file | ( | struct work_queue_task * | t, |
const char * | rname, | ||
const char * | fname | ||
) |
Add an output file to a task.
t | The task to which to add parameters |
rname | The name of a file created by the program when it runs. |
fname | The name of the file local target for copying rname back. |
int work_queue_task_specify_output_file_do_not_cache | ( | struct work_queue_task * | t, |
const char * | rname, | ||
const char * | fname | ||
) |
Add an output file to a task without caching.
t | The task to which to add parameters |
rname | The name of a file created by the program when it runs. |
fname | The name of the file local target for copying rname back. |
char* work_queue_generate_disk_alloc_full_filename | ( | char * | pwd, |
int | taskid | ||
) |
Generate a worker-level unique filename to indicate a disk allocation being full.
pwd | Base pathname. |
taskid | id of the task to generate the filename. |
void work_queue_task_specify_enviroment_variable | ( | struct work_queue_task * | t, |
const char * | name, | ||
const char * | value | ||
) |
Same as work_queue_task_specify_environment_variable, but with a typo in environment.
int wq_option_scheduler |
Initial setting for algorithm to assign tasks to workers upon creating queue .
Change prior to calling work_queue_create, after queue is created this variable is not considered and changes must be made through the API calls.